Implement Cypress-recommended workflow by replacing test.yml with cyp… #1
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
name: Cypress Tests | |
on: [push] | |
jobs: | |
cypress-run: | |
runs-on: ubuntu-latest | |
strategy: | |
fail-fast: false | |
matrix: | |
node: [18, 20, 22] | |
containers: [1, 2] | |
name: E2E Testing with Cypress | |
env: | |
CI: false | |
steps: | |
- name: Checkout Repository | |
uses: actions/checkout@v4 | |
with: | |
persist-credentials: false | |
- name: Setup Node.js Environment | |
uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ matrix.node }} | |
- name: Cache Node.js modules | |
uses: actions/cache@v3 | |
with: | |
path: ~/.npm | |
key: ${{ runner.os }}-node-${{ matrix.node }}-${{ hashFiles('**/package-lock.json') }} | |
restore-keys: | | |
${{ runner.os }}-node-${{ matrix.node }}- | |
- name: Create .env File | |
run: | | |
echo "VITE_APP_FIREBASE_API_KEY=${{ secrets.VITE_APP_FIREBASE_API_KEY }}" >> .env | |
echo "VITE_APP_FIREBASE_PROJECT_ID=${{ secrets.VITE_APP_FIREBASE_PROJECT_ID }}" >> .env | |
echo "VITE_APP_FIREBASE_MESSAGING_SENDER_ID=${{ secrets.VITE_APP_FIREBASE_MESSAGING_SENDER_ID }}" >> .env | |
echo "VITE_APP_FIREBASE_APP_ID=${{ secrets.VITE_APP_FIREBASE_APP_ID }}" >> .env | |
echo "VITE_APP_FIREBASE_MEASUREMENTID=${{ secrets.VITE_APP_FIREBASE_MEASUREMENTID }}" >> .env | |
echo "VITE_APP_FIREBASE_FCM_VAPID_KEY=${{ secrets.VITE_APP_FIREBASE_FCM_VAPID_KEY }}" >> .env | |
echo "VITE_APP_AUTH_DOMAIN=${{ secrets.VITE_APP_AUTH_DOMAIN }}" >> .env | |
echo "VITE_APP_DATABASE_URL=${{ secrets.VITE_APP_DATABASE_URL }}" >> .env | |
echo "VITE_APP_USE_EMULATOR=true" >> .env | |
echo "SKIP_PREFLIGHT_CHECK=true" >> .env | |
echo "CI=false" >> .env | |
echo "CYPRESS_PROJECT_ID=${{ secrets.CYPRESS_PROJECT_ID }}" >> .env | |
- name: Prepare Firebase Service Account | |
run: | | |
cd functions | |
mkdir -p private | |
echo "${{ secrets.FIREBASE_SERVICE_ACCOUNT_CODELABZ_2CD64 }}" > private/cl-dev-pk.json | |
- name: Install Functions Dependencies | |
run: cd functions && npm install --legacy-peer-deps | |
- name: Install Firebase CLI | |
run: npm install -g firebase-tools | |
- name: Start Firebase Emulators | |
run: | | |
firebase emulators:start --import=./testdata --project ${{ secrets.VITE_APP_FIREBASE_PROJECT_ID }} & | |
sleep 15 | |
- name: Run Cypress Tests | |
uses: cypress-io/github-action@v6 | |
with: | |
config-file: cypress.config.js | |
group: "GitHub Actions" | |
install-command: npm install --legacy-peer-deps | |
# build: npm run build | |
start: npm run dev | |
wait-on: "http://localhost:5173" | |
browser: chrome | |
record: true | |
parallel: true | |
tag: node-${{ matrix.node }} | |
env: | |
CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORD_KEY }} | |
CYPRESS_PROJECT_ID: ${{ secrets.CYPRESS_PROJECT_ID }} | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
COMMIT_INFO_BRANCH: ${{ github.ref_name }} | |
- name: Upload Cypress Artifacts | |
uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: Cypress Artifacts | |
path: | | |
cypress/screenshots | |
cypress/videos/ | |
- name: Print Cypress Cloud URL | |
if: always() | |
run: | | |
echo Cypress finished with: ${{ steps.cypress.outcome }} | |
echo See results at ${{ steps.cypress.outputs.resultsUrl }} | |
- name: Notify on Failure | |
if: failure() | |
run: echo "The workflow has failed!" |