| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Copyright 2017 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. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-08-16 19:19:52 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-25 15:05:50 -08:00
										 |  |  | import { browserTest as it, expect } from '../../config/browserTest'; | 
					
						
							| 
									
										
										
										
											2020-08-07 11:19:15 -07:00
										 |  |  | import fs from 'fs'; | 
					
						
							|  |  |  | import path from 'path'; | 
					
						
							| 
									
										
										
										
											2020-10-05 17:03:24 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  | it('should output a trace', async ({ browser, server }, testInfo) => { | 
					
						
							| 
									
										
										
										
											2023-09-25 10:59:14 -07:00
										 |  |  |   let warning = null; | 
					
						
							|  |  |  |   const warningHandler = w => warning = w; | 
					
						
							|  |  |  |   process.on('warning', warningHandler); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   const page = await browser.newPage(); | 
					
						
							|  |  |  |   const outputTraceFile = testInfo.outputPath(path.join(`trace.json`)); | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  |   await browser.startTracing(page, { screenshots: true, path: outputTraceFile }); | 
					
						
							| 
									
										
										
										
											2023-09-25 10:59:14 -07:00
										 |  |  |   for (let i = 0; i < 20; i++) | 
					
						
							|  |  |  |     await page.goto(server.PREFIX + '/grid.html'); | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   await browser.stopTracing(); | 
					
						
							|  |  |  |   expect(fs.existsSync(outputTraceFile)).toBe(true); | 
					
						
							|  |  |  |   await page.close(); | 
					
						
							| 
									
										
										
										
											2023-09-25 10:59:14 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   process.off('warning', warningHandler); | 
					
						
							|  |  |  |   expect(warning).toBe(null); | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  | }); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  | it('should create directories as needed', async ({ browser, server }, testInfo) => { | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   const page = await browser.newPage(); | 
					
						
							|  |  |  |   const filePath = testInfo.outputPath(path.join('these', 'are', 'directories', 'trace.json')); | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  |   await browser.startTracing(page, { screenshots: true, path: filePath }); | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   await page.goto(server.PREFIX + '/grid.html'); | 
					
						
							|  |  |  |   await browser.stopTracing(); | 
					
						
							|  |  |  |   expect(fs.existsSync(filePath)).toBe(true); | 
					
						
							|  |  |  |   await page.close(); | 
					
						
							|  |  |  | }); | 
					
						
							| 
									
										
										
										
											2020-08-17 16:53:19 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  | it('should run with custom categories if provided', async ({ browser }, testInfo) => { | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   const page = await browser.newPage(); | 
					
						
							|  |  |  |   const outputTraceFile = testInfo.outputPath(path.join(`trace.json`)); | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  |   await browser.startTracing(page, { path: outputTraceFile, categories: ['disabled-by-default-v8.cpu_profiler.hires'] }); | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   await browser.stopTracing(); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   const traceJson = JSON.parse(fs.readFileSync(outputTraceFile).toString()); | 
					
						
							|  |  |  |   expect(traceJson.metadata['trace-config']).toContain('disabled-by-default-v8.cpu_profiler.hires'); | 
					
						
							|  |  |  |   await page.close(); | 
					
						
							|  |  |  | }); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  | it('should throw if tracing on two pages', async ({ browser }, testInfo) => { | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   const page = await browser.newPage(); | 
					
						
							|  |  |  |   const outputTraceFile = testInfo.outputPath(path.join(`trace.json`)); | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  |   await browser.startTracing(page, { path: outputTraceFile }); | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   const newPage = await browser.newPage(); | 
					
						
							|  |  |  |   let error = null; | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  |   await browser.startTracing(newPage, { path: outputTraceFile }).catch(e => error = e); | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   await newPage.close(); | 
					
						
							|  |  |  |   expect(error).toBeTruthy(); | 
					
						
							|  |  |  |   await browser.stopTracing(); | 
					
						
							|  |  |  |   await page.close(); | 
					
						
							|  |  |  | }); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  | it('should return a buffer', async ({ browser, server }, testInfo) => { | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   const page = await browser.newPage(); | 
					
						
							|  |  |  |   const outputTraceFile = testInfo.outputPath(path.join(`trace.json`)); | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  |   await browser.startTracing(page, { screenshots: true, path: outputTraceFile }); | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   await page.goto(server.PREFIX + '/grid.html'); | 
					
						
							|  |  |  |   const trace = await browser.stopTracing(); | 
					
						
							|  |  |  |   const buf = fs.readFileSync(outputTraceFile); | 
					
						
							|  |  |  |   expect(trace.toString()).toEqual(buf.toString()); | 
					
						
							|  |  |  |   await page.close(); | 
					
						
							|  |  |  | }); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  | it('should work without options', async ({ browser, server }) => { | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   const page = await browser.newPage(); | 
					
						
							|  |  |  |   await browser.startTracing(page); | 
					
						
							|  |  |  |   await page.goto(server.PREFIX + '/grid.html'); | 
					
						
							|  |  |  |   const trace = await browser.stopTracing(); | 
					
						
							|  |  |  |   expect(trace).toBeTruthy(); | 
					
						
							|  |  |  |   await page.close(); | 
					
						
							|  |  |  | }); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  | it('should support a buffer without a path', async ({ browser, server }) => { | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   const page = await browser.newPage(); | 
					
						
							| 
									
										
										
										
											2021-09-27 18:58:08 +02:00
										 |  |  |   await browser.startTracing(page, { screenshots: true }); | 
					
						
							| 
									
										
										
										
											2021-05-08 17:45:04 -07:00
										 |  |  |   await page.goto(server.PREFIX + '/grid.html'); | 
					
						
							|  |  |  |   const trace = await browser.stopTracing(); | 
					
						
							|  |  |  |   expect(trace.toString()).toContain('screenshot'); | 
					
						
							|  |  |  |   await page.close(); | 
					
						
							| 
									
										
										
										
											2020-08-04 15:57:25 -07:00
										 |  |  | }); |