chore: follow test:$browser[:$flavor] naming for tests + retries for Firefox (#8775)

This commit is contained in:
Alex Rudenko 2022-08-11 20:45:52 +02:00 committed by GitHub
parent 23da97105c
commit 73221042db
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 28 additions and 19 deletions

View File

@ -168,16 +168,24 @@ jobs:
run: npm run build run: npm run build
- name: Test types - name: Test types
run: npm run test:types run: npm run test:types
- name: Run all tests (only on Linux) # On Linux we run all Chrome tests without retries and Firefox tests with retries.
id: full-test - name: Run all Chrome tests (only on Linux)
if: ${{ matrix.spec.name == 'Linux' }} if: ${{ matrix.spec.name == 'Linux' }}
run: xvfb-run --auto-servernum npm test run: xvfb-run --auto-servernum npm run test:chrome
- name: Test Chrome - name: Run all Firefox tests (only on Linux)
if: ${{ matrix.spec.name == 'Linux' }}
uses: nick-invision/retry@v2
with:
command: xvfb-run --auto-servernum npm run test:firefox
timeout_minutes: 20
max_attempts: 3
# On other platforms we only run chrome:headless tests and continue on Firefox errors.
- name: Test Chrome Headless (not on Linux)
id: test-chrome id: test-chrome
if: ${{ steps.full-test.conclusion == 'skipped' }} if: ${{ matrix.spec.name != 'Linux' }}
run: npm run test:chrome run: npm run test:chrome:headless
- name: Test Firefox - name: Run all Firefox tests (not on Linux)
if: ${{ steps.test-chrome.conclusion != 'skipped' }} if: ${{ matrix.spec.name != 'Linux' }}
continue-on-error: true continue-on-error: true
run: npm run test:firefox run: npm run test:firefox
- name: Test bundling and installation - name: Test bundling and installation

View File

@ -49,7 +49,7 @@ jobs:
- name: Run unit tests in headless - name: Run unit tests in headless
uses: nick-invision/retry@v2 uses: nick-invision/retry@v2
with: with:
command: xvfb-run --auto-servernum npm run test:chrome command: xvfb-run --auto-servernum npm run test:chrome:headless
timeout_minutes: 10 timeout_minutes: 10
max_attempts: 3 max_attempts: 3
@ -125,6 +125,6 @@ jobs:
- name: Run unit tests in chrome headless - name: Run unit tests in chrome headless
uses: nick-invision/retry@v2 uses: nick-invision/retry@v2
with: with:
command: xvfb-run --auto-servernum npm run test:chrome:headless command: xvfb-run --auto-servernum npm run test:chrome:headless-chrome
timeout_minutes: 10 timeout_minutes: 10
max_attempts: 3 max_attempts: 3

View File

@ -208,7 +208,7 @@ npm run test
- To run Chrome tests in non-headless mode: - To run Chrome tests in non-headless mode:
```bash ```bash
HEADLESS=false npm run test:chrome HEADLESS=false npm run test:chrome:headless
``` ```
- To run Firefox tests, firstly ensure you have Firefox installed locally (you only need to do this once, not on every test run) and then you can run the tests: - To run Firefox tests, firstly ensure you have Firefox installed locally (you only need to do this once, not on every test run) and then you can run the tests:
@ -222,13 +222,13 @@ npm run test:firefox
```bash ```bash
PUPPETEER_EXPERIMENTAL_CHROMIUM_MAC_ARM=1 npm install PUPPETEER_EXPERIMENTAL_CHROMIUM_MAC_ARM=1 npm install
PUPPETEER_EXPERIMENTAL_CHROMIUM_MAC_ARM=1 npm run test:chrome PUPPETEER_EXPERIMENTAL_CHROMIUM_MAC_ARM=1 npm run test:chrome:headless
``` ```
- To run tests with custom browser executable: - To run tests with custom browser executable:
```bash ```bash
BINARY=<path-to-executable> npm run test:chrome # Or npm run test:firefox BINARY=<path-to-executable> npm run test:chrome:headless # Or npm run test:firefox
``` ```
## API Coverage ## API Coverage

View File

@ -27,12 +27,13 @@
"node": ">=14.1.0" "node": ">=14.1.0"
}, },
"scripts": { "scripts": {
"test": "c8 --check-coverage --lines 93 run-s test:chrome test:chrome:* test:firefox", "test": "c8 --check-coverage --lines 93 run-s test:chrome:* test:firefox",
"test:types": "tsd", "test:types": "tsd",
"test:install": "scripts/test-install.sh", "test:install": "scripts/test-install.sh",
"test:firefox": "cross-env PUPPETEER_PRODUCT=firefox MOZ_WEBRENDER=0 mocha", "test:firefox": "cross-env PUPPETEER_PRODUCT=firefox MOZ_WEBRENDER=0 mocha",
"test:chrome": "mocha", "test:chrome": "run-s test:chrome:*",
"test:chrome:headless": "cross-env HEADLESS=chrome mocha", "test:chrome:headless": "cross-env HEADLESS=true mocha",
"test:chrome:headless-chrome": "cross-env HEADLESS=chrome mocha",
"test:chrome:headful": "cross-env HEADLESS=false mocha", "test:chrome:headful": "cross-env HEADLESS=false mocha",
"prepublishOnly": "npm run build", "prepublishOnly": "npm run build",
"prepare": "node typescript-if-required.js && husky install", "prepare": "node typescript-if-required.js && husky install",

View File

@ -81,5 +81,5 @@ npm run test:chrome:headful
- To run tests with custom browser executable: - To run tests with custom browser executable:
```bash ```bash
BINARY=<path-to-executable> npm run test:chrome # Or npm run test:firefox BINARY=<path-to-executable> npm run test:chrome:headless # Or npm run test:firefox
``` ```

View File

@ -180,7 +180,7 @@ function runScript(scriptPath, revisionInfo) {
function runUnitTest(pattern, revisionInfo) { function runUnitTest(pattern, revisionInfo) {
const log = debug('bisect:rununittest'); const log = debug('bisect:rununittest');
log('Running unit test'); log('Running unit test');
const child = spawn('npm run test:chrome', ['--', '-g', pattern], { const child = spawn('npm run test:chrome:headless', ['--', '-g', pattern], {
stdio: ['inherit', 'inherit', 'inherit', 'ipc'], stdio: ['inherit', 'inherit', 'inherit', 'ipc'],
shell: true, shell: true,
env: { env: {