| 
									
										
										
										
											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. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { test, expect } from './playwright-test-fixtures'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('should run in parallel', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |     '1.spec.ts': `
 | 
					
						
							|  |  |  |       import * as fs from 'fs'; | 
					
						
							|  |  |  |       import * as path from 'path'; | 
					
						
							| 
									
										
										
										
											2021-06-06 22:07:07 -07:00
										 |  |  |       const { test } = pwt; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |       test('succeeds', async ({}, testInfo) => { | 
					
						
							|  |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |         // First test waits for the second to start to work around the race.
 | 
					
						
							|  |  |  |         while (true) { | 
					
						
							|  |  |  |           if (fs.existsSync(path.join(testInfo.project.outputDir, 'parallel-index.txt'))) | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           await new Promise(f => setTimeout(f, 100)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     `,
 | 
					
						
							|  |  |  |     '2.spec.ts': `
 | 
					
						
							|  |  |  |       import * as fs from 'fs'; | 
					
						
							|  |  |  |       import * as path from 'path'; | 
					
						
							| 
									
										
										
										
											2021-06-06 22:07:07 -07:00
										 |  |  |       const { test } = pwt; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |       test('succeeds', async ({}, testInfo) => { | 
					
						
							|  |  |  |         // First test waits for the second to start to work around the race.
 | 
					
						
							|  |  |  |         fs.mkdirSync(testInfo.project.outputDir, { recursive: true }); | 
					
						
							|  |  |  |         fs.writeFileSync(path.join(testInfo.project.outputDir, 'parallel-index.txt'), 'TRUE'); | 
					
						
							|  |  |  |         expect(testInfo.workerIndex).toBe(1); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(1); | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  |     `,
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  |   expect(result.passed).toBe(2); | 
					
						
							|  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('should reuse worker for multiple tests', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |     'a.test.js': `
 | 
					
						
							| 
									
										
										
										
											2021-06-06 22:07:07 -07:00
										 |  |  |       const { test } = pwt; | 
					
						
							| 
									
										
										
										
											2021-06-28 22:13:35 +02:00
										 |  |  |       test('succeeds 1', async ({}, testInfo) => { | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-28 22:13:35 +02:00
										 |  |  |       test('succeeds 2', async ({}, testInfo) => { | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-28 22:13:35 +02:00
										 |  |  |       test('succeeds 3', async ({}, testInfo) => { | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  |     `,
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  |   expect(result.passed).toBe(3); | 
					
						
							|  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-08 09:36:28 -07:00
										 |  |  | test('should reuse worker after test.fixme()', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |     'a.test.js': `
 | 
					
						
							|  |  |  |       const { test } = pwt; | 
					
						
							|  |  |  |       test('succeeds 1', async ({}, testInfo) => { | 
					
						
							|  |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-07-08 09:36:28 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       test('fixme 1', async ({}, testInfo) => { | 
					
						
							|  |  |  |         test.fixme(); | 
					
						
							|  |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-07-08 09:36:28 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       test('succeeds 2', async ({}, testInfo) => { | 
					
						
							|  |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-07-08 09:36:28 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  |     `,
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  |   expect(result.passed).toBe(2); | 
					
						
							|  |  |  |   expect(result.skipped).toBe(1); | 
					
						
							|  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('should reuse worker after test.skip()', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |     'a.test.js': `
 | 
					
						
							|  |  |  |       const { test } = pwt; | 
					
						
							|  |  |  |       test('succeeds 1', async ({}, testInfo) => { | 
					
						
							|  |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-07-08 09:36:28 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       test('skip 1', async ({}, testInfo) => { | 
					
						
							|  |  |  |         test.skip(); | 
					
						
							|  |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-07-08 09:36:28 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       test('succeeds 2', async ({}, testInfo) => { | 
					
						
							|  |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-07-08 09:36:28 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  |     `,
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  |   expect(result.passed).toBe(2); | 
					
						
							|  |  |  |   expect(result.skipped).toBe(1); | 
					
						
							|  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-25 12:19:50 -07:00
										 |  |  | test('should not use new worker after test.fail()', async ({ runInlineTest }) => { | 
					
						
							| 
									
										
										
										
											2021-07-08 23:30:15 -07:00
										 |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |     'a.test.js': `
 | 
					
						
							|  |  |  |       const { test } = pwt; | 
					
						
							|  |  |  |       test('succeeds 1', async ({}, testInfo) => { | 
					
						
							|  |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-07-08 23:30:15 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       test('fail 1', async ({}, testInfo) => { | 
					
						
							|  |  |  |         test.fail(); | 
					
						
							|  |  |  |         expect(1).toBe(0); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       test('succeeds 2', async ({}, testInfo) => { | 
					
						
							| 
									
										
										
										
											2021-08-25 12:19:50 -07:00
										 |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-07-08 23:30:15 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  |     `,
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  |   expect(result.passed).toBe(3); | 
					
						
							|  |  |  |   expect(result.failed).toBe(0); | 
					
						
							|  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('should use new worker after test failure', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |     'a.test.js': `
 | 
					
						
							|  |  |  |       const { test } = pwt; | 
					
						
							|  |  |  |       test('succeeds 1', async ({}, testInfo) => { | 
					
						
							|  |  |  |         expect(testInfo.workerIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-07-08 23:30:15 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       test('fail 1', async ({}, testInfo) => { | 
					
						
							|  |  |  |         expect(1).toBe(0); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       test('succeeds 2', async ({}, testInfo) => { | 
					
						
							|  |  |  |         expect(testInfo.workerIndex).toBe(1); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         expect(testInfo.parallelIndex).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-07-08 23:30:15 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  |     `,
 | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |   }, { workers: 1 }); | 
					
						
							| 
									
										
										
										
											2021-07-08 23:30:15 -07:00
										 |  |  |   expect(result.passed).toBe(2); | 
					
						
							|  |  |  |   expect(result.failed).toBe(1); | 
					
						
							|  |  |  |   expect(result.exitCode).toBe(1); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  | test('should not reuse worker for different suites', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |   const result = await runInlineTest({ | 
					
						
							|  |  |  |     'playwright.config.ts': `
 | 
					
						
							|  |  |  |       module.exports = { projects: [{}, {}, {}] }; | 
					
						
							|  |  |  |     `,
 | 
					
						
							|  |  |  |     'a.test.js': `
 | 
					
						
							| 
									
										
										
										
											2021-06-06 22:07:07 -07:00
										 |  |  |       const { test } = pwt; | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |       test('succeeds', async ({}, testInfo) => { | 
					
						
							|  |  |  |         console.log('workerIndex-' + testInfo.workerIndex); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |         console.log('parallelIndex-' + testInfo.parallelIndex); | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  |     `,
 | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |   }, { workers: 1 }); | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  |   expect(result.passed).toBe(3); | 
					
						
							|  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  |   expect(result.results.map(r => r.workerIndex).sort()).toEqual([0, 1, 2]); | 
					
						
							|  |  |  |   expect(result.output).toContain('workerIndex-0'); | 
					
						
							|  |  |  |   expect(result.output).toContain('workerIndex-1'); | 
					
						
							|  |  |  |   expect(result.output).toContain('workerIndex-2'); | 
					
						
							| 
									
										
										
										
											2021-11-01 10:37:34 -07:00
										 |  |  |   expect(result.output).toContain('parallelIndex-0'); | 
					
						
							|  |  |  |   expect(result.output).not.toContain('parallelIndex-1'); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('parallelIndex should be in 0..workers-1', async ({ runInlineTest }) => { | 
					
						
							|  |  |  |   const files = {}; | 
					
						
							|  |  |  |   for (let i = 0; i < 10; i++) { | 
					
						
							|  |  |  |     files[`a${i}.test.js`] = `
 | 
					
						
							|  |  |  |       const { test } = pwt; | 
					
						
							|  |  |  |       test('passes-1', async ({}, testInfo) => { | 
					
						
							|  |  |  |         await new Promise(f => setTimeout(f, 100 + 50 * ${i})); | 
					
						
							|  |  |  |         expect(testInfo.parallelIndex >= 0).toBeTruthy(); | 
					
						
							|  |  |  |         expect(testInfo.parallelIndex < testInfo.config.workers).toBeTruthy(); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       test('passes-2', async ({}, testInfo) => { | 
					
						
							|  |  |  |         await new Promise(f => setTimeout(f, 100 + 50 * ${i})); | 
					
						
							|  |  |  |         expect(testInfo.parallelIndex >= 0).toBeTruthy(); | 
					
						
							|  |  |  |         expect(testInfo.parallelIndex < testInfo.config.workers).toBeTruthy(); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     `;
 | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   const result = await runInlineTest(files, { workers: 3 }); | 
					
						
							|  |  |  |   expect(result.exitCode).toBe(0); | 
					
						
							|  |  |  |   expect(result.passed).toBe(20); | 
					
						
							| 
									
										
										
										
											2021-06-06 17:09:53 -07:00
										 |  |  | }); |