 39ea1bb9b7
			
		
	
	
		39ea1bb9b7
		
	
	
	
	
		
			
			# Objective - Run examples in WASM in CI - Fix #4817 ## Solution - on feature `bevy_ci_testing` - add an extra log message before exiting - when building for wasm, read CI config file at compile time - add a simple [playwright](https://playwright.dev) test script that opens the browser then waits for the success log, and takes a screenshot - add a CI job that runs the playwright test for Chromium and Firefox on one example (lighting) and save the screenshots - Firefox screenshot is good (with some clusters visible) - Chromium screenshot is gray, I don't know why but it's logging `GPU stall due to ReadPixels` - Webkit is not enabled for now, to revisit once https://bugs.webkit.org/show_bug.cgi?id=234926 is fixed or worked around - the CI job only runs on bors validation example run: https://github.com/mockersf/bevy/actions/runs/2361673465. The screenshots can be downloaded
		
			
				
	
	
		
			108 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import type { PlaywrightTestConfig } from '@playwright/test';
 | |
| import { devices } from '@playwright/test';
 | |
| 
 | |
| /**
 | |
|  * Read environment variables from file.
 | |
|  * https://github.com/motdotla/dotenv
 | |
|  */
 | |
| require('dotenv').config();
 | |
| 
 | |
| /**
 | |
|  * See https://playwright.dev/docs/test-configuration.
 | |
|  */
 | |
| const config: PlaywrightTestConfig = {
 | |
|   testDir: './tests',
 | |
|   /* Maximum time one test can run for. */
 | |
|   timeout: 300_000,
 | |
|   expect: {
 | |
|     /**
 | |
|      * Maximum time expect() should wait for the condition to be met.
 | |
|      * For example in `await expect(locator).toHaveText();`
 | |
|      */
 | |
|     timeout: 5000
 | |
|   },
 | |
|   /* Run tests in files in parallel */
 | |
|   fullyParallel: true,
 | |
|   /* Fail the build on CI if you accidentally left test.only in the source code. */
 | |
|   forbidOnly: !!process.env.CI,
 | |
|   /* Retry on CI only */
 | |
|   retries: 0,
 | |
|   /* Opt out of parallel tests on CI. */
 | |
|   workers: 1,
 | |
|   /* Reporter to use. See https://playwright.dev/docs/test-reporters */
 | |
|   reporter: 'list',
 | |
|   /* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */
 | |
|   use: {
 | |
|     /* Maximum time each action such as `click()` can take. Defaults to 0 (no limit). */
 | |
|     actionTimeout: 0,
 | |
|     /* Base URL to use in actions like `await page.goto('/')`. */
 | |
|     // baseURL: 'http://localhost:3000',
 | |
| 
 | |
|     /* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */
 | |
|     trace: 'on-first-retry',
 | |
|   },
 | |
| 
 | |
|   /* Configure projects for major browsers */
 | |
|   projects: [
 | |
|     {
 | |
|       name: 'chromium',
 | |
|       use: {
 | |
|         ...devices['Desktop Chrome'],
 | |
|       },
 | |
|     },
 | |
| 
 | |
|     {
 | |
|       name: 'firefox',
 | |
|       use: {
 | |
|         ...devices['Desktop Firefox'],
 | |
|       },
 | |
|     },
 | |
| 
 | |
|     {
 | |
|       name: 'webkit',
 | |
|       use: {
 | |
|         ...devices['Desktop Safari'],
 | |
|       },
 | |
|     },
 | |
| 
 | |
|     /* Test against mobile viewports. */
 | |
|     // {
 | |
|     //   name: 'Mobile Chrome',
 | |
|     //   use: {
 | |
|     //     ...devices['Pixel 5'],
 | |
|     //   },
 | |
|     // },
 | |
|     // {
 | |
|     //   name: 'Mobile Safari',
 | |
|     //   use: {
 | |
|     //     ...devices['iPhone 12'],
 | |
|     //   },
 | |
|     // },
 | |
| 
 | |
|     /* Test against branded browsers. */
 | |
|     // {
 | |
|     //   name: 'Microsoft Edge',
 | |
|     //   use: {
 | |
|     //     channel: 'msedge',
 | |
|     //   },
 | |
|     // },
 | |
|     // {
 | |
|     //   name: 'Google Chrome',
 | |
|     //   use: {
 | |
|     //     channel: 'chrome',
 | |
|     //   },
 | |
|     // },
 | |
|   ],
 | |
| 
 | |
|   /* Folder for test artifacts such as screenshots, videos, traces, etc. */
 | |
|   // outputDir: 'test-results/',
 | |
| 
 | |
|   /* Run your local dev server before starting the tests */
 | |
|   // webServer: {
 | |
|   //   command: 'npm run start',
 | |
|   //   port: 3000,
 | |
|   // },
 | |
| };
 | |
| 
 | |
| export default config;
 |