From da01ccca0a5bebec0261310a76527e67d3336de2 Mon Sep 17 00:00:00 2001 From: Timothy Le Bon Date: Tue, 26 Nov 2024 16:34:29 +0100 Subject: [PATCH] chore: update pipeline to build app --- .github/workflows/precommit.yml | 107 +++++++++++++++++++++----------- 1 file changed, 71 insertions(+), 36 deletions(-) diff --git a/.github/workflows/precommit.yml b/.github/workflows/precommit.yml index a7bc8e1e07b..8ed113532b7 100644 --- a/.github/workflows/precommit.yml +++ b/.github/workflows/precommit.yml @@ -10,13 +10,20 @@ concurrency: cancel-in-progress: true jobs: - procommit-deploy: + precommit-deploy: runs-on: buildjet-8vcpu-ubuntu-2204 + outputs: + unit_tests_report: ${{ env.UNIT_TEST_REPORT_FILE }} + build_artifact: ${{ env.BUILD_ARTIFACT }} + env: - DEPLOYMENT_RECOVERY_TIMEOUT_SECONDS: 150 - AWS_APPLICATION_NAME: Webapp - AWS_BUILD_ZIP_PATH: server/dist/s3/ebs.zip + BUILD_DIR: server/dist/s3/ + BUILD_ARTIFACT: ebs.zip + COMMIT_URL: ${{github.event.head_commit.url}} + COMMITTER: ${{github.event.head_commit.committer.name}} + CHANGELOG_FILE: './changelog.md' + UNIT_TEST_REPORT_FILE: './unit-tests.log' steps: - name: Checkout @@ -31,6 +38,29 @@ jobs: - name: Install JS dependencies run: yarn --immutable + - name: Update configuration + run: yarn configure + + # - name: Test + # run: | + # set -o pipefail + # yarn test --detectOpenHandles=false 2>&1 | tee ${{ env.UNIT_TEST_REPORT_FILE }} + # echo -e "COMMIT SHA = ${{ github.sha }}" >> ${{env.UNIT_TEST_REPORT_FILE}} + # echo -e "TEST RUN DATE = $(date -u +'%Y-%m-%dT%H:%M:%SZ')" >> ${{env.UNIT_TEST_REPORT_FILE}} + + # - uses: actions/upload-artifact@v4 + # with: + # name: 'unit-tests-report' + # path: ${{env.UNIT_TEST_REPORT_FILE}} + + - name: Build + run: yarn build:prod + + - uses: actions/upload-artifact@v4 + with: + name: 'build-artifact' + path: '${{env.BUILD_DIR}}${{env.BUILD_ARTIFACT}}' + - name: Fetch PR details id: pr_details uses: octokit/request-action@v2.x @@ -47,37 +77,42 @@ jobs: echo "Total additions: $total_additions" echo "total_additions=$total_additions" >> $GITHUB_ENV - - name: Deploy to precommit environment - id: deploy - if: ${{ env.total_additions > 100 && github.actor != 'dependabot[bot]' }} - uses: einaregilsson/beanstalk-deploy@v22 - with: - application_name: ${{ env.AWS_APPLICATION_NAME }} - aws_access_key: ${{ secrets.WEBTEAM_AWS_ACCESS_KEY_ID }} - aws_secret_key: ${{ secrets.WEBTEAM_AWS_SECRET_ACCESS_KEY }} - deployment_package: ${{ env.AWS_BUILD_ZIP_PATH }} - environment_name: wire-webapp-precommit - region: eu-central-1 - use_existing_version_if_available: true - version_description: ${{ github.sha }} - version_label: ${{ github.run_id }} - wait_for_deployment: false - wait_for_environment_recovery: ${{ env.DEPLOYMENT_RECOVERY_TIMEOUT_SECONDS }} - - - name: Deployment Status - if: ${{ always() }} - run: | - if [[ "${{ steps.deploy.outcome }}" == "success" ]]; then - echo "✅ Deployment completed successfully" - elif [[ "${{ steps.deploy.outcome }}" == "skipped" ]]; then - if [[ "${{ env.total_additions }}" -le 100 ]]; then - echo "⏭️ Deployment was skipped: PR has ${{ env.total_additions }} additions (threshold: 100)" - elif [[ "${{ github.actor }}" == "dependabot[bot]" ]]; then - echo "⏭️ Deployment was skipped: PR is from dependabot" - else - echo "⏭️ Deployment was skipped" - fi + deploy_to_aws: + - uses: actions/download-artifact@v4 + with: + name: 'build-artifact' + + - name: Deploy to precommit environment + id: deploy + if: ${{ env.total_additions > 100 && github.actor != 'dependabot[bot]' }} + uses: einaregilsson/beanstalk-deploy@v22 + with: + application_name: Webapp + aws_access_key: ${{ secrets.WEBTEAM_AWS_ACCESS_KEY_ID }} + aws_secret_key: ${{ secrets.WEBTEAM_AWS_SECRET_ACCESS_KEY }} + deployment_package: ${{needs.build.outputs.build_artifact}} + environment_name: wire-webapp-precommit + region: eu-central-1 + use_existing_version_if_available: true + version_description: ${{ github.sha }} + version_label: ${{ github.run_id }} + wait_for_deployment: false + wait_for_environment_recovery: 150 + + - name: Deployment Status + if: ${{ always() }} + run: | + if [[ "${{ steps.deploy.outcome }}" == "success" ]]; then + echo "✅ Deployment completed successfully" + elif [[ "${{ steps.deploy.outcome }}" == "skipped" ]]; then + if [[ "${{ env.total_additions }}" -le 100 ]]; then + echo "⏭️ Deployment was skipped: PR has ${{ env.total_additions }} additions (threshold: 100)" + elif [[ "${{ github.actor }}" == "dependabot[bot]" ]]; then + echo "⏭️ Deployment was skipped: PR is from dependabot" else - echo "❌ Deployment failed" - exit 1 + echo "⏭️ Deployment was skipped" fi + else + echo "❌ Deployment failed" + exit 1 + fi