name: Client Unit Tests on: # This line enables manual triggering of this workflow. workflow_dispatch: workflow_call: inputs: pr: description: "This is the PR number in case the workflow is being called in a pull request" required: false type: number skip-tests: description: "This is a boolean value in case the workflow is being called in build deploy-preview" required: false type: string default: "false" pull_request: branches: [release, master] paths: - "app/client/**" - "!app/client/cypress/manual_TestSuite/**" # Change the working directory for all the jobs in this workflow defaults: run: working-directory: app/client jobs: build: runs-on: ubuntu-latest-8-cores # Only run this workflow for internally triggered events if: | github.event.pull_request.head.repo.full_name == github.repository || github.event_name == 'push' || github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' defaults: run: working-directory: app/client shell: bash steps: # The checkout steps MUST happen first because the default directory is set according to the code base. # GitHub Action expects all future commands to be executed in the code directory. Hence, we need to check out # the code before doing anything else. # Check out merge commit with the base branch in case this workflow is invoked via pull request - name: Checkout the merged commit from PR and base branch if: inputs.pr != 0 uses: actions/checkout@v3 with: fetch-depth: 0 ref: refs/pull/${{ inputs.pr }}/merge # Checkout the code in the current branch in case the workflow is called because of a branch push event - name: Checkout the head commit of the branch if: inputs.pr == 0 uses: actions/checkout@v3 with: fetch-depth: 0 # In case this is second attempt try restoring status of the prior attempt from cache - name: Restore the previous run result uses: actions/cache@v3 with: path: | ~/run_result key: ${{ github.run_id }}-${{ github.job }}-client # Fetch prior run result - name: Get the previous run result id: run_result run: cat ~/run_result 2>/dev/null || echo 'default' # In case of prior failure run the job - if: steps.run_result.outputs.run_result != 'success' run: echo "I'm alive!" && exit 0 - name: Use Node.js 16.14.0 if: steps.run_result.outputs.run_result != 'success' uses: actions/setup-node@v3 with: node-version: "16.14.0" # actions/setup-node@v3 doesn’t work properly with Yarn 3 # when the project lives in a subdirectory: https://github.com/actions/setup-node/issues/488 # Restoring the cache manually instead - name: Restore Yarn cache if: steps.run_result.outputs.run_result != 'success' uses: actions/cache@v3 with: path: app/client/.yarn/cache key: v1-yarn3-${{ hashFiles('app/client/yarn.lock') }} restore-keys: | v1-yarn3- # Install all the dependencies - name: Install dependencies if: steps.run_result.outputs.run_result != 'success' run: yarn install --immutable # Run the Unit tests for client and packages - name: Run the jest tests if: steps.run_result.outputs.run_result != 'success' run: yarn run test:unit:ci # Saving the cache to use it in subsequent runs - name: Save Yarn cache uses: actions/cache/save@v3 with: path: app/client/.yarn/cache key: v1-yarn3-${{ hashFiles('app/client/yarn.lock') }} restore-keys: | v1-yarn3- # Set status = success - name: Save the status of the run run: echo "run_result=success" >> $GITHUB_OUTPUT > ~/run_result