-
Notifications
You must be signed in to change notification settings - Fork 0
70 lines (57 loc) · 1.81 KB
/
e2e.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
name: E2E Tests
on:
workflow_run:
workflows: [CI]
types:
- completed
jobs:
e2e:
runs-on: ubuntu-latest
if: ${{ github.event.workflow_run.conclusion == 'success' }}
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: '20'
cache: 'yarn'
- name: Install dependencies
run: yarn install --frozen-lockfile
- name: Install Playwright Browsers
run: yarn playwright install --with-deps
- name: Download plugin-dist artifact
uses: actions/download-artifact@v4
with:
github-token: ${{ secrets.GH_PAT }}
merge-multiple: true
path: dist/
pattern: "*-dist"
repository: ${{ github.repository }}
run-id: ${{ github.event.workflow_run.id }}
# actions/download-artifact@v4 does not keep executable permissions
# intact, so we need to restore them manually.
- name: Restore executable permissions
run: |
TARGET_DIR="dist/"
if [ -d "$TARGET_DIR" ]; then
for file in ${TARGET_DIR}gpx_*; do
if [ -f "$file" ] && [ ! -x "$file" ]; then
echo "Setting executable permission for $file"
chmod +x "$file"
fi
done
else
echo "Directory $TARGET_DIR does not exist."
fi
- name: Install and run Docker Compose
uses: isbang/compose-action@v1.5.1
with:
compose-file: './docker-compose.yaml'
- name: Run Playwright tests
run: yarn playwright test
- uses: actions/upload-artifact@v4
if: always()
with:
name: playwright-report
path: playwright-report/
retention-days: 30
timeout-minutes: 60