Skip to content

Commit

Permalink
force python 3.12 usage
Browse files Browse the repository at this point in the history
  • Loading branch information
hatemosphere committed Nov 2, 2023
1 parent ba77b0c commit 5f99c0a
Showing 1 changed file with 83 additions and 81 deletions.
164 changes: 83 additions & 81 deletions .github/workflows/load_testing.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -55,91 +55,93 @@ jobs:
with:
node-version: 16

- uses: actions/setup-python@65d7f2d534ac1bc67fcd62888c5f4f3d2cb2b236 # v4
with:
python-version: '3.12'

- name: Setup Terraform
uses: hashicorp/setup-terraform@v2
with:
terraform_version: 1.5.6

- name: Install Ansible
run: |
python3 --version
python --version
# echo "/home/runner/.local/bin" >> $GITHUB_PATH
# python3 -m pip install --upgrade pip
# pip3 install -r infrastructure/loadtests/ansible/requirements.txt
# ansible-galaxy install -r infrastructure/loadtests/ansible/requirements.yml

# - name: Terraform Init And Apply
# working-directory: infrastructure/loadtests
# run: |
# terraform init
# terraform apply -auto-approve \
# -parallelism=${{ env.NUM_INSTANCES }} \
# -var="num_instances=${{ env.NUM_INSTANCES }}" \
# -var="node_port=${{ env.NODE_PORT }}" \
# -var="metrics_port=${{ env.METRICS_PORT }}" \
# -var="test_id=${{ env.TEST_ID }}"

# - name: Generate list of host:port for config generator
# working-directory: node
# run: |
# sudo apt update && sudo apt install -y gettext-base
# tmp_inventory=$(cat ../infrastructure/loadtests/ansible/gcp.yml)
# echo "${tmp_inventory}" | envsubst > ../infrastructure/loadtests/ansible/gcp.yml

# ansible-inventory -i ../infrastructure/loadtests/ansible/gcp.yml --list | jq -r '.gcp_loadtest.hosts[]' | \
# awk -v port=${{ env.NODE_PORT }} -F\" '{print $1 ":" port}' > ips_prts.txt

# - name: Install node build dependencies
# run: sudo apt update && sudo apt install -y clang

# - uses: actions-rust-lang/setup-rust-toolchain@v1
# id: setup-rust

# - name: Print used Rust versions
# run: |
# echo "Rustc version: ${{ steps.setup-rust.outputs.rustc-version }}"
# echo "Cargo version: ${{ steps.setup-rust.outputs.cargo-version }}"
# echo "Rustup version: ${{ steps.setup-rust.outputs.rustup-version }}"

# - name: Pre-create dirs for node artifacts
# working-directory: node
# run: mkdir -p artifacts/{node_configs,binaries}

# - name: Generate node configs
# working-directory: node
# run: |
# cargo run -p tools \
# --bin localnet_config -- \
# --input-addrs ips_prts.txt \
# --metrics-server-port ${{ env.METRICS_PORT }} \
# --output-dir artifacts/node_configs

# - name: Build executor binary
# working-directory: node
# run: |
# build_output=$(cargo build --release -p tools --bin executor --message-format=json) || exit 1
# echo "$build_output" | jq -r 'select(.executable != null) | .executable' \
# | while read binary; do
# cp "$binary" artifacts/binaries/
# done

# - name: Run ansible
# working-directory: infrastructure/loadtests/ansible
# run: |
# sa_name=$(gcloud iam service-accounts describe [email protected] --format='value(uniqueId)')
# ansible-playbook -i gcp.yml \
# --user sa_${sa_name} \
# --private-key .ssh/google_compute_engine playbook.yml \
# --forks ${{ env.NUM_INSTANCES }}

# - name: Terraform Destroy
# working-directory: infrastructure/loadtests
# if: always()
# run: |
# terraform destroy -auto-approve \
# -parallelism=${{ env.NUM_INSTANCES }} \
# -var="num_instances=${{ env.NUM_INSTANCES }}" \
# -var="node_port=${{ env.NODE_PORT }}" \
# -var="metrics_port=${{ env.METRICS_PORT }}" \
# -var="test_id=${{ env.TEST_ID }}"
echo "/home/runner/.local/bin" >> $GITHUB_PATH
python -m pip install --upgrade pip
pip install -r infrastructure/loadtests/ansible/requirements.txt
ansible-galaxy install -r infrastructure/loadtests/ansible/requirements.yml
- name: Terraform Init And Apply
working-directory: infrastructure/loadtests
run: |
terraform init
terraform apply -auto-approve \
-parallelism=${{ env.NUM_INSTANCES }} \
-var="num_instances=${{ env.NUM_INSTANCES }}" \
-var="node_port=${{ env.NODE_PORT }}" \
-var="metrics_port=${{ env.METRICS_PORT }}" \
-var="test_id=${{ env.TEST_ID }}"
- name: Generate list of host:port for config generator
working-directory: node
run: |
sudo apt update && sudo apt install -y gettext-base
tmp_inventory=$(cat ../infrastructure/loadtests/ansible/gcp.yml)
echo "${tmp_inventory}" | envsubst > ../infrastructure/loadtests/ansible/gcp.yml
ansible-inventory -i ../infrastructure/loadtests/ansible/gcp.yml --list | jq -r '.gcp_loadtest.hosts[]' | \
awk -v port=${{ env.NODE_PORT }} -F\" '{print $1 ":" port}' > ips_prts.txt
- name: Install node build dependencies
run: sudo apt update && sudo apt install -y clang

- uses: actions-rust-lang/setup-rust-toolchain@v1
id: setup-rust

- name: Print used Rust versions
run: |
echo "Rustc version: ${{ steps.setup-rust.outputs.rustc-version }}"
echo "Cargo version: ${{ steps.setup-rust.outputs.cargo-version }}"
echo "Rustup version: ${{ steps.setup-rust.outputs.rustup-version }}"
- name: Pre-create dirs for node artifacts
working-directory: node
run: mkdir -p artifacts/{node_configs,binaries}

- name: Generate node configs
working-directory: node
run: |
cargo run -p tools \
--bin localnet_config -- \
--input-addrs ips_prts.txt \
--metrics-server-port ${{ env.METRICS_PORT }} \
--output-dir artifacts/node_configs
- name: Build executor binary
working-directory: node
run: |
build_output=$(cargo build --release -p tools --bin executor --message-format=json) || exit 1
echo "$build_output" | jq -r 'select(.executable != null) | .executable' \
| while read binary; do
cp "$binary" artifacts/binaries/
done
- name: Run ansible
working-directory: infrastructure/loadtests/ansible
run: |
sa_name=$(gcloud iam service-accounts describe [email protected] --format='value(uniqueId)')
ansible-playbook -i gcp.yml \
--user sa_${sa_name} \
--private-key .ssh/google_compute_engine playbook.yml \
--forks ${{ env.NUM_INSTANCES }}
- name: Terraform Destroy
working-directory: infrastructure/loadtests
if: always()
run: |
terraform destroy -auto-approve \
-parallelism=${{ env.NUM_INSTANCES }} \
-var="num_instances=${{ env.NUM_INSTANCES }}" \
-var="node_port=${{ env.NODE_PORT }}" \
-var="metrics_port=${{ env.METRICS_PORT }}" \
-var="test_id=${{ env.TEST_ID }}"

0 comments on commit 5f99c0a

Please sign in to comment.