This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# # Workflow starts automatically on push or can be triggered manually. | |
# # This is a desirable pattern as it allows for adhoc test runs without a code push | |
# name: Cypress tests | |
# on: [push, workflow_dispatch] | |
# # on: | |
# # push: | |
# # branches: | |
# # - 'release-0.2.0' | |
# # pull_request: | |
# # workflow_dispatch: | |
# jobs: | |
# cypress-run: | |
# runs-on: ubuntu-latest | |
# strategy: | |
# fail-fast: false | |
# # In order for Cypress to run well, it needs to be fed the needed parameters. | |
# # The below is a mix of Cypress environment variables (All capital) and ones that are needed for this specific set of scripts (Mix of capital and lowercase) | |
# env: | |
# admin_idir_username: ${{ secrets.ADMIN_IDIR_USERNAME }}, | |
# admin_idir_password: ${{ secrets.ADMIN_IDIR_PASSWORD }}, | |
# org1_bceid_username: ${{ secrets.ORG1_BCEID_USERNAME }}, | |
# org1_bceid_password: ${{ secrets.ORG1_BCEID_PASSWORD }}, | |
# org1_bceid_id: ${{ secrets.ORG1_BCEID_ID }}, | |
# org1_bceid_userId: ${{ secrets.ORG1_BCEID_USERID }}, | |
# org2_bceid_username: ${{ secrets.ORG2_BCEID_USERNAME }}, | |
# org2_bceid_password: ${{ secrets.ORG2_BCEID_PASSWORD }}, | |
# org2_bceid_id: ${{ secrets.ORG2_BCEID_ID }}, | |
# org2_bceid_userId: ${{ secrets.ORG2_BCEID_USERID }} | |
# steps: | |
# # Checkout the PR branch | |
# - name: Checkout Target Branch | |
# uses: actions/checkout@v4 | |
# # We are cache-ing our node modules to slightly speed up execution in the future. | |
# - name: Cache node modules | |
# id: cache-npm | |
# uses: actions/cache@v4 | |
# env: | |
# cache-name: cache-node-modules | |
# with: | |
# # npm cache files are stored in `~/.npm` on Linux/macOS | |
# path: ~/.npm | |
# key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }} | |
# restore-keys: | | |
# ${{ runner.os }}-build-${{ env.cache-name }}- | |
# ${{ runner.os }}-build- | |
# ${{ runner.os }}- | |
# - if: ${{ steps.cache-npm.outputs.cache-hit != 'true' }} | |
# name: List the state of node modules | |
# continue-on-error: true | |
# run: npm list | |
# - name: Install dependencies | |
# run: sudo apt-get install -y libgtk2.0-0 libgtk-3-0 libgbm-dev | |
# # Many solutions have an API and APP that start fairly slow (specifically when not many resources are available). | |
# # Since the APP needs the API and Cypress needs the APP, we first have to test if the API is running and accessible. | |
# # Often an OK from the OpenShift deploy does not automatically mean that the API/APP is functional and/or reachable. | |
# # We like to use a straightforward CURL command, which we have included as a script in this repo. | |
# # - name: Wait for API response | |
# # env: | |
# # url: ${{ secrets.CYPRESS_API_HOST }} | |
# # code: 200 # The HTML Code we expect to get back | |
# # wait_time: 10 # Wait time in seconds between each attempt total wait time = wait_time * max_attempts | |
# # max_attempts: 5 | |
# # run: | | |
# # cd frontend | |
# # chmod +x waitforconnection.sh | |
# # bash ./waitforconnection.sh | |
# # - name: Wait for APP response | |
# # env: | |
# # url: ${{ secrets.CYPRESS_HOST }} | |
# # code: 200 | |
# # wait_time: 10 | |
# # max_attempts: 5 | |
# # run: | | |
# # cd frontend | |
# # chmod +x waitforconnection.sh | |
# # bash ./waitforconnection.sh | |
# # This is the actual Cypress action, invoked with a set of extra parameters. | |
# # Wait-on/wait-on-timeout: This is the Cypress way of waiting for a response from the application under test, but it does not address the API readiness hence the above Waits. | |
# # record: Switches on recording to the cloud-based Cypress dahsboard | |
# # install-command: Since we are forcing our libraries (keycloak) to be installed because of version issues, we have to specify "npm ci -f" to install as the normal "npm ci" would results in errors. | |
# # If you do not run additional libraries or forced the libraries to install, the this option can be left out. | |
# # working-directory: points to where you test scripts are located | |
# # browser: Specifies which browser you want to use. The default is 'Electron', but we would typically user 'Chrome' as this represent the majority of our users. | |
# # ci-build-id: to communicate the PR/Build number to the Cypress Dashboard | |
# # - name: E2E Smoke tests | |
# # uses: cypress-io/github-action@v6 | |
# # # let's give this action an ID so we can refer | |
# # # to its output values later | |
# # id: smoke | |
# # continue-on-error: false | |
# # with: | |
# # wait-on: ${{ secrets.CYPRESS_HOST }} | |
# # wait-on-timeout: 120 | |
# # start: npm run cypress:dev | |
# # install-command: npm ci -f | |
# # working-directory: frontend | |
# # browser: chrome | |
# # ci-build-id: ${{ github.event.number }} | |
# - name: Install Dependencies | |
# run: npm ci -f | |
# working-directory: frontend | |
# - name: Run Cypress Tests | |
# run: npm run cypress:dev | |
# working-directory: frontend | |
# - name: Debug Cypress Run | |
# if: failure() | |
# run: cat /home/runner/work/lcfs/lcfs/frontend/cypress/reports/*.json | |
# - uses: actions/upload-artifact@v3 | |
# if: failure() | |
# with: | |
# name: cypress-screenshots | |
# path: /home/runner/work/lcfs/lcfs/frontend/cypress/screenshots | |
# # For review/debug purposes, just print out key parameters | |
# - name: Print Env Vars | |
# run: | | |
# echo Git Base Ref: ${{ github.base_ref }} | |
# echo Git Change ID: ${{ github.event.number }} |