mirror of
https://github.com/inventree/InvenTree.git
synced 2025-07-03 12:10:59 +00:00
[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
This commit is contained in:
@ -1,13 +1,96 @@
|
||||
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: true,
|
||||
fullyParallel: false,
|
||||
timeout: 90000,
|
||||
forbidOnly: !!process.env.CI,
|
||||
retries: process.env.CI ? 3 : 0,
|
||||
workers: 1, // process.env.CI ? 3 : undefined,
|
||||
reporter: process.env.CI ? [['html', { open: 'never' }], ['github']] : 'list',
|
||||
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: [
|
||||
@ -26,35 +109,11 @@ export default defineConfig({
|
||||
],
|
||||
|
||||
/* Run your local dev server before starting the tests */
|
||||
webServer: [
|
||||
{
|
||||
command: 'yarn run dev --host',
|
||||
url: 'http://localhost:5173',
|
||||
reuseExistingServer: !process.env.CI,
|
||||
stdout: 'pipe',
|
||||
stderr: 'pipe',
|
||||
timeout: 120 * 1000
|
||||
},
|
||||
{
|
||||
command: 'invoke dev.server -a 127.0.0.1:8000',
|
||||
env: {
|
||||
INVENTREE_DEBUG: 'True',
|
||||
INVENTREE_PLUGINS_ENABLED: 'True',
|
||||
INVENTREE_ADMIN_URL: 'test-admin',
|
||||
INVENTREE_SITE_URL: 'http://localhost:8000',
|
||||
INVENTREE_CORS_ORIGIN_ALLOW_ALL: 'True',
|
||||
INVENTREE_COOKIE_SAMESITE: 'Lax',
|
||||
INVENTREE_LOGIN_ATTEMPTS: '100'
|
||||
},
|
||||
url: 'http://127.0.0.1:8000/api/',
|
||||
reuseExistingServer: !process.env.CI,
|
||||
stdout: 'pipe',
|
||||
stderr: 'pipe',
|
||||
timeout: 120 * 1000
|
||||
}
|
||||
],
|
||||
webServer: serverList,
|
||||
globalSetup: './playwright/global-setup.ts',
|
||||
use: {
|
||||
baseURL: 'http://localhost:5173',
|
||||
baseURL: IS_PRODUCTION ? 'http://localhost:8000' : 'http://localhost:5173',
|
||||
headless: IS_PRODUCTION ? true : undefined,
|
||||
trace: 'on-first-retry'
|
||||
}
|
||||
});
|
||||
|
Reference in New Issue
Block a user