2019-11-19 05:18:28 +03:00
/ * *
* Copyright 2017 Google Inc . All rights reserved .
2019-12-11 00:21:51 +03:00
* Modifications copyright ( c ) Microsoft Corporation .
2019-11-19 05:18:28 +03:00
*
* 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-05-22 01:13:16 +03:00
const fs = require ( 'fs' ) ;
2020-07-18 02:07:31 +03:00
const path = require ( 'path' ) ;
2020-04-09 01:19:09 +03:00
const utils = require ( './utils' ) ;
2020-07-18 02:07:31 +03:00
const os = require ( 'os' ) ;
2020-07-23 22:42:39 +03:00
const { mkdtempAsync , makeUserDataDir , removeUserDataDir } = utils ;
2020-07-18 02:07:31 +03:00
const { FFOX , MAC , CHROMIUM , WEBKIT , WIN , USES _HOOKS } = testOptions ;
2020-02-06 03:36:36 +03:00
2020-07-18 02:07:31 +03:00
registerFixture ( 'userDataDir' , async ( { } , test ) => {
const userDataDir = await mkdtempAsync ( path . join ( os . tmpdir ( ) , 'playwright_dev_profile-' ) ) ;
try {
await test ( userDataDir ) ;
} finally {
removeFolderAsync ( userDataDir ) . catch ( e => { } ) ;
}
} ) ;
registerFixture ( 'launchPersistent' , async ( { userDataDir , defaultBrowserOptions , browserType } , test ) => {
let context ;
async function launchPersistent ( options ) {
if ( context )
throw new Error ( 'can only launch one persitent context' ) ;
context = await browserType . launchPersistentContext ( userDataDir , { ... defaultBrowserOptions , ... options } ) ;
const page = context . pages ( ) [ 0 ] ;
return { context , page } ;
2020-05-22 01:13:16 +03:00
}
2020-07-18 02:07:31 +03:00
try {
await test ( launchPersistent ) ;
} finally {
if ( context )
await context . close ( ) ;
2020-05-22 01:13:16 +03:00
}
2020-07-18 02:07:31 +03:00
} ) ;
2020-05-22 01:13:16 +03:00
2020-07-18 02:07:31 +03:00
describe ( 'launchPersistentContext()' , function ( ) {
it ( 'context.cookies() should work' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( ) ;
2020-04-09 01:19:09 +03:00
await page . goto ( server . EMPTY _PAGE ) ;
2020-05-23 03:20:42 +03:00
const documentCookie = await page . evaluate ( ( ) => {
2020-04-09 01:19:09 +03:00
document . cookie = 'username=John Doe' ;
2020-05-23 03:20:42 +03:00
return document . cookie ;
2019-11-19 05:18:28 +03:00
} ) ;
2020-05-23 03:20:42 +03:00
expect ( documentCookie ) . toBe ( 'username=John Doe' ) ;
2020-04-09 01:19:09 +03:00
expect ( await page . context ( ) . cookies ( ) ) . toEqual ( [ {
name : 'username' ,
value : 'John Doe' ,
domain : 'localhost' ,
path : '/' ,
expires : - 1 ,
httpOnly : false ,
secure : false ,
sameSite : 'None' ,
} ] ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'context.addCookies() should work' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( ) ;
2020-04-09 01:19:09 +03:00
await page . goto ( server . EMPTY _PAGE ) ;
await page . context ( ) . addCookies ( [ {
url : server . EMPTY _PAGE ,
name : 'username' ,
value : 'John Doe'
} ] ) ;
expect ( await page . evaluate ( ( ) => document . cookie ) ) . toBe ( 'username=John Doe' ) ;
expect ( await page . context ( ) . cookies ( ) ) . toEqual ( [ {
name : 'username' ,
value : 'John Doe' ,
domain : 'localhost' ,
path : '/' ,
expires : - 1 ,
httpOnly : false ,
secure : false ,
sameSite : 'None' ,
} ] ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'context.clearCookies() should work' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( ) ;
2020-04-09 01:19:09 +03:00
await page . goto ( server . EMPTY _PAGE ) ;
await page . context ( ) . addCookies ( [ {
url : server . EMPTY _PAGE ,
name : 'cookie1' ,
value : '1'
} , {
url : server . EMPTY _PAGE ,
name : 'cookie2' ,
value : '2'
} ] ) ;
expect ( await page . evaluate ( 'document.cookie' ) ) . toBe ( 'cookie1=1; cookie2=2' ) ;
await page . context ( ) . clearCookies ( ) ;
await page . reload ( ) ;
expect ( await page . context ( ) . cookies ( [ ] ) ) . toEqual ( [ ] ) ;
expect ( await page . evaluate ( 'document.cookie' ) ) . toBe ( '' ) ;
2019-11-19 05:18:28 +03:00
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should(not) block third party cookies' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( ) ;
2020-05-04 19:14:42 +03:00
await page . goto ( server . EMPTY _PAGE ) ;
await page . evaluate ( src => {
let fulfill ;
const promise = new Promise ( x => fulfill = x ) ;
const iframe = document . createElement ( 'iframe' ) ;
document . body . appendChild ( iframe ) ;
iframe . onload = fulfill ;
iframe . src = src ;
return promise ;
} , server . CROSS _PROCESS _PREFIX + '/grid.html' ) ;
2020-05-23 03:20:42 +03:00
const documentCookie = await page . frames ( ) [ 1 ] . evaluate ( ( ) => {
document . cookie = 'username=John Doe' ;
return document . cookie ;
} ) ;
2020-05-04 19:14:42 +03:00
await page . waitForTimeout ( 2000 ) ;
const allowsThirdParty = CHROMIUM || FFOX ;
2020-05-26 20:22:53 +03:00
expect ( documentCookie ) . toBe ( allowsThirdParty ? 'username=John Doe' : '' ) ;
2020-05-22 01:13:16 +03:00
const cookies = await context . cookies ( server . CROSS _PROCESS _PREFIX + '/grid.html' ) ;
2020-05-04 19:14:42 +03:00
if ( allowsThirdParty ) {
expect ( cookies ) . toEqual ( [
{
"domain" : "127.0.0.1" ,
"expires" : - 1 ,
"httpOnly" : false ,
"name" : "username" ,
"path" : "/" ,
"sameSite" : "None" ,
"secure" : false ,
"value" : "John Doe"
}
] ) ;
} else {
expect ( cookies ) . toEqual ( [ ] ) ;
}
2020-05-22 01:13:16 +03:00
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support viewport option' , async ( { launchPersistent } ) => {
const { page , context } = await launchPersistent ( { viewport : { width : 456 , height : 789 } } ) ;
2020-06-24 20:16:54 +03:00
await utils . verifyViewport ( page , 456 , 789 ) ;
2020-07-18 02:07:31 +03:00
const page2 = await context . newPage ( ) ;
await utils . verifyViewport ( page2 , 456 , 789 ) ;
2020-05-22 01:13:16 +03:00
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support deviceScaleFactor option' , async ( { launchPersistent } ) => {
const { page , context } = await launchPersistent ( { deviceScaleFactor : 3 } ) ;
2020-05-22 01:13:16 +03:00
expect ( await page . evaluate ( 'window.devicePixelRatio' ) ) . toBe ( 3 ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support userAgent option' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( { userAgent : 'foobar' } ) ;
2020-05-22 01:13:16 +03:00
expect ( await page . evaluate ( ( ) => navigator . userAgent ) ) . toBe ( 'foobar' ) ;
const [ request ] = await Promise . all ( [
server . waitForRequest ( '/empty.html' ) ,
page . goto ( server . EMPTY _PAGE ) ,
] ) ;
expect ( request . headers [ 'user-agent' ] ) . toBe ( 'foobar' ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support bypassCSP option' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( { bypassCSP : true } ) ;
2020-05-22 01:13:16 +03:00
await page . goto ( server . PREFIX + '/csp.html' ) ;
await page . addScriptTag ( { content : 'window.__injected = 42;' } ) ;
expect ( await page . evaluate ( ( ) => window . _ _injected ) ) . toBe ( 42 ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support javascriptEnabled option' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( { javaScriptEnabled : false } ) ;
2020-05-22 01:13:16 +03:00
await page . goto ( 'data:text/html, <script>var something = "forbidden"</script>' ) ;
let error = null ;
await page . evaluate ( 'something' ) . catch ( e => error = e ) ;
if ( WEBKIT )
expect ( error . message ) . toContain ( 'Can\'t find variable: something' ) ;
else
expect ( error . message ) . toContain ( 'something is not defined' ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support httpCredentials option' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( { httpCredentials : { username : 'user' , password : 'pass' } } ) ;
2020-05-22 01:13:16 +03:00
server . setAuth ( '/playground.html' , 'user' , 'pass' ) ;
const response = await page . goto ( server . PREFIX + '/playground.html' ) ;
expect ( response . status ( ) ) . toBe ( 200 ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support offline option' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( { offline : true } ) ;
2020-05-22 01:13:16 +03:00
const error = await page . goto ( server . EMPTY _PAGE ) . catch ( e => e ) ;
expect ( error ) . toBeTruthy ( ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it . skip ( true ) ( 'should support acceptDownloads option' , async ( { server , launchPersistent } ) => {
2020-05-22 01:13:16 +03:00
// TODO: unskip once we support downloads in persistent context.
2020-07-18 02:07:31 +03:00
const { page , context } = await launchPersistent ( { acceptDownloads : true } ) ;
2020-05-22 01:13:16 +03:00
server . setRoute ( '/download' , ( req , res ) => {
res . setHeader ( 'Content-Type' , 'application/octet-stream' ) ;
res . setHeader ( 'Content-Disposition' , 'attachment' ) ;
res . end ( ` Hello world ` ) ;
} ) ;
await page . setContent ( ` <a href=" ${ server . PREFIX } /download">download</a> ` ) ;
const [ download ] = await Promise . all ( [
page . waitForEvent ( 'download' ) ,
page . click ( 'a' )
] ) ;
const path = await download . path ( ) ;
expect ( fs . existsSync ( path ) ) . toBeTruthy ( ) ;
expect ( fs . readFileSync ( path ) . toString ( ) ) . toBe ( 'Hello world' ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support hasTouch option' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( { hasTouch : true } ) ;
2020-05-22 01:13:16 +03:00
await page . goto ( server . PREFIX + '/mobile.html' ) ;
expect ( await page . evaluate ( ( ) => 'ontouchstart' in window ) ) . toBe ( true ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it . skip ( FFOX ) ( 'should work in persistent context' , async ( { server , launchPersistent } ) => {
2020-05-22 01:13:16 +03:00
// Firefox does not support mobile.
2020-07-18 02:07:31 +03:00
const { page , context } = await launchPersistent ( { viewport : { width : 320 , height : 480 } , isMobile : true } ) ;
2020-05-22 01:13:16 +03:00
await page . goto ( server . PREFIX + '/empty.html' ) ;
expect ( await page . evaluate ( ( ) => window . innerWidth ) ) . toBe ( 980 ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support colorScheme option' , async ( { launchPersistent } ) => {
const { page , context } = await launchPersistent ( { colorScheme : 'dark' } ) ;
2020-05-22 01:13:16 +03:00
expect ( await page . evaluate ( ( ) => matchMedia ( '(prefers-color-scheme: light)' ) . matches ) ) . toBe ( false ) ;
expect ( await page . evaluate ( ( ) => matchMedia ( '(prefers-color-scheme: dark)' ) . matches ) ) . toBe ( true ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support timezoneId option' , async ( { launchPersistent } ) => {
const { page , context } = await launchPersistent ( { timezoneId : 'America/Jamaica' } ) ;
2020-05-22 01:13:16 +03:00
expect ( await page . evaluate ( ( ) => new Date ( 1479579154987 ) . toString ( ) ) ) . toBe ( 'Sat Nov 19 2016 13:12:34 GMT-0500 (Eastern Standard Time)' ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support locale option' , async ( { launchPersistent } ) => {
const { page , context } = await launchPersistent ( { locale : 'fr-CH' } ) ;
2020-05-22 01:13:16 +03:00
expect ( await page . evaluate ( ( ) => navigator . language ) ) . toBe ( 'fr-CH' ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support geolocation and permissions options' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( { geolocation : { longitude : 10 , latitude : 10 } , permissions : [ 'geolocation' ] } ) ;
2020-05-22 01:13:16 +03:00
await page . goto ( server . EMPTY _PAGE ) ;
const geolocation = await page . evaluate ( ( ) => new Promise ( resolve => navigator . geolocation . getCurrentPosition ( position => {
resolve ( { latitude : position . coords . latitude , longitude : position . coords . longitude } ) ;
} ) ) ) ;
expect ( geolocation ) . toEqual ( { latitude : 10 , longitude : 10 } ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support ignoreHTTPSErrors option' , async ( { httpsServer , launchPersistent } ) => {
const { page , context } = await launchPersistent ( { ignoreHTTPSErrors : true } ) ;
2020-05-22 01:13:16 +03:00
let error = null ;
const response = await page . goto ( httpsServer . EMPTY _PAGE ) . catch ( e => error = e ) ;
expect ( error ) . toBe ( null ) ;
expect ( response . ok ( ) ) . toBe ( true ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should support extraHTTPHeaders option' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( { extraHTTPHeaders : { foo : 'bar' } } ) ;
2020-05-22 01:13:16 +03:00
const [ request ] = await Promise . all ( [
server . waitForRequest ( '/empty.html' ) ,
page . goto ( server . EMPTY _PAGE ) ,
] ) ;
expect ( request . headers [ 'foo' ] ) . toBe ( 'bar' ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should accept userDataDir' , async ( { launchPersistent , userDataDir } ) => {
const { page , context } = await launchPersistent ( ) ;
2020-05-22 01:13:16 +03:00
// Note: we need an open page to make sure its functional.
expect ( fs . readdirSync ( userDataDir ) . length ) . toBeGreaterThan ( 0 ) ;
await context . close ( ) ;
expect ( fs . readdirSync ( userDataDir ) . length ) . toBeGreaterThan ( 0 ) ;
// This might throw. See https://github.com/GoogleChrome/puppeteer/issues/2778
await removeUserDataDir ( userDataDir ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it . slow ( ) ( 'should restore state from userDataDir' , async ( { browserType , defaultBrowserOptions , server , launchPersistent } ) => {
2020-05-22 01:13:16 +03:00
const userDataDir = await makeUserDataDir ( ) ;
const browserContext = await browserType . launchPersistentContext ( userDataDir , defaultBrowserOptions ) ;
const page = await browserContext . newPage ( ) ;
await page . goto ( server . EMPTY _PAGE ) ;
await page . evaluate ( ( ) => localStorage . hey = 'hello' ) ;
await browserContext . close ( ) ;
const browserContext2 = await browserType . launchPersistentContext ( userDataDir , defaultBrowserOptions ) ;
const page2 = await browserContext2 . newPage ( ) ;
await page2 . goto ( server . EMPTY _PAGE ) ;
expect ( await page2 . evaluate ( ( ) => localStorage . hey ) ) . toBe ( 'hello' ) ;
await browserContext2 . close ( ) ;
const userDataDir2 = await makeUserDataDir ( ) ;
const browserContext3 = await browserType . launchPersistentContext ( userDataDir2 , defaultBrowserOptions ) ;
const page3 = await browserContext3 . newPage ( ) ;
await page3 . goto ( server . EMPTY _PAGE ) ;
expect ( await page3 . evaluate ( ( ) => localStorage . hey ) ) . not . toBe ( 'hello' ) ;
await browserContext3 . close ( ) ;
// This might throw. See https://github.com/GoogleChrome/puppeteer/issues/2778
await removeUserDataDir ( userDataDir ) ;
await removeUserDataDir ( userDataDir2 ) ;
} ) ;
2020-07-18 03:17:06 +03:00
it . fail ( CHROMIUM && ( WIN || MAC ) ) . slow ( ) ( 'should restore cookies from userDataDir' , async ( { browserType , defaultBrowserOptions , server , launchPersistent } ) => {
2020-05-22 01:13:16 +03:00
const userDataDir = await makeUserDataDir ( ) ;
const browserContext = await browserType . launchPersistentContext ( userDataDir , defaultBrowserOptions ) ;
const page = await browserContext . newPage ( ) ;
await page . goto ( server . EMPTY _PAGE ) ;
2020-05-28 08:17:42 +03:00
const documentCookie = await page . evaluate ( ( ) => {
document . cookie = 'doSomethingOnlyOnce=true; expires=Fri, 31 Dec 9999 23:59:59 GMT' ;
return document . cookie ;
} ) ;
expect ( documentCookie ) . toBe ( 'doSomethingOnlyOnce=true' ) ;
2020-05-22 01:13:16 +03:00
await browserContext . close ( ) ;
const browserContext2 = await browserType . launchPersistentContext ( userDataDir , defaultBrowserOptions ) ;
const page2 = await browserContext2 . newPage ( ) ;
await page2 . goto ( server . EMPTY _PAGE ) ;
expect ( await page2 . evaluate ( ( ) => document . cookie ) ) . toBe ( 'doSomethingOnlyOnce=true' ) ;
await browserContext2 . close ( ) ;
const userDataDir2 = await makeUserDataDir ( ) ;
const browserContext3 = await browserType . launchPersistentContext ( userDataDir2 , defaultBrowserOptions ) ;
const page3 = await browserContext3 . newPage ( ) ;
await page3 . goto ( server . EMPTY _PAGE ) ;
2020-05-28 08:17:42 +03:00
expect ( await page3 . evaluate ( ( ) => document . cookie ) ) . not . toBe ( 'doSomethingOnlyOnce=true' ) ;
2020-05-22 01:13:16 +03:00
await browserContext3 . close ( ) ;
// This might throw. See https://github.com/GoogleChrome/puppeteer/issues/2778
await removeUserDataDir ( userDataDir ) ;
await removeUserDataDir ( userDataDir2 ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should have default URL when launching browser' , async ( { launchPersistent } ) => {
const { page , context } = await launchPersistent ( ) ;
2020-05-22 01:13:16 +03:00
const urls = context . pages ( ) . map ( page => page . url ( ) ) ;
expect ( urls ) . toEqual ( [ 'about:blank' ] ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it . skip ( FFOX ) ( 'should throw if page argument is passed' , async ( { browserType , defaultBrowserOptions , server , userDataDir } ) => {
2020-05-22 01:13:16 +03:00
const options = { ... defaultBrowserOptions , args : [ server . EMPTY _PAGE ] } ;
const error = await browserType . launchPersistentContext ( userDataDir , options ) . catch ( e => e ) ;
expect ( error . message ) . toContain ( 'can not specify page' ) ;
} ) ;
2020-07-24 20:17:07 +03:00
it . skip ( USES _HOOKS ) ( 'should have passed URL when launching with ignoreDefaultArgs: true' , async ( { browserType , defaultBrowserOptions , server , userDataDir , toImpl } ) => {
const args = toImpl ( browserType ) . _defaultArgs ( defaultBrowserOptions , 'persistent' , userDataDir , 0 ) . filter ( a => a !== 'about:blank' ) ;
2020-05-22 01:13:16 +03:00
const options = {
... defaultBrowserOptions ,
args : [ ... args , server . EMPTY _PAGE ] ,
ignoreDefaultArgs : true ,
} ;
const browserContext = await browserType . launchPersistentContext ( userDataDir , options ) ;
if ( ! browserContext . pages ( ) . length )
await browserContext . waitForEvent ( 'page' ) ;
await browserContext . pages ( ) [ 0 ] . waitForLoadState ( ) ;
const gotUrls = browserContext . pages ( ) . map ( page => page . url ( ) ) ;
expect ( gotUrls ) . toEqual ( [ server . EMPTY _PAGE ] ) ;
await browserContext . close ( ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it . skip ( USES _HOOKS ) ( 'should handle timeout' , async ( { browserType , defaultBrowserOptions , userDataDir } ) => {
2020-05-22 01:13:16 +03:00
const options = { ... defaultBrowserOptions , timeout : 5000 , _ _testHookBeforeCreateBrowser : ( ) => new Promise ( f => setTimeout ( f , 6000 ) ) } ;
const error = await browserType . launchPersistentContext ( userDataDir , options ) . catch ( e => e ) ;
2020-07-16 00:04:39 +03:00
expect ( error . message ) . toContain ( ` browserType.launchPersistentContext: Timeout 5000ms exceeded. ` ) ;
2020-05-22 01:13:16 +03:00
} ) ;
2020-07-18 02:07:31 +03:00
it . skip ( USES _HOOKS ) ( 'should handle exception' , async ( { browserType , defaultBrowserOptions , userDataDir } ) => {
2020-05-22 01:13:16 +03:00
const e = new Error ( 'Dummy' ) ;
const options = { ... defaultBrowserOptions , _ _testHookBeforeCreateBrowser : ( ) => { throw e ; } } ;
const error = await browserType . launchPersistentContext ( userDataDir , options ) . catch ( e => e ) ;
2020-07-13 18:31:20 +03:00
expect ( error . message ) . toContain ( 'Dummy' ) ;
2020-05-22 01:13:16 +03:00
} ) ;
2020-07-18 02:07:31 +03:00
it ( 'should fire close event for a persistent context' , async ( { launchPersistent } ) => {
const { page , context } = await launchPersistent ( ) ;
2020-07-09 18:34:07 +03:00
let closed = false ;
context . on ( 'close' , ( ) => closed = true ) ;
2020-07-18 02:07:31 +03:00
await context . close ( ) ;
2020-07-09 18:34:07 +03:00
expect ( closed ) . toBe ( true ) ;
2020-07-13 18:31:20 +03:00
} ) ;
2020-07-18 02:07:31 +03:00
it . skip ( ! CHROMIUM ) ( 'coverage should work' , async ( { server , launchPersistent } ) => {
const { page , context } = await launchPersistent ( ) ;
2020-07-14 01:26:09 +03:00
await page . coverage . startJSCoverage ( ) ;
await page . goto ( server . PREFIX + '/jscoverage/simple.html' , { waitUntil : 'load' } ) ;
const coverage = await page . coverage . stopJSCoverage ( ) ;
expect ( coverage . length ) . toBe ( 1 ) ;
expect ( coverage [ 0 ] . url ) . toContain ( '/jscoverage/simple.html' ) ;
expect ( coverage [ 0 ] . functions . find ( f => f . functionName === 'foo' ) . ranges [ 0 ] . count ) . toEqual ( 1 ) ;
} ) ;
2020-07-18 02:07:31 +03:00
it . skip ( CHROMIUM ) ( 'coverage should be missing' , async ( { launchPersistent } ) => {
const { page , context } = await launchPersistent ( ) ;
2020-07-14 01:26:09 +03:00
expect ( page . coverage ) . toBe ( null ) ;
} ) ;
2020-04-09 01:19:09 +03:00
} ) ;