mirror of
				https://github.com/microsoft/playwright.git
				synced 2025-06-26 21:40:17 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			129 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /**
 | |
|  * Copyright 2017 Google Inc. All rights reserved.
 | |
|  * Modifications 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 { contextTest as it, expect } from '../config/browserTest';
 | |
| 
 | |
| it('should close browser with beforeunload page', async ({ server, browserType }) => {
 | |
|   const browser = await browserType.launch();
 | |
|   const page = await browser.newPage();
 | |
|   await page.goto(server.PREFIX + '/beforeunload.html');
 | |
|   // We have to interact with a page so that 'beforeunload' handlers
 | |
|   // fire.
 | |
|   await page.click('body');
 | |
|   await browser.close();
 | |
| });
 | |
| 
 | |
| it('should close browsercontext with beforeunload page', async ({ server, page, context }) => {
 | |
|   await page.goto(server.PREFIX + '/beforeunload.html');
 | |
|   // We have to interact with a page so that 'beforeunload' handlers
 | |
|   // fire.
 | |
|   await page.click('body');
 | |
|   await context.close();
 | |
| });
 | |
| 
 | |
| it('should be able to navigate away from page with beforeunload', async ({ server, page, context }) => {
 | |
|   await page.goto(server.PREFIX + '/beforeunload.html');
 | |
|   // We have to interact with a page so that 'beforeunload' handlers
 | |
|   // fire.
 | |
|   await page.click('body');
 | |
|   await page.goto(server.EMPTY_PAGE);
 | |
| });
 | |
| 
 | |
| it('should close page with beforeunload listener', async ({ context, server }) => {
 | |
|   const newPage = await context.newPage();
 | |
|   await newPage.goto(server.PREFIX + '/beforeunload.html');
 | |
|   // We have to interact with a page so that 'beforeunload' handlers
 | |
|   // fire.
 | |
|   await newPage.click('body');
 | |
|   await newPage.close();
 | |
| });
 | |
| 
 | |
| it('should run beforeunload if asked for @smoke', async ({ context, server, browserName }) => {
 | |
|   const newPage = await context.newPage();
 | |
|   await newPage.goto(server.PREFIX + '/beforeunload.html');
 | |
|   // We have to interact with a page so that 'beforeunload' handlers
 | |
|   // fire.
 | |
|   await newPage.click('body');
 | |
|   const [dialog] = await Promise.all([
 | |
|     newPage.waitForEvent('dialog'),
 | |
|     newPage.close({ runBeforeUnload: true })
 | |
|   ]);
 | |
|   expect(dialog.type()).toBe('beforeunload');
 | |
|   expect(dialog.defaultValue()).toBe('');
 | |
|   if (browserName === 'chromium')
 | |
|     expect(dialog.message()).toBe('');
 | |
|   else if (browserName === 'webkit')
 | |
|     expect(dialog.message()).toBe('Leave?');
 | |
|   else
 | |
|     expect(dialog.message()).toContain('This page is asking you to confirm that you want to leave');
 | |
|   await Promise.all([
 | |
|     dialog.accept(),
 | |
|     newPage.waitForEvent('close'),
 | |
|   ]);
 | |
| });
 | |
| 
 | |
| it('should access page after beforeunload', async ({ page, server }) => {
 | |
|   await page.goto(server.PREFIX + '/beforeunload.html');
 | |
|   // We have to interact with a page so that 'beforeunload' handlers
 | |
|   // fire.
 | |
|   await page.click('body');
 | |
|   const [dialog] = await Promise.all([
 | |
|     page.waitForEvent('dialog'),
 | |
|     page.close({ runBeforeUnload: true }),
 | |
|   ]);
 | |
|   await dialog.dismiss();
 | |
|   await page.evaluate(() => document.title);
 | |
| });
 | |
| 
 | |
| it('should not stall on evaluate when dismissing beforeunload', async ({ page, server }) => {
 | |
|   it.info().annotations.push({ type: 'issue', description: 'https://github.com/microsoft/playwright/issues/23141' });
 | |
| 
 | |
|   await page.goto(server.PREFIX + '/beforeunload.html');
 | |
|   // We have to interact with a page so that 'beforeunload' handlers fire.
 | |
|   await page.click('body');
 | |
| 
 | |
|   await Promise.all([
 | |
|     page.waitForEvent('dialog').then(dialog => dialog.dismiss()),
 | |
|     page.evaluate(() => {
 | |
|       window.location.reload();
 | |
|     }),
 | |
|   ]);
 | |
| });
 | |
| 
 | |
| it('should not stall on click when dismissing beforeunload', async ({ page, server }) => {
 | |
|   it.info().annotations.push({ type: 'issue', description: 'https://github.com/microsoft/playwright/issues/33806' });
 | |
| 
 | |
|   await page.goto(server.EMPTY_PAGE);
 | |
|   await page.setContent(`<a href="${server.PREFIX}/frames/one-frame.html">click me</a>`);
 | |
| 
 | |
|   await page.evaluate(() => {
 | |
|     window.onbeforeunload = () => false;
 | |
|   });
 | |
|   page.on('dialog', async dialog => {
 | |
|     await dialog.dismiss();
 | |
|   });
 | |
| 
 | |
|   await page.getByRole('link').click({ noWaitAfter: true });
 | |
|   await page.evaluate(() => {
 | |
|     window.onbeforeunload = null;
 | |
|   });
 | |
| 
 | |
|   // This line should not timeout.
 | |
|   await page.getByRole('link').click({ timeout: 5000 });
 | |
|   await expect(page).toHaveURL(server.PREFIX + '/frames/one-frame.html');
 | |
| });
 | 
