name: Run E2E tests k8s on: pull_request_review: types: [submitted] workflow_dispatch: env: K8S_LOCAL_PORT: ${{ secrets.K8S_LOCAL_PORT }} K8S_HOST: ${{ secrets.K8S_HOST }} BASTION_HOST: ${{ secrets.BASTION_HOST }} K8S_PORT: ${{ secrets.K8S_PORT }} USERNAME: ${{ secrets.USERNAME }} BASTION_SSH_KEY: ${{secrets.BASTION_SSH_KEY}} RELEASE_VERSION: 5.1.5 jobs: push_to_registry: if: github.event.review.state == 'approved' name: Push Docker image to Docker Hub runs-on: ubuntu-latest outputs: release-version: ${{ steps.output-step.outputs.release-version }} short-sha: ${{ steps.output-step.outputs.short-sha }} steps: - name: Check out the repo uses: actions/checkout@v3 - name: Set up QEMU uses: docker/setup-qemu-action@v2 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v2 - name: Log in to Docker Hub uses: docker/login-action@v2 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_PASSWORD }} - name: Extract metadata (tags, labels) for Docker id: meta uses: docker/metadata-action@v4 with: images: blockscout/blockscout - name: Add SHORT_SHA env property with commit short sha run: echo "SHORT_SHA=`echo ${GITHUB_SHA} | cut -c1-8`" >> $GITHUB_ENV - name: Add outputs run: | echo "::set-output name=short-sha::${{ env.SHORT_SHA }}" id: output-step - name: Build and push Docker image uses: docker/build-push-action@v3 with: context: . file: ./docker/Dockerfile push: true cache-from: type=registry,ref=blockscout/blockscout:pr-buildcache cache-to: type=registry,ref=blockscout/blockscout:pr-buildcache,mode=max tags: blockscout/blockscout:pr-${{ env.SHORT_SHA }} build-args: | CACHE_EXCHANGE_RATES_PERIOD= API_V1_READ_METHODS_DISABLED=false DISABLE_WEBAPP=false API_V1_WRITE_METHODS_DISABLED=false CACHE_TOTAL_GAS_USAGE_COUNTER_ENABLED= ADMIN_PANEL_ENABLED=false DECODE_NOT_A_CONTRACT_CALLS=false MIXPANEL_URL= MIXPANEL_TOKEN= AMPLITUDE_URL= AMPLITUDE_API_KEY= CACHE_ADDRESS_WITH_BALANCES_UPDATE_INTERVAL= BLOCKSCOUT_VERSION=v${{ env.RELEASE_VERSION }}-beta.+commit.${{ env.SHORT_SHA }} RELEASE_VERSION=${{ env.RELEASE_VERSION }} deploy_and_tests: needs: push_to_registry if: github.event.review.state == 'approved' uses: blockscout/blockscout-ci-cd/.github/workflows/e2e_new.yaml@master with: blockscoutImage: blockscout/blockscout:pr-${{ needs.push_to_registry.outputs.short-sha }} blockscoutIngressHost: e2e-blockscout-$GITHUB_SHA_SHORT frontendIngressHost: e2e-blockscout-$GITHUB_SHA_SHORT gethIngressHost: e2e-geth-$GITHUB_SHA_SHORT scVerifierIngressHost: e2e-sc-verifier-$GITHUB_SHA_SHORT secrets: inherit