14fb3e38db
This patch: - introduces new testRunner methods `addTestDSL` and `addSuiteDSL` to add annotated test / suite. - introduces new test/suite declaration methods: `it_fails_ffox` and `describe_fails_ffox`. These are equal to `it`/`describe` for chromium tests and to `xit`/`xdescribe` for firefox. - marks all unsupported tests with `it_fails_ffox` - adds a new command-line flag `'--firefox-status'` to `//test/test.js`. This flag dumps current amount of tests that are intentionally skipped for Firefox. End goal: get rid of all `it_fails_ffox` and `describe_fails_ffox` tests. Drive-By: remove cookie tests "afterEach" hook that was removing cookies - it's not needed any more since every test is run in a designated browser context. References #3889
42 lines
1.6 KiB
JavaScript
42 lines
1.6 KiB
JavaScript
/**
|
|
* 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.
|
|
*/
|
|
|
|
module.exports.addTests = function({testRunner, expect, headless, puppeteer}) {
|
|
const {describe, xdescribe, fdescribe} = testRunner;
|
|
const {it, fit, xit, it_fails_ffox} = testRunner;
|
|
const {beforeAll, beforeEach, afterAll, afterEach} = testRunner;
|
|
|
|
describe('Browser.target', function() {
|
|
it_fails_ffox('should return browser target', async({browser}) => {
|
|
const target = browser.target();
|
|
expect(target.type()).toBe('browser');
|
|
});
|
|
});
|
|
|
|
describe('Browser.process', function() {
|
|
it('should return child_process instance', async function({browser}) {
|
|
const process = await browser.process();
|
|
expect(process.pid).toBeGreaterThan(0);
|
|
});
|
|
it_fails_ffox('should not return child_process for remote browser', async function({browser}) {
|
|
const browserWSEndpoint = browser.wsEndpoint();
|
|
const remoteBrowser = await puppeteer.connect({browserWSEndpoint});
|
|
expect(remoteBrowser.process()).toBe(null);
|
|
await remoteBrowser.disconnect();
|
|
});
|
|
});
|
|
};
|