| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Copyright 2019 Google Inc. All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-25 15:05:50 -08:00
										 |  |  | import { playwrightTest as it, expect } from '../../config/browserTest'; | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-27 18:00:06 -08:00
										 |  |  | it('should throw with remote-debugging-pipe argument', async ({ browserType, mode }) => { | 
					
						
							| 
									
										
										
										
											2021-04-05 09:18:56 -07:00
										 |  |  |   it.skip(mode !== 'default'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-27 18:00:06 -08:00
										 |  |  |   const options: any = {}; | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  |   options.args = ['--remote-debugging-pipe'].concat(options.args || []); | 
					
						
							|  |  |  |   const error = await browserType.launchServer(options).catch(e => e); | 
					
						
							|  |  |  |   expect(error.message).toContain('Playwright manages remote debugging connection itself'); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-27 18:00:06 -08:00
										 |  |  | it('should not throw with remote-debugging-port argument', async ({ browserType, mode }) => { | 
					
						
							| 
									
										
										
										
											2021-04-05 09:18:56 -07:00
										 |  |  |   it.skip(mode !== 'default'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-27 18:00:06 -08:00
										 |  |  |   const options: any = {}; | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  |   options.args = ['--remote-debugging-port=0'].concat(options.args || []); | 
					
						
							|  |  |  |   const browser = await browserType.launchServer(options); | 
					
						
							|  |  |  |   await browser.close(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-27 18:00:06 -08:00
										 |  |  | it('should open devtools when "devtools: true" option is given', async ({ browserType, mode, platform, channel }) => { | 
					
						
							| 
									
										
										
										
											2021-07-13 15:57:40 -07:00
										 |  |  |   it.skip(mode !== 'default' || platform === 'win32' || !!channel); | 
					
						
							| 
									
										
										
										
											2021-04-05 09:18:56 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  |   let devtoolsCallback; | 
					
						
							|  |  |  |   const devtoolsPromise = new Promise(f => devtoolsCallback = f); | 
					
						
							|  |  |  |   const __testHookForDevTools = devtools => devtools.__testHookOnBinding = parsed => { | 
					
						
							|  |  |  |     if (parsed.method === 'getPreferences') | 
					
						
							|  |  |  |       devtoolsCallback(); | 
					
						
							|  |  |  |   }; | 
					
						
							| 
									
										
										
										
											2021-10-27 18:00:06 -08:00
										 |  |  |   const browser = await browserType.launch({ headless: false, devtools: true, __testHookForDevTools } as any); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  |   const context = await browser.newContext(); | 
					
						
							|  |  |  |   await Promise.all([ | 
					
						
							|  |  |  |     devtoolsPromise, | 
					
						
							|  |  |  |     context.newPage() | 
					
						
							|  |  |  |   ]); | 
					
						
							|  |  |  |   await browser.close(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-27 18:00:06 -08:00
										 |  |  | it('should return background pages', async ({ browserType, createUserDataDir, asset }) => { | 
					
						
							| 
									
										
										
										
											2020-09-18 15:52:14 -07:00
										 |  |  |   const userDataDir = await createUserDataDir(); | 
					
						
							| 
									
										
										
										
											2021-04-05 15:51:45 -07:00
										 |  |  |   const extensionPath = asset('simple-extension'); | 
					
						
							| 
									
										
										
										
											2021-10-27 18:00:06 -08:00
										 |  |  |   const extensionOptions = { | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  |     headless: false, | 
					
						
							|  |  |  |     args: [ | 
					
						
							|  |  |  |       `--disable-extensions-except=${extensionPath}`, | 
					
						
							|  |  |  |       `--load-extension=${extensionPath}`, | 
					
						
							|  |  |  |     ], | 
					
						
							|  |  |  |   }; | 
					
						
							| 
									
										
										
										
											2021-04-02 09:47:14 +08:00
										 |  |  |   const context = await browserType.launchPersistentContext(userDataDir, extensionOptions); | 
					
						
							| 
									
										
										
										
											2021-01-06 15:08:28 -08:00
										 |  |  |   const backgroundPages = context.backgroundPages(); | 
					
						
							|  |  |  |   const backgroundPage = backgroundPages.length | 
					
						
							|  |  |  |     ? backgroundPages[0] | 
					
						
							|  |  |  |     : await context.waitForEvent('backgroundpage'); | 
					
						
							|  |  |  |   expect(backgroundPage).toBeTruthy(); | 
					
						
							|  |  |  |   expect(context.backgroundPages()).toContain(backgroundPage); | 
					
						
							|  |  |  |   expect(context.pages()).not.toContain(backgroundPage); | 
					
						
							|  |  |  |   await context.close(); | 
					
						
							| 
									
										
										
										
											2021-05-12 22:15:04 +02:00
										 |  |  |   expect(context.pages().length).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-05-18 18:07:45 +02:00
										 |  |  |   expect(context.backgroundPages().length).toBe(0); | 
					
						
							| 
									
										
										
										
											2021-01-06 15:08:28 -08:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-27 18:00:06 -08:00
										 |  |  | it('should return background pages when recording video', async ({ browserType, createUserDataDir, asset }, testInfo) => { | 
					
						
							| 
									
										
										
										
											2021-01-06 15:08:28 -08:00
										 |  |  |   const userDataDir = await createUserDataDir(); | 
					
						
							| 
									
										
										
										
											2021-04-05 15:51:45 -07:00
										 |  |  |   const extensionPath = asset('simple-extension'); | 
					
						
							| 
									
										
										
										
											2021-10-27 18:00:06 -08:00
										 |  |  |   const extensionOptions = { | 
					
						
							| 
									
										
										
										
											2021-01-06 15:08:28 -08:00
										 |  |  |     headless: false, | 
					
						
							|  |  |  |     args: [ | 
					
						
							|  |  |  |       `--disable-extensions-except=${extensionPath}`, | 
					
						
							|  |  |  |       `--load-extension=${extensionPath}`, | 
					
						
							|  |  |  |     ], | 
					
						
							|  |  |  |     recordVideo: { | 
					
						
							|  |  |  |       dir: testInfo.outputPath(''), | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |   }; | 
					
						
							| 
									
										
										
										
											2021-04-02 09:47:14 +08:00
										 |  |  |   const context = await browserType.launchPersistentContext(userDataDir, extensionOptions); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  |   const backgroundPages = context.backgroundPages(); | 
					
						
							| 
									
										
										
										
											2020-08-28 04:20:29 -07:00
										 |  |  |   const backgroundPage = backgroundPages.length | 
					
						
							|  |  |  |     ? backgroundPages[0] | 
					
						
							|  |  |  |     : await context.waitForEvent('backgroundpage'); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  |   expect(backgroundPage).toBeTruthy(); | 
					
						
							|  |  |  |   expect(context.backgroundPages()).toContain(backgroundPage); | 
					
						
							|  |  |  |   expect(context.pages()).not.toContain(backgroundPage); | 
					
						
							|  |  |  |   await context.close(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-22 17:23:51 +02:00
										 |  |  | it('should support request/response events when using backgroundPage()', async ({ browserType, createUserDataDir, asset, server }) => { | 
					
						
							|  |  |  |   server.setRoute('/empty.html', (req, res) => { | 
					
						
							|  |  |  |     res.writeHead(200, { 'Content-Type': 'text/html', 'x-response-foobar': 'BarFoo' }); | 
					
						
							|  |  |  |     res.end(`<span>hello world!</span>`); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  |   const userDataDir = await createUserDataDir(); | 
					
						
							|  |  |  |   const extensionPath = asset('simple-extension'); | 
					
						
							|  |  |  |   const extensionOptions = { | 
					
						
							|  |  |  |     headless: false, | 
					
						
							|  |  |  |     args: [ | 
					
						
							|  |  |  |       `--disable-extensions-except=${extensionPath}`, | 
					
						
							|  |  |  |       `--load-extension=${extensionPath}`, | 
					
						
							|  |  |  |     ], | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   const context = await browserType.launchPersistentContext(userDataDir, extensionOptions); | 
					
						
							|  |  |  |   const backgroundPages = context.backgroundPages(); | 
					
						
							|  |  |  |   const backgroundPage = backgroundPages.length | 
					
						
							|  |  |  |     ? backgroundPages[0] | 
					
						
							|  |  |  |     : await context.waitForEvent('backgroundpage'); | 
					
						
							| 
									
										
										
										
											2022-06-23 09:36:33 +02:00
										 |  |  |   await backgroundPage.waitForURL(/chrome-extension\:\/\/.*/); | 
					
						
							| 
									
										
										
										
											2023-10-09 14:52:05 -07:00
										 |  |  |   const [request, response, contextRequest, contextResponse] = await Promise.all([ | 
					
						
							|  |  |  |     backgroundPage.waitForEvent('request'), | 
					
						
							|  |  |  |     backgroundPage.waitForEvent('response'), | 
					
						
							|  |  |  |     context.waitForEvent('request'), | 
					
						
							|  |  |  |     context.waitForEvent('response'), | 
					
						
							| 
									
										
										
										
											2022-06-22 17:23:51 +02:00
										 |  |  |     backgroundPage.evaluate(url => fetch(url, { | 
					
						
							|  |  |  |       method: 'POST', | 
					
						
							|  |  |  |       body: 'foobar', | 
					
						
							|  |  |  |       headers: { 'X-FOOBAR': 'KEKBAR' } | 
					
						
							|  |  |  |     }), server.EMPTY_PAGE), | 
					
						
							|  |  |  |   ]); | 
					
						
							|  |  |  |   expect(request).toBe(contextRequest); | 
					
						
							|  |  |  |   expect(response).toBe(contextResponse); | 
					
						
							|  |  |  |   expect(request.url()).toBe(server.EMPTY_PAGE); | 
					
						
							|  |  |  |   expect(request.method()).toBe('POST'); | 
					
						
							|  |  |  |   expect(await request.allHeaders()).toEqual(expect.objectContaining({ 'x-foobar': 'KEKBAR' })); | 
					
						
							|  |  |  |   expect(request.postData()).toBe('foobar'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   expect(response.status()).toBe(200); | 
					
						
							|  |  |  |   expect(response.url()).toBe(server.EMPTY_PAGE); | 
					
						
							|  |  |  |   expect(response.request()).toBe(request); | 
					
						
							|  |  |  |   expect(await response.text()).toBe('<span>hello world!</span>'); | 
					
						
							|  |  |  |   expect(await response.allHeaders()).toEqual(expect.objectContaining({ 'x-response-foobar': 'BarFoo' })); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   await context.close(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-27 18:00:06 -08:00
										 |  |  | it('should not create pages automatically', async ({ browserType }) => { | 
					
						
							|  |  |  |   const browser = await browserType.launch(); | 
					
						
							| 
									
										
										
										
											2021-04-02 09:47:14 +08:00
										 |  |  |   const browserSession = await browser.newBrowserCDPSession(); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  |   const targets = []; | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  |   browserSession.on('Target.targetCreated', async ({ targetInfo }) => { | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  |     if (targetInfo.type !== 'browser') | 
					
						
							| 
									
										
										
										
											2020-08-28 04:20:29 -07:00
										 |  |  |       targets.push(targetInfo); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  |   }); | 
					
						
							|  |  |  |   await browserSession.send('Target.setDiscoverTargets', { discover: true }); | 
					
						
							|  |  |  |   await browser.newContext(); | 
					
						
							|  |  |  |   await browser.close(); | 
					
						
							|  |  |  |   expect(targets.length).toBe(0); | 
					
						
							|  |  |  | }); |