-
Notifications
You must be signed in to change notification settings - Fork 0
85 lines (82 loc) · 3.62 KB
/
voucher.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
name: Voucher
on:
push:
branches: [develop]
pull_request:
# defaults to run on opened, reopened, synchronized and assigned
branches: [develop]
env: # Environment variables
PERCY_TOKEN: ${{ secrets.PERCY_TOKEN }}
jobs:
e2e:
name: e2e
# Visual testing must be done on same platform as development
runs-on: ubuntu-20.04
strategy:
fail-fast: false
matrix:
# Opted to implement 6 shards at this juncture due to the relatively higher number of test cases currently available in the voucher section.
# This decision aims to balance resource allocation and testing efficiency, ensuring that we neither overutilize nor underutilize our testing resources.
# As the test suite expands in the future, we will reassess the sharding strategy to accommodate growing demands and maintain optimal performance
shard: [1/6, 2/6, 3/6, 4/6, 5/6, 6/6]
steps:
- uses: actions/checkout@v4
- name: Use Node.js
uses: actions/setup-node@v4
with:
node-version-file: "packages/voucher/.nvmrc"
- name: Cache Node.js modules
uses: actions/cache@v4
with:
path: ~/.pnpm-store
key: ${{ runner.OS }}-node-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.OS }}-node-
${{ runner.OS }}-
- run: corepack enable pnpm
- run: pnpm i --frozen-lockfile
- name: Set up PERCY_PARALLEL_TOTAL
# setting the total number of percy shards as an environment variable. If PERCY_PARALLEL_TOTAL is set to to -1 this tells the API to
# disregard the number of builds created and finalized. The API will then wait for a finalize all builds call, which will close the
# build for that nonce. The Percy CLI sets the total to -1 when the --parallel flag is passed.
run: echo "PERCY_PARALLEL_TOTAL=-1" >> $GITHUB_ENV
- run: npx playwright install-deps
- run: npx playwright install
- run: pnpm --filter @redeem/voucher build
- run: pnpm --filter @redeem/voucher test:e2e:ci --shard ${{ matrix.shard }}
env:
DEBUG: pw:api
- name: Upload failure report to GitHub actions Artificats
if: ${{ failure() }}
uses: actions/upload-artifact@v4
with:
name: diffs
path: test-results/
# Multiple containers are deployed to facilitate the concurrent running of tests. To aggregate all Percy snapshots into a single build,
# an additional job is configured to execute at the conclusion of all test runs. This job is tasked with waiting for all containerized tests to complete,
# subsequently gathering all generated snapshots, and then uploading them cohesively to Percy.
upload-percy-snapshot:
# Merge reports after e2e test, even if some shards have failed
if: ${{ always() }}
needs: [e2e]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version-file: ".nvmrc"
- name: Cache Node.js modules
uses: actions/cache@v4
with:
# npm cache files are stored in `~/.npm` on Linux/macOS
path: ~/.pnpm-store
key: ${{ runner.OS }}-node-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.OS }}-node-
${{ runner.OS }}-
- run: corepack enable pnpm
- name: Download node dependencies from npm cache instead
run: pnpm i --frozen-lockfile --prefer-offline
- name: "Finalise percy build into one"
if: ${{ env.PERCY_TOKEN != '' }}
run: pnpm --filter @redeem/voucher percy:ci:build