mirror of
				https://github.com/microsoft/playwright.git
				synced 2025-06-26 21:40:17 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			158 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			158 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /**
 | |
|  * 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 reuse context', async ({ runInlineTest }) => {
 | |
|   const result = await runInlineTest({
 | |
|     'playwright/index.html': `<script type="module" src="/playwright/index.ts"></script>`,
 | |
|     'playwright/index.ts': `
 | |
|       //@no-header
 | |
|     `,
 | |
| 
 | |
|     'src/reuse.test.tsx': `
 | |
|       //@no-header
 | |
|       import { test, expect } from '@playwright/experimental-ct-react';
 | |
|       let lastContextGuid;
 | |
| 
 | |
|       test('one', async ({ context }) => {
 | |
|         lastContextGuid = context._guid;
 | |
|       });
 | |
| 
 | |
|       test('two', async ({ context }) => {
 | |
|         expect(context._guid).toBe(lastContextGuid);
 | |
|       });
 | |
| 
 | |
|       test.describe('Dark', () => {
 | |
|         test.use({ userAgent: 'dark' });
 | |
| 
 | |
|         test('three', async ({ context }) => {
 | |
|           expect(context._guid).not.toBe(lastContextGuid);
 | |
|         });
 | |
|       });
 | |
|     `,
 | |
|   }, { workers: 1 });
 | |
| 
 | |
|   expect(result.exitCode).toBe(0);
 | |
|   expect(result.passed).toBe(3);
 | |
| });
 | |
| 
 | |
| test('should not reuse context with video', async ({ runInlineTest }) => {
 | |
|   const result = await runInlineTest({
 | |
|     'playwright.config.ts': `
 | |
|       export default {
 | |
|         use: { video: 'on' },
 | |
|       };
 | |
|     `,
 | |
|     'playwright/index.html': `<script type="module" src="/playwright/index.ts"></script>`,
 | |
|     'playwright/index.ts': `
 | |
|       //@no-header
 | |
|     `,
 | |
| 
 | |
|     'src/reuse.test.tsx': `
 | |
|       //@no-header
 | |
|       import { test, expect } from '@playwright/experimental-ct-react';
 | |
|       let lastContext;
 | |
| 
 | |
|       test('one', async ({ context }) => {
 | |
|         lastContext = context;
 | |
|       });
 | |
| 
 | |
|       test('two', async ({ context }) => {
 | |
|         expect(context).not.toBe(lastContext);
 | |
|       });
 | |
|     `,
 | |
|   }, { workers: 1 });
 | |
| 
 | |
|   expect(result.exitCode).toBe(0);
 | |
|   expect(result.passed).toBe(2);
 | |
| });
 | |
| 
 | |
| test('should not reuse context with trace', async ({ runInlineTest }) => {
 | |
|   const result = await runInlineTest({
 | |
|     'playwright.config.ts': `
 | |
|       export default {
 | |
|         use: { trace: 'on' },
 | |
|       };
 | |
|     `,
 | |
|     'playwright/index.html': `<script type="module" src="/playwright/index.ts"></script>`,
 | |
|     'playwright/index.ts': `
 | |
|       //@no-header
 | |
|     `,
 | |
| 
 | |
|     'src/reuse.test.tsx': `
 | |
|       //@no-header
 | |
|       import { test, expect } from '@playwright/experimental-ct-react';
 | |
|       let lastContext;
 | |
| 
 | |
|       test('one', async ({ context }) => {
 | |
|         lastContext = context;
 | |
|       });
 | |
| 
 | |
|       test('two', async ({ context }) => {
 | |
|         expect(context).not.toBe(lastContext);
 | |
|       });
 | |
|     `,
 | |
|   }, { workers: 1 });
 | |
| 
 | |
|   expect(result.exitCode).toBe(0);
 | |
|   expect(result.passed).toBe(2);
 | |
| });
 | |
| 
 | |
| test('should work with manually closed pages', async ({ runInlineTest }) => {
 | |
|   const result = await runInlineTest({
 | |
|     'playwright/index.html': `<script type="module" src="/playwright/index.ts"></script>`,
 | |
|     'playwright/index.ts': `
 | |
|       //@no-header
 | |
|     `,
 | |
| 
 | |
|     'src/button.test.tsx': `
 | |
|       //@no-header
 | |
|       import { test, expect } from '@playwright/experimental-ct-react';
 | |
| 
 | |
|       test('closes page', async ({ mount, page }) => {
 | |
|         let hadEvent = false;
 | |
|         const component = await mount(<button onClick={e => hadEvent = true}>Submit</button>);
 | |
|         await expect(component).toHaveText('Submit');
 | |
|         await component.click();
 | |
|         expect(hadEvent).toBe(true);
 | |
|         await page.close();
 | |
|       });
 | |
| 
 | |
|       test('creates a new page', async ({ mount, page, context }) => {
 | |
|         let hadEvent = false;
 | |
|         const component = await mount(<button onClick={e => hadEvent = true}>Submit</button>);
 | |
|         await expect(component).toHaveText('Submit');
 | |
|         await component.click();
 | |
|         expect(hadEvent).toBe(true);
 | |
|         await page.close();
 | |
|         await context.newPage();
 | |
|       });
 | |
| 
 | |
|       test('still works', async ({ mount }) => {
 | |
|         let hadEvent = false;
 | |
|         const component = await mount(<button onClick={e => hadEvent = true}>Submit</button>);
 | |
|         await expect(component).toHaveText('Submit');
 | |
|         await component.click();
 | |
|         expect(hadEvent).toBe(true);
 | |
|       });
 | |
|     `,
 | |
|   }, { workers: 1 });
 | |
| 
 | |
|   expect(result.exitCode).toBe(0);
 | |
|   expect(result.passed).toBe(3);
 | |
| });
 | 
