2018-03-20 03:00:12 +00:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2019-02-25 20:51:06 +00:00
|
|
|
module.exports.addTests = function({testRunner, expect, headless, puppeteer, CHROME}) {
|
2018-03-20 03:00:12 +00:00
|
|
|
const {describe, xdescribe, fdescribe} = testRunner;
|
2019-02-06 06:32:41 +00:00
|
|
|
const {it, fit, xit, it_fails_ffox} = testRunner;
|
2018-03-20 03:00:12 +00:00
|
|
|
const {beforeAll, beforeEach, afterAll, afterEach} = testRunner;
|
|
|
|
|
2019-02-25 20:51:06 +00:00
|
|
|
describe('Browser.version', function() {
|
|
|
|
it('should return whether we are in headless', async({browser}) => {
|
|
|
|
const version = await browser.version();
|
|
|
|
expect(version.length).toBeGreaterThan(0);
|
2020-02-20 12:57:15 +00:00
|
|
|
expect(version.startsWith('Headless')).toBe(headless);
|
2019-02-25 20:51:06 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('Browser.userAgent', function() {
|
|
|
|
it('should include WebKit', async({browser}) => {
|
|
|
|
const userAgent = await browser.userAgent();
|
|
|
|
expect(userAgent.length).toBeGreaterThan(0);
|
|
|
|
if (CHROME)
|
|
|
|
expect(userAgent).toContain('WebKit');
|
|
|
|
else
|
|
|
|
expect(userAgent).toContain('Gecko');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2018-09-20 18:55:23 +00:00
|
|
|
describe('Browser.target', function() {
|
2019-02-17 18:23:48 +00:00
|
|
|
it('should return browser target', async({browser}) => {
|
2018-09-20 18:55:23 +00:00
|
|
|
const target = browser.target();
|
|
|
|
expect(target.type()).toBe('browser');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2018-03-20 03:00:12 +00:00
|
|
|
describe('Browser.process', function() {
|
|
|
|
it('should return child_process instance', async function({browser}) {
|
|
|
|
const process = await browser.process();
|
|
|
|
expect(process.pid).toBeGreaterThan(0);
|
2019-02-02 01:55:12 +00:00
|
|
|
});
|
2019-02-16 01:57:48 +00:00
|
|
|
it('should not return child_process for remote browser', async function({browser}) {
|
2018-03-20 03:00:12 +00:00
|
|
|
const browserWSEndpoint = browser.wsEndpoint();
|
|
|
|
const remoteBrowser = await puppeteer.connect({browserWSEndpoint});
|
|
|
|
expect(remoteBrowser.process()).toBe(null);
|
2019-05-21 14:26:04 +00:00
|
|
|
remoteBrowser.disconnect();
|
2018-03-20 03:00:12 +00:00
|
|
|
});
|
|
|
|
});
|
2019-05-09 23:24:52 +00:00
|
|
|
|
|
|
|
describe('Browser.isConnected', () => {
|
|
|
|
it('should set the browser connected state', async({browser}) => {
|
|
|
|
const browserWSEndpoint = browser.wsEndpoint();
|
|
|
|
const newBrowser = await puppeteer.connect({browserWSEndpoint});
|
|
|
|
expect(newBrowser.isConnected()).toBe(true);
|
2019-05-21 14:26:04 +00:00
|
|
|
newBrowser.disconnect();
|
2019-05-09 23:24:52 +00:00
|
|
|
expect(newBrowser.isConnected()).toBe(false);
|
|
|
|
});
|
|
|
|
});
|
2018-04-09 21:49:02 +00:00
|
|
|
};
|