Skip to content

OpenZeppelin / terraform / 16 jobs #678

OpenZeppelin / terraform / 16 jobs

OpenZeppelin / terraform / 16 jobs #678

Workflow file for this run

name: "OpenZeppelin"
run-name: "OpenZeppelin / ${{ github.event.inputs.network || 'terraform' }} / ${{ github.event.inputs.jobsNumber || '16' }} jobs"
on:
schedule:
- cron: "0 3 * * 0,1,2,3,4"
workflow_dispatch:
inputs:
network:
type: choice
default: terraform
required: true
description: "Stand name"
options:
- night-stand
- devnet
- terraform
jobsNumber:
description: "Count of parallel jobs"
required: true
default: "16"
oz_tag:
description: "Which OZ tag to use (if it is empty, the 'latest' tag will be used)"
required: false
default: latest
env:
JOBS_NUMBER: ${{ github.event.inputs.jobsNumber || '8' }}
NETWORK: ${{ github.event.inputs.network || 'terraform' }}
IMAGE: ${{ github.repository_owner }}/neon_tests
CONTAINER: oz-${{ github.run_id }}
BUILD_URL: "${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}"
DOCKER_HUB_ORG_NAME: ${{ github.repository_owner }}
jobs:
dockerize:
if: github.ref_name != 'develop' || github.event.inputs.oz_tag !=''
runs-on: ["self-hosted", "k8s-prod"]
steps:
- uses: actions/checkout@v4
- name: "Dockerize neon tests"
uses: ./.github/actions/dockerize-neon-tests
with:
image_tag: ${{ github.sha }}
docker_username: ${{ secrets.DOCKER_USERNAME }}
docker_password: ${{ secrets.DOCKER_PASSWORD }}
oz_tag: ${{ github.event.inputs.oz_tag || 'latest' }}
image_name: ${{ env.IMAGE }}
docker_hub_org_name: ${{ github.repository_owner }}
prepare-env:
runs-on: ["self-hosted", "k8s-prod"]
steps:
- uses: actions/checkout@v4
- uses: hashicorp/setup-terraform@v3
- uses: actions/setup-node@v4
with:
node-version: 16
- name: "Prepare terraform stand"
if: ${{ env.NETWORK == 'terraform' }}
id: prepare_terraform
timeout-minutes: 15
env:
AWS_ACCESS_KEY_ID: ${{secrets.AWS_ACCESS_KEY_ID}}
AWS_DEFAULT_REGION: ${{secrets.AWS_DEFAULT_REGION}}
AWS_SECRET_ACCESS_KEY: ${{secrets.AWS_SECRET_ACCESS_KEY}}
HCLOUD_TOKEN: ${{secrets.HCLOUD_TOKEN}}
TFSTATE_BUCKET: ${{vars.TFSTATE_BUCKET}}
TFSTATE_KEY: ${{vars.TFSTATE_KEY_PREFIX}}-${{ github.run_number }}
TFSTATE_REGION: ${{vars.TFSTATE_REGION}}
uses: ./.github/actions/create-tf-stand
with:
ci_stands_key_hcloud: ${{ secrets.CI_STANDS_KEY_HCLOUD }}
- name: "Define outputs"
id: vars
uses: ./.github/actions/define-stand-env
with:
network: ${{ env.NETWORK }}
devnet_solana_url: ${{ secrets.SOLANA_URL }}
devnet_faucet_url: ${{ secrets.DEVNET_FAUCET_URL }}
proxy_ip: ${{ steps.prepare_terraform.outputs.proxy_ip }}
solana_ip: ${{ steps.prepare_terraform.outputs.solana_ip }}
proxy_url: ${{ github.event.inputs.proxy_url }}
solana_url: ${{ github.event.inputs.solana_url }}
faucet_url: ${{ github.event.inputs.faucet_url }}
network_id: ${{ github.event.inputs.network_id }}
outputs:
network: ${{ env.NETWORK }}
solana_url: ${{ steps.prepare_stand.outputs.solana_url }}
proxy_url: ${{ steps.vars.outputs.proxy_url }}
faucet_url: ${{ steps.vars.outputs.faucet_url }}
network_id: ${{ steps.vars.outputs.network_id }}
proxy_ip: ${{ steps.prepare_terraform.outputs.proxy_ip }}
solana_ip: ${{ steps.prepare_terraform.outputs.solana_ip }}
dapps: ${{ steps.dapps.outputs.list }}
tests:
name: OpenZeppelin tests
needs:
- prepare-env
- dockerize
runs-on: ["self-hosted", "k8s-prod"]
if: always() && contains(fromJSON('["success", "skipped"]'), needs.dockerize.result) && needs.prepare-env.result == 'success'
steps:
- uses: actions/checkout@v4
- name: Define image tag
id: image_tag
run: |
if [[ "${{ needs.dockerize.result }}" != "skipped" ]]; then
tag=${{ github.sha }}
else
tag='latest'
fi
echo "tag=${tag}"
echo "tag=${tag}" >> $GITHUB_OUTPUT
- name: Pull docker image
run: docker pull ${{ env.IMAGE }}:${{ steps.image_tag.outputs.tag }}
- name: Run docker container
run: |
docker run -i -d --name=${{ env.CONTAINER }} ${{ env.IMAGE }}:${{ steps.image_tag.outputs.tag }} /bin/bash
- name: Run OpenZeppelin tests
timeout-minutes: 150
run: |
env=''
if [ "${{ env.NETWORK }}" == "terraform" ]; then
env="-e PROXY_IP=${{ needs.prepare-env.outputs.proxy_ip }} -e SOLANA_IP=${{ needs.prepare-env.outputs.solana_ip }}"
fi
echo "env=${env}"
docker exec -i -e OZ_BALANCES_REPORT_FLAG=1 -e DEVNET_FAUCET_URL=${{ env.DEVNET_FAUCET_URL }} ${env} ${{ env.CONTAINER }} python3 ./clickfile.py run oz \
--network ${{ env.NETWORK }} \
--jobs ${{ env.JOBS_NUMBER }} \
--users 10
- name: Print OpenZeppelin report
run: |
docker exec -i ${{ env.CONTAINER }} python3 ./clickfile.py oz report
- name: "Generate allure report"
uses: ./.github/actions/generate-allure-report
with:
container: ${{ env.CONTAINER }}
network: ${{ env.NETWORK }}
aws_access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
tests_name: oz
- name: Analyze tests results
run: |
docker exec -i ${{ env.CONTAINER }} python3 ./clickfile.py oz analyze
- name: "Notify on failure."
if: failure() && github.ref_name == 'develop'
run: |
docker exec -i ${{ env.CONTAINER }} \
python3 ./clickfile.py send-notification -u ${{ secrets.SLACK_QA_CHANNEL_URL }} \
-b ${{ env.BUILD_URL }} -n ${{ env.NETWORK }} --test-group oz
- name: Remove docker container
if: always()
run: docker rm -f ${{ env.CONTAINER }}
destroy:
runs-on: ["self-hosted", "k8s-prod"]
needs: [tests, prepare-env]
if: always() && needs.prepare-env.outputs.network == 'terraform'
steps:
- uses: actions/checkout@v4
- uses: hashicorp/setup-terraform@v3
- uses: actions/setup-node@v4
with:
node-version: 16
- name: "Destroy stand"
env:
AWS_ACCESS_KEY_ID: ${{secrets.AWS_ACCESS_KEY_ID}}
AWS_DEFAULT_REGION: ${{secrets.AWS_DEFAULT_REGION}}
AWS_SECRET_ACCESS_KEY: ${{secrets.AWS_SECRET_ACCESS_KEY}}
HCLOUD_TOKEN: ${{secrets.HCLOUD_TOKEN}}
TFSTATE_BUCKET: ${{vars.TFSTATE_BUCKET}}
TFSTATE_KEY: ${{vars.TFSTATE_KEY_PREFIX}}-${{ github.run_number }}
TFSTATE_REGION: ${{vars.TFSTATE_REGION}}
PROXY_IP: ${{ needs.prepare-env.outputs.proxy_ip }}
SOLANA_IP: ${{ needs.prepare-env.outputs.solana_ip }}
uses: ./.github/actions/destroy-tf-stand
with:
ci_stands_key_hcloud: ${{ secrets.CI_STANDS_KEY_HCLOUD }}
devnet_solana_url: ${{ secrets.SOLANA_URL }}