Skip to content

Commit 2ec9e6d

Browse files
authored
test: cleanup some test files (#1195)
1 parent 9f3ccb4 commit 2ec9e6d

7 files changed

+106
-174
lines changed

test/chromium/headful.spec.js

-103
This file was deleted.

test/chromium/launcher.spec.js

+55-18
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,7 @@ const readFileAsync = util.promisify(fs.readFile);
2222
const rmAsync = util.promisify(require('rimraf'));
2323
const mkdtempAsync = util.promisify(fs.mkdtemp);
2424
const statAsync = util.promisify(fs.stat);
25+
const { makeUserDataDir, removeUserDataDir } = require('../utils');
2526

2627
const TMP_FOLDER = path.join(os.tmpdir(), 'pw_tmp_folder-');
2728

@@ -33,24 +34,60 @@ module.exports.describe = function({testRunner, expect, defaultBrowserOptions, p
3334
const {it, fit, xit, dit} = testRunner;
3435
const {beforeAll, beforeEach, afterAll, afterEach} = testRunner;
3536

36-
describe('CrPlaywright', function() {
37-
describe('Playwright.launch webSocket option', function() {
38-
it('should support the remote-debugging-port argument', async() => {
39-
const options = Object.assign({}, defaultBrowserOptions);
40-
const browserServer = await playwright.launchServer({ ...options, port: 0 });
41-
const browser = await playwright.connect({ wsEndpoint: browserServer.wsEndpoint() });
42-
expect(browserServer.wsEndpoint()).not.toBe(null);
43-
const page = await browser.newPage();
44-
expect(await page.evaluate('11 * 11')).toBe(121);
45-
await page.close();
46-
await browserServer.close();
47-
});
48-
it('should throw with remote-debugging-pipe argument and webSocket', async() => {
49-
const options = Object.assign({}, defaultBrowserOptions);
50-
options.args = ['--remote-debugging-pipe'].concat(options.args || []);
51-
const error = await playwright.launchServer(options).catch(e => e);
52-
expect(error.message).toContain('Playwright manages remote debugging connection itself');
53-
});
37+
const headfulOptions = Object.assign({}, defaultBrowserOptions, {
38+
headless: false
39+
});
40+
const extensionPath = path.join(__dirname, '..', 'assets', 'simple-extension');
41+
const extensionOptions = Object.assign({}, defaultBrowserOptions, {
42+
headless: false,
43+
args: [
44+
`--disable-extensions-except=${extensionPath}`,
45+
`--load-extension=${extensionPath}`,
46+
],
47+
});
48+
49+
describe('launcher', function() {
50+
it('should throw with remote-debugging-pipe argument', async() => {
51+
const options = Object.assign({}, defaultBrowserOptions);
52+
options.args = ['--remote-debugging-pipe'].concat(options.args || []);
53+
const error = await playwright.launchServer(options).catch(e => e);
54+
expect(error.message).toContain('Playwright manages remote debugging connection itself');
55+
});
56+
it('should throw with remote-debugging-port argument', async() => {
57+
const options = Object.assign({}, defaultBrowserOptions);
58+
options.args = ['--remote-debugging-port=9222'].concat(options.args || []);
59+
const error = await playwright.launchServer(options).catch(e => e);
60+
expect(error.message).toContain('Playwright manages remote debugging connection itself');
61+
});
62+
it('should open devtools when "devtools: true" option is given', async({server}) => {
63+
const browser = await playwright.launch(Object.assign({devtools: true}, headfulOptions));
64+
const context = await browser.newContext();
65+
const browserSession = await browser.createBrowserSession();
66+
await browserSession.send('Target.setDiscoverTargets', { discover: true });
67+
const devtoolsPagePromise = new Promise(fulfill => browserSession.on('Target.targetCreated', async ({targetInfo}) => {
68+
if (targetInfo.type === 'other' && targetInfo.url.includes('devtools://'))
69+
fulfill();
70+
}));
71+
await Promise.all([
72+
devtoolsPagePromise,
73+
context.newPage()
74+
]);
75+
await browser.close();
76+
});
77+
});
78+
79+
describe('extensions', () => {
80+
it('should return background pages', async() => {
81+
const userDataDir = await makeUserDataDir();
82+
const context = await playwright.launchPersistent(userDataDir, extensionOptions);
83+
const backgroundPages = await context.backgroundPages();
84+
let backgroundPage = backgroundPages.length
85+
? backgroundPages[0]
86+
: await new Promise(fulfill => context.once('backgroundpage', async event => fulfill(await event.page())));
87+
expect(backgroundPage).toBeTruthy();
88+
expect(await context.backgroundPages()).toContain(backgroundPage);
89+
expect(await context.pages()).not.toContain(backgroundPage);
90+
await removeUserDataDir(userDataDir);
5491
});
5592
});
5693

test/chromium/oopif.spec.js

+28-1
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,10 @@ module.exports.describe = function({testRunner, expect, defaultBrowserOptions, p
2222
const {it, fit, xit, dit} = testRunner;
2323
const {beforeAll, beforeEach, afterAll, afterEach} = testRunner;
2424

25+
const headfulOptions = Object.assign({}, defaultBrowserOptions, {
26+
headless: false
27+
});
28+
2529
describe('OOPIF', function() {
2630
beforeAll(async function(state) {
2731
state.browser = await playwright.launch(Object.assign({}, defaultBrowserOptions, {
@@ -54,7 +58,7 @@ module.exports.describe = function({testRunner, expect, defaultBrowserOptions, p
5458
expect(page.frames().length).toBe(2);
5559
});
5660
it('should load oopif iframes with subresources and request interception', async function({browser, page, server, context}) {
57-
await page.route('*', request => request.continue());
61+
await page.route('**/*', request => request.continue());
5862
const browserSession = await browser.createBrowserSession();
5963
await browserSession.send('Target.setDiscoverTargets', { discover: true });
6064
const oopifs = [];
@@ -66,5 +70,28 @@ module.exports.describe = function({testRunner, expect, defaultBrowserOptions, p
6670
expect(oopifs.length).toBe(1);
6771
await browserSession.detach();
6872
});
73+
it.fail(true)('should report google.com frame with headful', async({server}) => {
74+
// TODO: Support OOOPIF. @see https://github.com/GoogleChrome/puppeteer/issues/2548
75+
// https://google.com is isolated by default in Chromium embedder.
76+
const browser = await playwright.launch(headfulOptions);
77+
const page = await browser.newPage();
78+
await page.goto(server.EMPTY_PAGE);
79+
await page.route('**/*', request => {
80+
request.fulfill({body: 'YO, GOOGLE.COM'});
81+
});
82+
await page.evaluate(() => {
83+
const frame = document.createElement('iframe');
84+
frame.setAttribute('src', 'https://google.com/');
85+
document.body.appendChild(frame);
86+
return new Promise(x => frame.onload = x);
87+
});
88+
await page.waitForSelector('iframe[src="https://google.com/"]');
89+
const urls = page.frames().map(frame => frame.url()).sort();
90+
expect(urls).toEqual([
91+
server.EMPTY_PAGE,
92+
'https://google.com/'
93+
]);
94+
await browser.close();
95+
});
6996
});
7097
};

test/navigation.spec.js

+20-5
Original file line numberDiff line numberDiff line change
@@ -392,6 +392,21 @@ module.exports.describe = function({testRunner, expect, playwright, MAC, WIN, FF
392392
const error = await failed;
393393
expect(error.message).toBeTruthy();
394394
});
395+
it('extraHttpHeaders should be pushed to provisional page', async({page, server}) => {
396+
await page.goto(server.EMPTY_PAGE);
397+
const pagePath = '/one-style.html';
398+
server.setRoute(pagePath, async (req, res) => {
399+
page.setExtraHTTPHeaders({ foo: 'bar' });
400+
server.serveFile(req, res, pagePath);
401+
});
402+
const [htmlReq, cssReq] = await Promise.all([
403+
server.waitForRequest(pagePath),
404+
server.waitForRequest('/one-style.css'),
405+
page.goto(server.CROSS_PROCESS_PREFIX + pagePath)
406+
]);
407+
expect(htmlReq.headers['foo']).toBe(undefined);
408+
expect(cssReq.headers['foo']).toBe('bar');
409+
});
395410

396411
describe('network idle', function() {
397412
it('should navigate to empty page with networkidle0', async({page, server}) => {
@@ -404,11 +419,11 @@ module.exports.describe = function({testRunner, expect, playwright, MAC, WIN, FF
404419
});
405420

406421
/**
407-
* @param {import('../src/frames').Frame} frame
408-
* @param {TestServer} server
409-
* @param {'networkidle0'|'networkidle2'} signal
410-
* @param {() => Promise<void>} action
411-
* @param {boolean} isSetContent
422+
* @param {import('../src/frames').Frame} frame
423+
* @param {TestServer} server
424+
* @param {'networkidle0'|'networkidle2'} signal
425+
* @param {() => Promise<void>} action
426+
* @param {boolean} isSetContent
412427
*/
413428
async function networkIdleTest(frame, server, signal, action, isSetContent) {
414429
const finishResponse = response => {
File renamed without changes.

test/playwright.spec.js

+3-5
Original file line numberDiff line numberDiff line change
@@ -181,17 +181,16 @@ module.exports.describe = ({testRunner, product, playwrightPath}) => {
181181
testRunner.loadTests(require('./workers.spec.js'), testOptions);
182182
testRunner.loadTests(require('./capabilities.spec.js'), testOptions);
183183
});
184+
describe('[Permissions]', () => {
185+
testRunner.loadTests(require('./permissions.spec.js'), testOptions);
186+
});
184187

185188
describe.skip(!CHROMIUM)('[Chromium]', () => {
186189
testRunner.loadTests(require('./chromium/chromium.spec.js'), testOptions);
187190
testRunner.loadTests(require('./chromium/coverage.spec.js'), testOptions);
188191
testRunner.loadTests(require('./chromium/pdf.spec.js'), testOptions);
189192
testRunner.loadTests(require('./chromium/session.spec.js'), testOptions);
190193
});
191-
192-
describe('[Permissions]', () => {
193-
testRunner.loadTests(require('./features/permissions.spec.js'), testOptions);
194-
});
195194
});
196195

197196
// Browser-level tests that are given a browser.
@@ -214,7 +213,6 @@ module.exports.describe = ({testRunner, product, playwrightPath}) => {
214213

215214
describe.skip(!CHROMIUM)('[Chromium]', () => {
216215
testRunner.loadTests(require('./chromium/launcher.spec.js'), testOptions);
217-
testRunner.loadTests(require('./chromium/headful.spec.js'), testOptions);
218216
testRunner.loadTests(require('./chromium/oopif.spec.js'), testOptions);
219217
testRunner.loadTests(require('./chromium/tracing.spec.js'), testOptions);
220218
});

test/webkit/provisional.spec.js

-42
This file was deleted.

0 commit comments

Comments
 (0)