From 8f9fbdbae68254600a9c73ab05f36146c975dba6 Mon Sep 17 00:00:00 2001 From: Maksim Sadym <69349599+sadym-chromium@users.noreply.github.com> Date: Tue, 2 Feb 2021 08:39:29 +0100 Subject: [PATCH] feat(chromium): roll Chromium to r843427 (#6797) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This corresponds to Chromium 89.0.4389.0. This roll includes: - Add `SameParty` attribute to cookies https://crrev.com/c/2598846 - Anchor `target=_blank` implies `rel=noopener` https://crrev.com/c/1630010 - Don’t expect ignored elements in the AXTree https://crrev.com/c/2505362 BREAKING CHANGE: The built-in `aria/` selector query handler doesn’t return ignored elements anymore. Issue: #6758 --- package.json | 2 +- src/revisions.ts | 2 +- test/ariaqueryhandler.spec.ts | 6 +++--- test/cookies.spec.ts | 11 +++++++++++ test/defaultbrowsercontext.spec.ts | 3 +++ test/page.spec.ts | 16 +++++++++++++++- test/worker.spec.ts | 2 +- versions.js | 1 + 8 files changed, 36 insertions(+), 7 deletions(-) diff --git a/package.json b/package.json index 8b64a8cd..8bdd2960 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "license": "Apache-2.0", "dependencies": { "debug": "^4.1.0", - "devtools-protocol": "0.0.818844", + "devtools-protocol": "0.0.842839", "extract-zip": "^2.0.0", "https-proxy-agent": "^5.0.0", "node-fetch": "^2.6.1", diff --git a/src/revisions.ts b/src/revisions.ts index 5e9169ad..eaeb33a1 100644 --- a/src/revisions.ts +++ b/src/revisions.ts @@ -20,6 +20,6 @@ type Revisions = Readonly<{ }>; export const PUPPETEER_REVISIONS: Revisions = { - chromium: '818858', + chromium: '843427', firefox: 'latest', }; diff --git a/test/ariaqueryhandler.spec.ts b/test/ariaqueryhandler.spec.ts index 93e2a9f2..576dedf2 100644 --- a/test/ariaqueryhandler.spec.ts +++ b/test/ariaqueryhandler.spec.ts @@ -563,13 +563,13 @@ describeChromeOnly('AriaQueryHandler', () => { const { page } = getTestState(); const found = await page.$$('aria/[role="heading"]'); const ids = await getIds(found); - expect(ids).toEqual(['shown', 'hidden', 'node11', 'node13']); + expect(ids).toEqual(['shown', 'node11', 'node13']); }); - it('should find both ignored and unignored', async () => { + it('should not find ignored', async () => { const { page } = getTestState(); const found = await page.$$('aria/title'); const ids = await getIds(found); - expect(ids).toEqual(['shown', 'hidden']); + expect(ids).toEqual(['shown']); }); }); }); diff --git a/test/cookies.spec.ts b/test/cookies.spec.ts index 27edbd5a..29f4ad98 100644 --- a/test/cookies.spec.ts +++ b/test/cookies.spec.ts @@ -43,6 +43,7 @@ describe('Cookie specs', () => { value: 'John Doe', domain: 'localhost', path: '/', + sameParty: false, expires: -1, size: 16, httpOnly: false, @@ -99,6 +100,7 @@ describe('Cookie specs', () => { value: '1234', domain: 'localhost', path: '/', + sameParty: false, expires: -1, size: 12, httpOnly: false, @@ -110,6 +112,7 @@ describe('Cookie specs', () => { value: 'John Doe', domain: 'localhost', path: '/', + sameParty: false, expires: -1, size: 16, httpOnly: false, @@ -145,6 +148,7 @@ describe('Cookie specs', () => { value: 'tweets', domain: 'baz.com', path: '/', + sameParty: false, expires: -1, size: 11, httpOnly: false, @@ -156,6 +160,7 @@ describe('Cookie specs', () => { value: 'woofs', domain: 'foo.com', path: '/', + sameParty: false, expires: -1, size: 10, httpOnly: false, @@ -248,6 +253,7 @@ describe('Cookie specs', () => { value: '123456', domain: 'localhost', path: '/', + sameParty: false, expires: -1, size: 14, httpOnly: false, @@ -271,6 +277,7 @@ describe('Cookie specs', () => { value: 'GRID', domain: 'localhost', path: '/grid.html', + sameParty: false, expires: -1, size: 14, httpOnly: false, @@ -376,6 +383,7 @@ describe('Cookie specs', () => { value: 'best', domain: 'www.example.com', path: '/', + sameParty: false, expires: -1, size: 18, httpOnly: false, @@ -414,6 +422,7 @@ describe('Cookie specs', () => { value: 'best', domain: 'localhost', path: '/', + sameParty: false, expires: -1, size: 20, httpOnly: false, @@ -428,6 +437,7 @@ describe('Cookie specs', () => { value: 'worst', domain: '127.0.0.1', path: '/', + sameParty: false, expires: -1, size: 15, httpOnly: false, @@ -479,6 +489,7 @@ describe('Cookie specs', () => { value: 'best', domain: '127.0.0.1', path: '/', + sameParty: false, expires: -1, size: 24, httpOnly: false, diff --git a/test/defaultbrowsercontext.spec.ts b/test/defaultbrowsercontext.spec.ts index 01dec7f3..bd695d30 100644 --- a/test/defaultbrowsercontext.spec.ts +++ b/test/defaultbrowsercontext.spec.ts @@ -37,6 +37,7 @@ describe('DefaultBrowserContext', function () { value: 'John Doe', domain: 'localhost', path: '/', + sameParty: false, expires: -1, size: 16, httpOnly: false, @@ -62,6 +63,7 @@ describe('DefaultBrowserContext', function () { value: 'John Doe', domain: 'localhost', path: '/', + sameParty: false, expires: -1, size: 16, httpOnly: false, @@ -93,6 +95,7 @@ describe('DefaultBrowserContext', function () { value: '1', domain: 'localhost', path: '/', + sameParty: false, expires: -1, size: 8, httpOnly: false, diff --git a/test/page.spec.ts b/test/page.spec.ts index 18a653e6..b190518f 100644 --- a/test/page.spec.ts +++ b/test/page.spec.ts @@ -176,7 +176,7 @@ describe('Page', function () { expect(await page.evaluate(() => !!window.opener)).toBe(false); expect(await popup.evaluate(() => !!window.opener)).toBe(false); }); - it('should work with clicking target=_blank', async () => { + it('should work with clicking target=_blank and without rel=opener', async () => { const { page, server } = getTestState(); await page.goto(server.EMPTY_PAGE); @@ -186,6 +186,20 @@ describe('Page', function () { page.click('a'), ]); expect(await page.evaluate(() => !!window.opener)).toBe(false); + expect(await popup.evaluate(() => !!window.opener)).toBe(false); + }); + it('should work with clicking target=_blank and with rel=opener', async () => { + const { page, server } = getTestState(); + + await page.goto(server.EMPTY_PAGE); + await page.setContent( + 'yo' + ); + const [popup] = await Promise.all([ + new Promise((x) => page.once('popup', x)), + page.click('a'), + ]); + expect(await page.evaluate(() => !!window.opener)).toBe(false); expect(await popup.evaluate(() => !!window.opener)).toBe(true); }); it('should work with fake-clicking target=_blank and rel=noopener', async () => { diff --git a/test/worker.spec.ts b/test/worker.spec.ts index 2c582736..b4f81dbb 100644 --- a/test/worker.spec.ts +++ b/test/worker.spec.ts @@ -79,7 +79,7 @@ describeFailsFirefox('Workers', function () { ]); expect(message.text()).toBe('1'); expect(message.location()).toEqual({ - url: 'data:text/javascript,console.log(1)', + url: '', lineNumber: 0, columnNumber: 8, }); diff --git a/versions.js b/versions.js index 003b3854..36c4c886 100644 --- a/versions.js +++ b/versions.js @@ -17,6 +17,7 @@ const versionsPerRelease = new Map([ // This is a mapping from Chromium version => Puppeteer version. // In Chromium roll patches, use 'NEXT' for the Puppeteer version. + ['89.0.4389.0', 'NEXT'], ['88.0.4298.0', 'v5.5.0'], ['87.0.4272.0', 'v5.4.0'], ['86.0.4240.0', 'v5.3.0'],