/** * Copyright 2018 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. */ import { test as it, slowTest, expect } from './config/playwrightTest'; it('should have default url when launching browser', async ({browserType, browserOptions, createUserDataDir}) => { const browserContext = await browserType.launchPersistentContext(await createUserDataDir(), {...browserOptions, headless: false }); const urls = browserContext.pages().map(page => page.url()); expect(urls).toEqual(['about:blank']); await browserContext.close(); }); slowTest('headless should be able to read cookies written by headful', async ({browserType, browserOptions, server, createUserDataDir}) => { // see https://github.com/microsoft/playwright/issues/717 const userDataDir = await createUserDataDir(); // Write a cookie in headful chrome const headfulContext = await browserType.launchPersistentContext(userDataDir, {...browserOptions, headless: false}); const headfulPage = await headfulContext.newPage(); await headfulPage.goto(server.EMPTY_PAGE); await headfulPage.evaluate(() => document.cookie = 'foo=true; expires=Fri, 31 Dec 9999 23:59:59 GMT'); await headfulContext.close(); // Read the cookie from headless chrome const headlessContext = await browserType.launchPersistentContext(userDataDir, {...browserOptions, headless: true}); const headlessPage = await headlessContext.newPage(); await headlessPage.goto(server.EMPTY_PAGE); const cookie = await headlessPage.evaluate(() => document.cookie); await headlessContext.close(); expect(cookie).toBe('foo=true'); }); slowTest('should close browser with beforeunload page', async ({browserType, browserOptions, server, createUserDataDir}) => { const browserContext = await browserType.launchPersistentContext(await createUserDataDir(), {...browserOptions, headless: false}); const page = await browserContext.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 browserContext.close(); }); it('should not crash when creating second context', async ({browserType, browserOptions}) => { const browser = await browserType.launch({...browserOptions, headless: false }); { const browserContext = await browser.newContext(); await browserContext.newPage(); await browserContext.close(); } { const browserContext = await browser.newContext(); await browserContext.newPage(); await browserContext.close(); } await browser.close(); }); it('should click background tab', async ({browserType, browserOptions, server}) => { const browser = await browserType.launch({...browserOptions, headless: false }); const page = await browser.newPage(); await page.setContent(`empty.html`); await page.click('a'); await page.click('button'); await browser.close(); }); it('should close browser after context menu was triggered', async ({browserType, browserOptions, server}) => { const browser = await browserType.launch({...browserOptions, headless: false }); const page = await browser.newPage(); await page.goto(server.PREFIX + '/grid.html'); await page.click('body', {button: 'right'}); await browser.close(); }); it('should(not) block third party cookies', async ({browserType, browserOptions, server, isChromium, isFirefox}) => { const browser = await browserType.launch({...browserOptions, headless: false }); const page = await browser.newPage(); 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'); const documentCookie = await page.frames()[1].evaluate(() => { document.cookie = 'username=John Doe'; return document.cookie; }); await page.waitForTimeout(2000); const allowsThirdParty = isChromium || isFirefox; expect(documentCookie).toBe(allowsThirdParty ? 'username=John Doe' : ''); const cookies = await page.context().cookies(server.CROSS_PROCESS_PREFIX + '/grid.html'); 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([]); } await browser.close(); }); it('should not override viewport size when passed null', async function({browserType, browserOptions, server, browserName}) { it.fixme(browserName === 'webkit'); // Our WebKit embedder does not respect window features. const browser = await browserType.launch({...browserOptions, headless: false }); const context = await browser.newContext({ viewport: null }); const page = await context.newPage(); await page.goto(server.EMPTY_PAGE); const [popup] = await Promise.all([ page.waitForEvent('popup'), page.evaluate(() => { const win = window.open(window.location.href, 'Title', 'toolbar=no,location=no,directories=no,status=no,menubar=no,scrollbars=yes,resizable=yes,width=600,height=300,top=0,left=0'); win.resizeTo(500, 450); }), ]); await popup.waitForLoadState(); await popup.waitForFunction(() => window.outerWidth === 500 && window.outerHeight === 450); await context.close(); await browser.close(); }); it('Page.bringToFront should work', async ({browserType, browserOptions}) => { const browser = await browserType.launch({...browserOptions, headless: false }); const page1 = await browser.newPage(); await page1.setContent('Page1'); const page2 = await browser.newPage(); await page2.setContent('Page2'); await page1.bringToFront(); expect(await page1.evaluate('document.visibilityState')).toBe('visible'); expect(await page2.evaluate('document.visibilityState')).toBe('visible'); await page2.bringToFront(); expect(await page1.evaluate('document.visibilityState')).toBe('visible'); expect(await page2.evaluate('document.visibilityState')).toBe( 'visible' ); await browser.close(); }); it('focused input should produce the same screenshot', async ({browserType, browserOptions, browserName, platform, browserChannel}, testInfo) => { it.fail(browserName === 'firefox' && platform === 'darwin', 'headless has thinner outline'); it.fail(browserName === 'firefox' && platform === 'linux', 'headless has no outline'); it.skip(browserName === 'webkit' && platform === 'linux', 'gtk vs wpe'); it.skip(!!process.env.CRPATH); it.skip(!!browserChannel, 'Uncomment on roll'); testInfo.snapshotPathSegment = browserName + '-' + platform; const headful = await browserType.launch({...browserOptions, headless: false }); const headfulPage = await headful.newPage(); await headfulPage.setContent(''); await headfulPage.focus('input'); const headfulScreenshot = await headfulPage.screenshot(); await headful.close(); const headless = await browserType.launch({...browserOptions, headless: true }); const headlessPage = await headless.newPage(); await headlessPage.setContent(''); await headlessPage.focus('input'); const headlessScreenshot = await headlessPage.screenshot(); await headless.close(); expect(headfulScreenshot).toMatchSnapshot('focused-input.png'); expect(headlessScreenshot).toMatchSnapshot('focused-input.png'); });