| 
									
										
										
										
											2020-11-02 17:29:35 -08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 11:11:32 -07:00
										 |  |  | import { contextTest as it, expect } from './config/browserTest'; | 
					
						
							| 
									
										
										
										
											2020-11-02 17:29:35 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-02 21:07:45 -07:00
										 |  |  | it('should close browser with beforeunload page', async ({server, browserType, browserOptions }) => { | 
					
						
							| 
									
										
										
										
											2020-11-02 17:29:35 -08:00
										 |  |  |   const browser = await browserType.launch(browserOptions); | 
					
						
							|  |  |  |   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(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-05 18:48:46 -07:00
										 |  |  | it('should close browsercontext with beforeunload page', async ({server, page, context }) => { | 
					
						
							| 
									
										
										
										
											2020-11-02 17:29:35 -08:00
										 |  |  |   await page.goto(server.PREFIX + '/beforeunload.html'); | 
					
						
							|  |  |  |   // We have to interact with a page so that 'beforeunload' handlers
 | 
					
						
							|  |  |  |   // fire.
 | 
					
						
							|  |  |  |   await page.click('body'); | 
					
						
							| 
									
										
										
										
											2021-04-05 18:48:46 -07:00
										 |  |  |   await context.close(); | 
					
						
							| 
									
										
										
										
											2020-11-02 17:29:35 -08:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-05 18:48:46 -07:00
										 |  |  | it('should close page with beforeunload listener', async ({context, server}) => { | 
					
						
							| 
									
										
										
										
											2020-11-02 17:29:35 -08:00
										 |  |  |   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(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-05 18:48:46 -07:00
										 |  |  | it('should run beforeunload if asked for', async ({context, server, isChromium, isWebKit}) => { | 
					
						
							| 
									
										
										
										
											2020-11-02 17:29:35 -08:00
										 |  |  |   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 (isChromium) | 
					
						
							|  |  |  |     expect(dialog.message()).toBe(''); | 
					
						
							|  |  |  |   else if (isWebKit) | 
					
						
							|  |  |  |     expect(dialog.message()).toBe('Leave?'); | 
					
						
							|  |  |  |   else | 
					
						
							| 
									
										
										
										
											2021-04-19 23:26:33 -05:00
										 |  |  |     expect(dialog.message()).toContain('This page is asking you to confirm that you want to leave'); | 
					
						
							| 
									
										
										
										
											2020-11-02 17:29:35 -08:00
										 |  |  |   await Promise.all([ | 
					
						
							|  |  |  |     dialog.accept(), | 
					
						
							|  |  |  |     newPage.waitForEvent('close'), | 
					
						
							|  |  |  |   ]); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-05 18:48:46 -07:00
										 |  |  | it('should access page after beforeunload', async ({page, server}) => { | 
					
						
							| 
									
										
										
										
											2020-11-02 17:29:35 -08:00
										 |  |  |   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); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 |