2
0
mirror of https://github.com/inventree/InvenTree.git synced 2025-04-28 03:26:45 +00:00
InvenTree/src/frontend/playwright.config.ts
Oliver 7f5a447769
[CI] Playwright improvements (#9395)
* Allow port 4173 (vite preview)

* Change 'base' attr based on vite command

* Allow api_host to be specified separately

* Harden API host functionality

* Adjust server selections

* Cleanup vite.config.ts

* Adjust playwright configuration

- Allow to run in "production" mode
- Builds the code first
- Runs only the backend web server
- Not suitable for coverage

* Tweak github actions

* Tweak QC file

* Reduce number of steps

* Tweak CI file

* Fix typo

* Ensure translation before build

* Fix hard-coded test

* Test tweaks

* uncomment

* Revert some changes

* Run with gunicorn, single worker

* Reduce log output in DEBUG mode

* Update deps

* Add global-setup func

* Fix for .gitignore file

* Cached auth state

* Tweak login func

* Updated tests

* Enable parallel workers again

* Simplify config

* Try with a single worker again

* Single retry mode

* Run auth setup first

- Prevent issues with parallel test doing login

* Improve test setup process

* Tweaks

* Bump to 3 workers

* Tweak playwright settings

* Revert change

* Revert change
2025-03-30 14:12:48 +11:00

120 lines
3.7 KiB
TypeScript

import { defineConfig, devices } from '@playwright/test';
import type TestConfigWebServer from '@playwright/test';
// Detect if running in CI
const IS_CI = !!process.env.CI;
const IS_COVERAGE = !!process.env.VITE_COVERAGE_BUILD;
// If specified, tests will be run against the production build
const IS_PRODUCTION = !!process.env.VITE_PRODUCTION_BUILD;
console.log('Running Playwright tests:');
console.log(` - CI Mode: ${IS_CI}`);
console.log(` - Coverage Mode: ${IS_COVERAGE}`);
console.log(` - Production Mode: ${IS_PRODUCTION}`);
const MAX_WORKERS: number = 3;
const MAX_RETRIES: number = 3;
/* We optionally spin-up services based on the testing mode:
*
* Local Development:
* - If running locally (developer mode), we run "vite dev" with HMR enabled
* - This allows playwright to monitor the code for changes
* - WORKERS = 1 (to avoid conflicts with HMR)
*
* CI Mode (Production):
* - In CI (GitHub actions), we run "vite build" to generate a production build
* - This build is then served by a local server for testing
* - This allows the tests to run much faster and with parallel workers
* - Run a Gunicorn multi-threaded web server to handle multiple requests
* - WORKERS = MAX_WORKERS (to speed up the tests)
*
* CI Mode (Coverage):
* - In coverage mode (GitHub actions), we cannot compile the code first
* - This is because we need to compile coverage report against ./src directory
* - So, we run "vite dev" with coverage enabled (similar to the local dev mode)
* - WORKERS = 1 (to avoid conflicts with HMR)
*/
const devServer: TestConfigWebServer = {
command: 'yarn run dev --host --port 5173',
url: 'http://localhost:5173',
reuseExistingServer: IS_CI,
stdout: 'pipe',
stderr: 'pipe',
timeout: 120 * 1000
};
const WEB_BUILD_CMD: string =
'yarn run extract && yarn run compile && yarn run build';
// Command to spin-up the backend server
// In production mode, we want a stronger webserver to handle multiple requests
const WEB_SERVER_CMD: string = IS_PRODUCTION
? `${WEB_BUILD_CMD} && gunicorn --chdir ../backend/InvenTree --workers 8 --thread 8 --bind 127.0.0.1:8000 InvenTree.wsgi`
: 'invoke dev.server -a 127.0.0.1:8000';
const webServer: TestConfigWebServer = {
// If running in production mode, we need to build the frontend first
command: WEB_SERVER_CMD,
env: {
INVENTREE_DEBUG: 'True',
INVENTREE_PLUGINS_ENABLED: 'True',
INVENTREE_ADMIN_URL: 'test-admin',
INVENTREE_SITE_URL: 'http://localhost:8000',
INVENTREE_FRONTEND_API_HOST: 'http://localhost:8000',
INVENTREE_CORS_ORIGIN_ALLOW_ALL: 'True',
INVENTREE_COOKIE_SAMESITE: 'Lax',
INVENTREE_LOGIN_ATTEMPTS: '100'
},
url: 'http://localhost:8000/api/',
reuseExistingServer: IS_CI,
stdout: 'pipe',
stderr: 'pipe',
timeout: 120 * 1000
};
const serverList: TestConfigWebServer[] = [];
if (!IS_PRODUCTION) {
serverList.push(devServer);
}
serverList.push(webServer);
export default defineConfig({
testDir: './tests',
fullyParallel: false,
timeout: 90000,
forbidOnly: !!IS_CI,
retries: IS_CI ? MAX_RETRIES : 0,
workers: IS_PRODUCTION ? MAX_WORKERS : 1,
reporter: IS_CI ? [['html', { open: 'never' }], ['github']] : 'list',
/* Configure projects for major browsers */
projects: [
{
name: 'chromium',
use: {
...devices['Desktop Chrome']
}
},
{
name: 'firefox',
use: {
...devices['Desktop Firefox']
}
}
],
/* Run your local dev server before starting the tests */
webServer: serverList,
globalSetup: './playwright/global-setup.ts',
use: {
baseURL: IS_PRODUCTION ? 'http://localhost:8000' : 'http://localhost:5173',
headless: IS_PRODUCTION ? true : undefined,
trace: 'on-first-retry'
}
});