fix: disable OOPIF by default (#2661)

This patch disables OOPIF by default.

**NOTE**: this is a temporary bandaid for the time we're crafting
the full-fledged support for site isolation over DevTools protocol.

References #2548.
This commit is contained in:
Andrey Lushnikov 2018-06-01 15:20:37 -07:00 committed by GitHub
parent 85d5a3348c
commit d8023726c5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 23 additions and 1 deletions

View File

@ -38,6 +38,8 @@ const DEFAULT_ARGS = [
'--disable-default-apps', '--disable-default-apps',
'--disable-dev-shm-usage', '--disable-dev-shm-usage',
'--disable-extensions', '--disable-extensions',
// TODO: Support OOOPIF. @see https://github.com/GoogleChrome/puppeteer/issues/2548
'--disable-features=site-per-process',
'--disable-hang-monitor', '--disable-hang-monitor',
'--disable-popup-blocking', '--disable-popup-blocking',
'--disable-prompt-on-repost', '--disable-prompt-on-repost',
@ -107,7 +109,6 @@ class Launcher {
if (Array.isArray(options.args)) if (Array.isArray(options.args))
chromeArguments.push(...options.args); chromeArguments.push(...options.args);
const usePipe = chromeArguments.includes('--remote-debugging-pipe'); const usePipe = chromeArguments.includes('--remote-debugging-pipe');
const stdio = ['pipe', 'pipe', 'pipe']; const stdio = ['pipe', 'pipe', 'pipe'];
if (usePipe) if (usePipe)

View File

@ -74,6 +74,27 @@ module.exports.addTests = function({testRunner, expect, PROJECT_ROOT, defaultBro
rm(userDataDir); rm(userDataDir);
expect(cookie).toBe('foo=true'); expect(cookie).toBe('foo=true');
}); });
it('OOPIF: should report google.com frame', async({server}) => {
// https://google.com is isolated by default in Chromium embedder.
const browser = await puppeteer.launch(headfulOptions);
const page = await browser.newPage();
await page.goto(server.EMPTY_PAGE);
await page.setRequestInterception(true);
page.on('request', r => r.respond({body: 'YO, GOOGLE.COM'}));
await page.evaluate(() => {
const frame = document.createElement('iframe');
frame.setAttribute('src', 'https://google.com/');
document.body.appendChild(frame);
return new Promise(x => frame.onload = x);
});
await page.waitForSelector('iframe[src="https://google.com/"]');
const urls = page.frames().map(frame => frame.url()).sort();
expect(urls).toEqual([
server.EMPTY_PAGE,
'https://google.com/'
]);
await browser.close();
});
}); });
}; };