name: Test, build and push Docker Image on: # This line enables manual triggering of this workflow. workflow_dispatch: # trigger for pushes to release and master push: branches: [release, master] paths: - "app/client/**" - "app/server/**" - "app/client/packages/rts/**" - "!app/client/cypress/manual_TestSuite/**" jobs: server-build: name: server-build uses: ./.github/workflows/server-build.yml secrets: inherit with: pr: 0 client-build: name: client-build uses: ./.github/workflows/client-build.yml secrets: inherit with: pr: 0 rts-build: name: rts-build uses: ./.github/workflows/rts-build.yml secrets: inherit with: pr: 0 build-docker-image: needs: [client-build, server-build, rts-build] # Only run if the build step is successful if: success() name: build-docker-image uses: ./.github/workflows/build-docker-image.yml secrets: inherit with: pr: 0 perf-test: needs: [build-docker-image] # Only run if the build step is successful if: success() name: perf-test uses: ./.github/workflows/perf-test.yml secrets: inherit with: pr: 0 ci-test: needs: [build-docker-image] # Only run if the build step is successful if: success() name: ci-test uses: ./.github/workflows/ci-test-custom-script.yml secrets: inherit with: pr: 0 ci-test-result: needs: [ci-test] if: always() && (github.event_name == 'workflow_dispatch' || github.event_name == 'push' || (github.event_name == 'pull_request_review' && github.event.review.state == 'approved' && github.event.pull_request.head.repo.full_name == github.repository)) runs-on: ubuntu-latest defaults: run: shell: bash steps: - run: echo "All ci-test matrices completed" # Deleting the existing dir's if any - name: Delete existing directories if: needs.ci-test.result != 'success' run: | rm -f ~/failed_spec_ci rm -f ~/combined_failed_spec_ci # Download failed_spec_ci list for all CI container jobs - uses: actions/download-artifact@v3 if: needs.ci-test.result != 'success' id: download_ci with: name: failed-spec-ci-${{github.run_attempt}} path: ~/failed_spec_ci # In case for any ci job failure, create combined failed spec - name: "combine all specs for CI" if: needs.ci-test.result != 'success' run: | rm -f ~/combined_failed_spec_ci cat ~/failed_spec_ci/failed_spec_ci* >> ~/combined_failed_spec_ci - name: CI test failures if: needs.ci-test.result != 'success' shell: bash run: | new_failed_spec_env="
    $(sort -u ~/combined_failed_spec_ci | sed 's/|cypress|cypress/\n/g' | sed 's/^/
  1. /')
" echo "$new_failed_spec_env" echo "new_failed_spec_env<> $GITHUB_ENV echo "$new_failed_spec_env" >> $GITHUB_ENV echo "EOF" >> $GITHUB_ENV - name: Generate slack message continue-on-error: true if: always() id: slack_notification run: | if [[ "${{ needs.ci-test.result }}" != "success" ]]; then echo "slack_message=There are test failures in the run.
${{env.new_failed_spec_env}}
Please check the <${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}|Github Actions> for more details." >> $GITHUB_OUTPUT echo "slack_color=#FF0000" >> $GITHUB_OUTPUT else echo "slack_message=All tests passed successfully :tada: . Github Action: <${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}|Click here!>" >> $GITHUB_OUTPUT echo "slack_color=#00FF00" >> $GITHUB_OUTPUT fi - name: Slack Notification continue-on-error: true if: always() uses: rtCamp/action-slack-notify@v2 env: SLACK_CHANNEL: cypresspushworkflow SLACK_COLOR: ${{steps.slack_notification.outputs.slack_color}} SLACK_ICON: https://app.slack.com/services/B05D17E4QVB SLACK_TITLE: 'Result:' SLACK_USERNAME: Cypress Push Workflows SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK_HOSTED }} MSG_MINIMAL: Ref,Event,Commit SLACK_FOOTER: 'Appsmith Push Workflows' SLACK_MESSAGE: ${{steps.slack_notification.outputs.slack_message}} # Force save the CI failed spec list into a cache - name: Store the combined run result for CI if: needs.ci-test.result != 'success' uses: martijnhols/actions-cache/save@v3 with: path: | ~/combined_failed_spec_ci key: ${{ github.run_id }}-"ci-test-result" restore-keys: | ${{ github.run_id }}-${{ github.job }} # Upload combined failed CI spec list to a file # This is done for debugging. - name: upload combined failed spec if: needs.ci-test.result != 'success' uses: actions/upload-artifact@v3 with: name: combined_failed_spec_ci path: ~/combined_failed_spec_ci - name: Return status for ui-matrix run: | if [[ "${{ needs.ci-test.result }}" == "success" ]]; then echo "Integration tests completed successfully!"; exit 0; elif [[ "${{ needs.ci-test.result }}" == "skipped" ]]; then echo "Integration tests were skipped"; exit 1; else echo "Integration tests have failed"; exit 1; fi package-release: needs: build-docker-image runs-on: ubuntu-latest # Set permissions since we're using OIDC token authentication between Depot and GitHub permissions: contents: read id-token: write # Run this job as soon as the docker image is ready, if this is the release branch if: ( always() && github.ref == 'refs/heads/release' ) steps: - name: Checkout the head commit of the branch if: github.event_name == 'push' || github.event_name == 'workflow_dispatch' uses: actions/checkout@v3 - name: Download the react build artifact uses: actions/download-artifact@v3 with: name: client-build path: app/client - name: Unpack the client build artifact if: steps.run_result.outputs.run_result != 'success' run: | mkdir -p app/client/build tar -xvf app/client/build.tar -C app/client/build - name: Download the server build artifact uses: actions/download-artifact@v3 with: name: server-build path: app/server/dist - name: Download the rts build artifact uses: actions/download-artifact@v3 with: name: rts-dist path: app/client/packages/rts/dist - name: Untar the rts folder run: | tar -xvf app/client/packages/rts/dist/rts-dist.tar -C app/client/packages/rts/ echo "Cleaning up the tar files" rm app/client/packages/rts/dist/rts-dist.tar - name: Generate info.json run: | if [[ -f scripts/generate_info_json.sh ]]; then scripts/generate_info_json.sh fi - name: Set up Depot CLI uses: depot/setup-action@v1 - name: Login to DockerHub uses: docker/login-action@v2 with: username: ${{ secrets.DOCKER_HUB_USERNAME }} password: ${{ secrets.DOCKER_HUB_ACCESS_TOKEN }} - name: Build and push release image to Docker Hub if: success() uses: depot/build-push-action@v1 with: context: . push: true platforms: linux/arm64,linux/amd64 build-args: | APPSMITH_SEGMENT_CE_KEY=${{ secrets.APPSMITH_SEGMENT_CE_KEY_RELEASE }} APPSMITH_CLOUD_SERVICES_BASE_URL=https://release-cs.appsmith.com tags: | ${{ vars.DOCKER_HUB_ORGANIZATION }}/appsmith-${{ vars.EDITION }}:release package-master: needs: ci-test runs-on: ubuntu-latest # Set permissions since we're using OIDC token authentication between Depot and GitHub permissions: contents: read id-token: write # Run this job irrespective of tests failing, if this is the release branch; or only if the tests pass, if this is the master branch. if: ( success() && github.ref == 'refs/heads/master' ) steps: - name: Checkout the head commit of the branch if: github.event_name == 'push' || github.event_name == 'workflow_dispatch' uses: actions/checkout@v3 - name: Download the react build artifact uses: actions/download-artifact@v3 with: name: client-build path: app/client - name: Unpack the client build artifact if: steps.run_result.outputs.run_result != 'success' run: | mkdir -p app/client/build tar -xvf app/client/build.tar -C app/client/build - name: Download the server build artifact uses: actions/download-artifact@v3 with: name: server-build path: app/server/dist - name: Download the rts build artifact uses: actions/download-artifact@v3 with: name: rts-dist path: app/client/packages/rts/dist - name: Untar the rts folder run: | tar -xvf app/client/packages/rts/dist/rts-dist.tar -C app/client/packages/rts/ echo "Cleaning up the tar files" rm app/client/packages/rts/dist/rts-dist.tar - name: Generate info.json run: | if [[ -f scripts/generate_info_json.sh ]]; then scripts/generate_info_json.sh fi - name: Set up Depot CLI uses: depot/setup-action@v1 - name: Login to DockerHub uses: docker/login-action@v2 with: username: ${{ secrets.DOCKER_HUB_USERNAME }} password: ${{ secrets.DOCKER_HUB_ACCESS_TOKEN }} - name: Build and push master image to Docker Hub with commit tag if: success() uses: depot/build-push-action@v1 with: context: . push: true platforms: linux/arm64,linux/amd64 build-args: | APPSMITH_SEGMENT_CE_KEY=${{ secrets.APPSMITH_SEGMENT_CE_KEY }} tags: | ${{ vars.DOCKER_HUB_ORGANIZATION }}/appsmith-${{ vars.EDITION }}:${{ github.sha }} ${{ vars.DOCKER_HUB_ORGANIZATION }}/appsmith-${{ vars.EDITION }}:nightly