| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  | /** | 
					
						
							|  |  |  |  |  * Copyright (c) Microsoft Corporation. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Licensed under the Apache License, Version 2.0 (the "License"); | 
					
						
							|  |  |  |  |  * you may not use this file except in compliance with the License. | 
					
						
							|  |  |  |  |  * You may obtain a copy of the License at | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * http://www.apache.org/licenses/LICENSE-2.0
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Unless required by applicable law or agreed to in writing, software | 
					
						
							|  |  |  |  |  * distributed under the License is distributed on an "AS IS" BASIS, | 
					
						
							|  |  |  |  |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
					
						
							|  |  |  |  |  * See the License for the specific language governing permissions and | 
					
						
							|  |  |  |  |  * limitations under the License. | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-07 15:11:44 -08:00
										 |  |  |  | import { test, expect } from './playwright-test-fixtures'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should fail', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |  |     'one-failure.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |       test('fails', () => { | 
					
						
							|  |  |  |  |         expect(1 + 1).toBe(7); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(1); | 
					
						
							|  |  |  |  |   expect(result.passed).toBe(0); | 
					
						
							|  |  |  |  |   expect(result.failed).toBe(1); | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |   expect(result.output).toContain('1) one-failure.spec.ts:3'); | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should timeout', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const { exitCode, passed, failed, output } = await runInlineTest({ | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'one-timeout.spec.ts': `
 | 
					
						
							|  |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |       test('timeout', async () => { | 
					
						
							|  |  |  |  |         await new Promise(f => setTimeout(f, 10000)); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }, { timeout: 100 }); | 
					
						
							|  |  |  |  |   expect(exitCode).toBe(1); | 
					
						
							|  |  |  |  |   expect(passed).toBe(0); | 
					
						
							|  |  |  |  |   expect(failed).toBe(1); | 
					
						
							| 
									
										
										
										
											2022-06-30 17:05:08 -07:00
										 |  |  |  |   expect(output).toContain('Test timeout of 100ms exceeded.'); | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should succeed', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const result = await runInlineTest({ | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'one-success.spec.ts': `
 | 
					
						
							|  |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |       test('succeeds', () => { | 
					
						
							|  |  |  |  |         expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  |  |   expect(result.passed).toBe(1); | 
					
						
							|  |  |  |  |   expect(result.failed).toBe(0); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should report suite errors', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const { exitCode, failed, output } = await runInlineTest({ | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'suite-error.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2023-01-22 15:04:29 -08:00
										 |  |  |  |       if (new Error().stack.includes('workerMain')) | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |         throw new Error('Suite error'); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |       test('passes',() => { | 
					
						
							|  |  |  |  |         expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(exitCode).toBe(1); | 
					
						
							|  |  |  |  |   expect(failed).toBe(1); | 
					
						
							|  |  |  |  |   expect(output).toContain('Suite error'); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should respect nested skip', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const { exitCode, passed, failed, skipped } = await runInlineTest({ | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'nested-skip.spec.ts': `
 | 
					
						
							|  |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |       test.describe('skipped', () => { | 
					
						
							|  |  |  |  |         test.skip(); | 
					
						
							|  |  |  |  |         test('succeeds',() => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(exitCode).toBe(0); | 
					
						
							|  |  |  |  |   expect(passed).toBe(0); | 
					
						
							|  |  |  |  |   expect(failed).toBe(0); | 
					
						
							|  |  |  |  |   expect(skipped).toBe(1); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should respect excluded tests', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const { exitCode, passed } = await runInlineTest({ | 
					
						
							|  |  |  |  |     'excluded.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |       test('included test', () => { | 
					
						
							|  |  |  |  |         expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-28 22:13:35 +02:00
										 |  |  |  |       test('excluded test 1', () => { | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |         test.skip(); | 
					
						
							|  |  |  |  |         expect(1 + 1).toBe(3); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-28 22:13:35 +02:00
										 |  |  |  |       test('excluded test 2', () => { | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |         test.skip(); | 
					
						
							|  |  |  |  |         expect(1 + 1).toBe(3); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       test.describe('included describe', () => { | 
					
						
							|  |  |  |  |         test('included describe test', () => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       test.describe('excluded describe', () => { | 
					
						
							|  |  |  |  |         test.skip(); | 
					
						
							|  |  |  |  |         test('excluded describe test', () => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(3); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(passed).toBe(2); | 
					
						
							|  |  |  |  |   expect(exitCode).toBe(0); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should respect focused tests', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const { exitCode, passed } = await runInlineTest({ | 
					
						
							|  |  |  |  |     'focused.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |       test('included test', () => { | 
					
						
							|  |  |  |  |         expect(1 + 1).toBe(3); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       test.only('focused test', () => { | 
					
						
							|  |  |  |  |         expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       test.only('focused only test', () => { | 
					
						
							|  |  |  |  |         expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       test.describe.only('focused describe', () => { | 
					
						
							|  |  |  |  |         test('describe test', () => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       test.describe('non-focused describe', () => { | 
					
						
							|  |  |  |  |         test('describe test', () => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(3); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       test.describe.only('focused describe', () => { | 
					
						
							|  |  |  |  |         test('test1', () => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         test.only('test2', () => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         test('test3', () => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         test.only('test4', () => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(passed).toBe(5); | 
					
						
							|  |  |  |  |   expect(exitCode).toBe(0); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | test('skip should take priority over fail', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const { passed, skipped, failed } = await runInlineTest({ | 
					
						
							|  |  |  |  |     'test.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |       test.describe('failing suite', () => { | 
					
						
							|  |  |  |  |         test.fail(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         test('skipped', () => { | 
					
						
							|  |  |  |  |           test.skip(); | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(3); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         test('passing', () => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(3); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         test('passing2', () => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(3); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         test('failing', () => { | 
					
						
							|  |  |  |  |           expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(passed).toBe(2); | 
					
						
							|  |  |  |  |   expect(skipped).toBe(1); | 
					
						
							|  |  |  |  |   expect(failed).toBe(1); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  | test('should focus test from one project', async ({ runInlineTest }) => { | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |   const { exitCode, passed, skipped, failed } = await runInlineTest({ | 
					
						
							|  |  |  |  |     'playwright.config.ts': `
 | 
					
						
							|  |  |  |  |       import * as path from 'path'; | 
					
						
							|  |  |  |  |       module.exports = { projects: [ | 
					
						
							|  |  |  |  |         { testDir: path.join(__dirname, 'a') }, | 
					
						
							|  |  |  |  |         { testDir: path.join(__dirname, 'b') }, | 
					
						
							|  |  |  |  |       ] }; | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							|  |  |  |  |     'a/afile.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |       test('just a test', () => { | 
					
						
							|  |  |  |  |         expect(1 + 1).toBe(3); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							|  |  |  |  |     'b/bfile.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |       test.only('focused test', () => { | 
					
						
							|  |  |  |  |         expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							|  |  |  |  |   }, { reporter: 'list,json' }); | 
					
						
							|  |  |  |  |   expect(passed).toBe(1); | 
					
						
							|  |  |  |  |   expect(failed).toBe(0); | 
					
						
							|  |  |  |  |   expect(skipped).toBe(0); | 
					
						
							|  |  |  |  |   expect(exitCode).toBe(0); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should work with default export', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |  |     'file.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2021-10-11 10:52:17 -04:00
										 |  |  |  |       import t from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |  |       t('passed', () => { | 
					
						
							|  |  |  |  |         t.expect(1 + 1).toBe(2); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  |  |   expect(result.passed).toBe(1); | 
					
						
							|  |  |  |  |   expect(result.failed).toBe(0); | 
					
						
							|  |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should work with test wrapper', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |  |     'helper.js': `
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       const { test, expect } = require('@playwright/test'); | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |       console.log('%%helper'); | 
					
						
							|  |  |  |  |       exports.wrap = (title, fn) => { | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |         test(title, fn); | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |       }; | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'a.spec.ts': `
 | 
					
						
							|  |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |       console.log('%%a.spec'); | 
					
						
							|  |  |  |  |       const { wrap } = require('./helper'); | 
					
						
							|  |  |  |  |       wrap('test1', () => { | 
					
						
							|  |  |  |  |         console.log('%%test1'); | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       test.describe('suite1', () => { | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |         wrap('suite1.test1', () => { | 
					
						
							|  |  |  |  |           console.log('%%suite1.test1'); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'b.spec.ts': `
 | 
					
						
							|  |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |       console.log('%%b.spec'); | 
					
						
							|  |  |  |  |       const { wrap } = require('./helper'); | 
					
						
							|  |  |  |  |       wrap('test2', () => { | 
					
						
							|  |  |  |  |         console.log('%%test2'); | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       test.describe('suite2', () => { | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |         wrap('suite2.test2', () => { | 
					
						
							|  |  |  |  |           console.log('%%suite2.test2'); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							|  |  |  |  |   }, { workers: 1, reporter: 'line' }); | 
					
						
							|  |  |  |  |   expect(result.passed).toBe(4); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							| 
									
										
										
										
											2023-02-07 15:11:44 -08:00
										 |  |  |  |   expect(result.outputLines).toEqual([ | 
					
						
							|  |  |  |  |     'a.spec', | 
					
						
							|  |  |  |  |     'helper', | 
					
						
							|  |  |  |  |     'b.spec', | 
					
						
							|  |  |  |  |     'a.spec', | 
					
						
							|  |  |  |  |     'helper', | 
					
						
							|  |  |  |  |     'test1', | 
					
						
							|  |  |  |  |     'suite1.test1', | 
					
						
							|  |  |  |  |     'b.spec', | 
					
						
							|  |  |  |  |     'test2', | 
					
						
							|  |  |  |  |     'suite2.test2', | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |   ]); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should work with test helper', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const result = await runInlineTest({ | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'helper-a.ts': `
 | 
					
						
							|  |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |       console.log('%%helper-a'); | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       test('test1', () => { | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |         console.log('%%test1'); | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       test.describe('suite1', () => { | 
					
						
							|  |  |  |  |         test('suite1.test1', () => { | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |           console.log('%%suite1.test1'); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'a.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |       console.log('%%a.spec'); | 
					
						
							|  |  |  |  |       require('./helper-a'); | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'helper-b.ts': `
 | 
					
						
							|  |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |       console.log('%%helper-b'); | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       test('test1', () => { | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |         console.log('%%test2'); | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       test.describe('suite2', () => { | 
					
						
							|  |  |  |  |         test('suite2.test2', () => { | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |           console.log('%%suite2.test2'); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'b.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |       console.log('%%b.spec'); | 
					
						
							|  |  |  |  |       require('./helper-b'); | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							|  |  |  |  |   }, { workers: 1, reporter: 'line' }); | 
					
						
							|  |  |  |  |   expect(result.passed).toBe(4); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							| 
									
										
										
										
											2023-02-07 15:11:44 -08:00
										 |  |  |  |   expect(result.outputLines).toEqual([ | 
					
						
							|  |  |  |  |     'a.spec', | 
					
						
							|  |  |  |  |     'helper-a', | 
					
						
							|  |  |  |  |     'b.spec', | 
					
						
							|  |  |  |  |     'helper-b', | 
					
						
							|  |  |  |  |     'a.spec', | 
					
						
							|  |  |  |  |     'helper-a', | 
					
						
							|  |  |  |  |     'test1', | 
					
						
							|  |  |  |  |     'suite1.test1', | 
					
						
							|  |  |  |  |     'b.spec', | 
					
						
							|  |  |  |  |     'helper-b', | 
					
						
							|  |  |  |  |     'test2', | 
					
						
							|  |  |  |  |     'suite2.test2', | 
					
						
							| 
									
										
										
										
											2021-06-21 11:25:15 -07:00
										 |  |  |  |   ]); | 
					
						
							|  |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2021-07-22 12:34:37 -07:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-06 13:54:11 -07:00
										 |  |  |  | test('should support describe() without a title', async ({ runInlineTest }) => { | 
					
						
							| 
									
										
										
										
											2021-07-22 12:34:37 -07:00
										 |  |  |  |   const result = await runInlineTest({ | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'a.spec.ts': `
 | 
					
						
							|  |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							|  |  |  |  |       test.describe('suite1', () => { | 
					
						
							|  |  |  |  |         test.describe(() => { | 
					
						
							|  |  |  |  |           test.describe('suite2', () => { | 
					
						
							|  |  |  |  |             test('my test', () => {}); | 
					
						
							| 
									
										
										
										
											2022-07-06 13:54:11 -07:00
										 |  |  |  |           }); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2021-07-22 12:34:37 -07:00
										 |  |  |  |     `,
 | 
					
						
							| 
									
										
										
										
											2022-07-06 13:54:11 -07:00
										 |  |  |  |   }, { reporter: 'list' }); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  |  |   expect(result.passed).toBe(1); | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |   expect(result.output).toContain('a.spec.ts:6:17 › suite1 › suite2 › my test'); | 
					
						
							| 
									
										
										
										
											2021-07-22 12:34:37 -07:00
										 |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2021-07-29 14:33:37 -07:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-19 11:40:40 -08:00
										 |  |  |  | test('test.{skip,fixme} should define a skipped test', async ({ runInlineTest }) => { | 
					
						
							| 
									
										
										
										
											2021-07-29 14:33:37 -07:00
										 |  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |  |     'a.test.ts': `
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-07-29 14:33:37 -07:00
										 |  |  |  |       const logs = []; | 
					
						
							|  |  |  |  |       test.skip('foo', () => { | 
					
						
							|  |  |  |  |         console.log('%%dontseethis'); | 
					
						
							|  |  |  |  |         throw new Error('foo'); | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2021-11-19 11:40:40 -08:00
										 |  |  |  |       test.fixme('bar', () => { | 
					
						
							|  |  |  |  |         console.log('%%dontseethis'); | 
					
						
							|  |  |  |  |         throw new Error('bar'); | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2021-07-29 14:33:37 -07:00
										 |  |  |  |     `,
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-19 11:40:40 -08:00
										 |  |  |  |   expect(result.skipped).toBe(2); | 
					
						
							| 
									
										
										
										
											2021-07-29 14:33:37 -07:00
										 |  |  |  |   expect(result.output).not.toContain('%%dontseethis'); | 
					
						
							|  |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2021-08-31 10:50:30 -07:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-24 15:03:49 -07:00
										 |  |  |  | test('should report unhandled error during test and not report timeout', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |  |     'a.test.ts': `
 | 
					
						
							|  |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							|  |  |  |  |       test('unhandled rejection', async () => { | 
					
						
							|  |  |  |  |         setTimeout(() => { | 
					
						
							|  |  |  |  |           throw new Error('Unhandled'); | 
					
						
							|  |  |  |  |         }, 0); | 
					
						
							|  |  |  |  |         await new Promise(f => setTimeout(f, 100)); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(1); | 
					
						
							|  |  |  |  |   expect(result.failed).toBe(1); | 
					
						
							|  |  |  |  |   expect(result.output).toContain('Error: Unhandled'); | 
					
						
							|  |  |  |  |   expect(result.output).not.toContain('Test timeout of 30000ms exceeded'); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-31 10:50:30 -07:00
										 |  |  |  | test('should report unhandled rejection during worker shutdown', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |  |     'a.test.ts': `
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2021-08-31 10:50:30 -07:00
										 |  |  |  |       test('unhandled rejection', async () => { | 
					
						
							|  |  |  |  |         new Promise((f, r) => r(new Error('Unhandled'))); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `,
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(1); | 
					
						
							|  |  |  |  |   expect(result.passed).toBe(1); | 
					
						
							|  |  |  |  |   expect(result.output).toContain('Error: Unhandled'); | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |   expect(result.output).toContain('a.test.ts:4:33'); | 
					
						
							| 
									
										
										
										
											2021-08-31 10:50:30 -07:00
										 |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2021-10-29 13:36:12 -07:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should not reuse worker after unhandled rejection in test.fail', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |  |     'a.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       import { test as base, expect } from '@playwright/test'; | 
					
						
							|  |  |  |  |       const test = base.extend({ | 
					
						
							| 
									
										
										
										
											2021-10-29 13:36:12 -07:00
										 |  |  |  |         needsCleanup: async ({}, use) => { | 
					
						
							|  |  |  |  |           await use(); | 
					
						
							|  |  |  |  |           await new Promise(f => setTimeout(f, 3000)); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       test('failing', async ({ needsCleanup }) => { | 
					
						
							|  |  |  |  |         test.fail(); | 
					
						
							|  |  |  |  |         new Promise(() => { throw new Error('Oh my!') }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       test('passing', async () => { | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }, { workers: 1 }); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(1); | 
					
						
							|  |  |  |  |   expect(result.failed).toBe(1); | 
					
						
							| 
									
										
										
										
											2022-08-02 12:55:43 -07:00
										 |  |  |  |   expect(result.interrupted).toBe(1); | 
					
						
							| 
									
										
										
										
											2021-10-29 13:36:12 -07:00
										 |  |  |  |   expect(result.output).toContain(`Error: Oh my!`); | 
					
						
							|  |  |  |  |   expect(result.output).not.toContain(`Did not teardown test scope`); | 
					
						
							|  |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2022-02-03 17:14:12 -08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should allow unhandled expects in test.fail', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |  |     'a.spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2022-02-03 17:14:12 -08:00
										 |  |  |  |       test('failing1', async ({}) => { | 
					
						
							|  |  |  |  |         test.fail(); | 
					
						
							|  |  |  |  |         Promise.resolve().then(() => expect(1).toBe(2)); | 
					
						
							|  |  |  |  |         await new Promise(f => setTimeout(f, 100)); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  |  |   expect(result.passed).toBe(1); | 
					
						
							|  |  |  |  |   expect(result.output).not.toContain(`Error: expect`); | 
					
						
							|  |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2022-03-18 16:07:11 -07:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should support describe.skip', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const result = await runInlineTest({ | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'nested-skip.spec.ts': `
 | 
					
						
							|  |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2022-03-18 16:07:11 -07:00
										 |  |  |  |       test.describe.skip('skipped', () => { | 
					
						
							|  |  |  |  |         test.describe('nested', () => { | 
					
						
							|  |  |  |  |           test('test1', () => {}); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         test('test2', () => {}); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       test.describe('not skipped', () => { | 
					
						
							|  |  |  |  |         test.describe.skip('skipped', () => { | 
					
						
							|  |  |  |  |           test('test4', () => {}); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         test('test4', () => { | 
					
						
							|  |  |  |  |           console.log('heytest4'); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  |  |   expect(result.passed).toBe(1); | 
					
						
							|  |  |  |  |   expect(result.skipped).toBe(3); | 
					
						
							|  |  |  |  |   expect(result.output).toContain('heytest4'); | 
					
						
							|  |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2022-07-29 12:44:22 -07:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | test('should support describe.fixme', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |  |   const result = await runInlineTest({ | 
					
						
							| 
									
										
										
										
											2023-02-14 19:20:56 -08:00
										 |  |  |  |     'nested-skip.spec.ts': `
 | 
					
						
							|  |  |  |  |       import { test, expect } from '@playwright/test'; | 
					
						
							| 
									
										
										
										
											2022-07-29 12:44:22 -07:00
										 |  |  |  |       test.describe.fixme('skipped', () => { | 
					
						
							|  |  |  |  |         test.describe('nested', () => { | 
					
						
							|  |  |  |  |           test('test1', () => {}); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         test('test2', () => {}); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       test.describe('not skipped', () => { | 
					
						
							|  |  |  |  |         test.describe.fixme('skipped', () => { | 
					
						
							|  |  |  |  |           test('test4', () => {}); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         test('test4', () => { | 
					
						
							|  |  |  |  |           console.log('heytest4'); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     `
 | 
					
						
							|  |  |  |  |   }); | 
					
						
							|  |  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  |  |   expect(result.passed).toBe(1); | 
					
						
							|  |  |  |  |   expect(result.skipped).toBe(3); | 
					
						
							|  |  |  |  |   expect(result.output).toContain('heytest4'); | 
					
						
							|  |  |  |  | }); |