-
Notifications
You must be signed in to change notification settings - Fork 142
131 lines (109 loc) · 3.35 KB
/
ai.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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
name: AI test
on:
push:
branches:
- main
workflow_dispatch:
inputs:
branch:
description: 'Branch to checkout'
required: false
default: 'main'
type: string
jobs:
main:
runs-on: ubuntu-22.04
strategy:
matrix:
node-version: [18.19.0]
env:
OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }}
OPENAI_BASE_URL: ${{ secrets.OPENAI_BASE_URL }}
MIDSCENE_MODEL_NAME: gpt-4o-2024-08-06
CI: 1
# MIDSCENE_DEBUG_AI_PROFILE: 1
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
ref: ${{ github.event.inputs.branch || 'main' }}
- name: Setup pnpm
uses: pnpm/action-setup@v2
with:
version: 9.3.0
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: '18'
cache: 'pnpm'
- name: Cache Playwright dependencies
uses: actions/cache@v3
id: cache-playwright
with:
path: ~/.cache/ms-playwright
key: ${{ runner.os }}-playwright-${{ hashFiles('pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-playwright-
- name: Install dependencies
run: pnpm install --frozen-lockfile
- name: Install Playwright dependencies
run: |
cd packages/web-integration
if [ "${{ steps.cache-playwright.outputs.cache-hit }}" != "true" ]; then
npx playwright install --with-deps
else
npx playwright install-deps && npx playwright install
fi
- name: Install puppeteer dependencies
run: |
cd packages/web-integration
npx puppeteer browsers install chrome
- name: Build project
run: pnpm run build
- name: Run e2e tests
run: pnpm run e2e
id: e2e-tests
continue-on-error: true
- name: Upload e2e report
if: always()
uses: actions/upload-artifact@v4
with:
name: e2e-report
path: ${{ github.workspace }}/packages/web-integration/midscene_run/report
if-no-files-found: ignore
- name: Run e2e tests cache
run: pnpm run e2e:cache
id: e2e-tests-cache
continue-on-error: true
- name: Upload e2e cache report
if: always()
uses: actions/upload-artifact@v4
with:
name: e2e-cache-report
path: ${{ github.workspace }}/packages/web-integration/midscene_run/report
if-no-files-found: ignore
- name: Run e2e tests report
run: pnpm run e2e:report
id: e2e-tests-report
continue-on-error: true
- name: Upload e2e report output
if: always()
uses: actions/upload-artifact@v4
with:
name: e2e-report-output
path: ${{ github.workspace }}/packages/web-integration/midscene_run/report
if-no-files-found: ignore
- name: Run tests
run: pnpm run test:ai
id: test-ai
continue-on-error: true
- name: Upload test-ai output
if: always()
uses: actions/upload-artifact@v4
with:
name: test-ai-output
path: ${{ github.workspace }}/packages/web-integration/midscene_run/report
if-no-files-found: ignore
- name: Check if script failed
if: steps.test-ai.outcome == 'failure' || steps.e2e-tests.outcome == 'failure' || steps.e2e-tests-cache.outcome == 'failure' || steps.e2e-tests-report.outcome == 'failure'
run: exit 1