From 6887ad881ae75ed19656fb8462a966c3ca28ea58 Mon Sep 17 00:00:00 2001 From: Andrey Lushnikov Date: Wed, 6 Feb 2019 13:49:14 -0800 Subject: [PATCH] chore: further unify Puppeteer-Firefox tests with Puppeteer (#3931) This patch: * unifies assets between tests * enables a few puppeteer tests on Puppeteer-Firefox Drive-by: beautify failing output of `expect.toEqual` matcher. References #3889 --- test/assets/frames/nested-frames.html | 4 ++-- test/assets/frames/two-frames.html | 4 ++-- test/assets/input/keyboard.html | 2 +- test/assets/title.html | 1 + test/assets/wrappedlink.html | 3 +++ test/evaluation.spec.js | 17 ++++------------- test/frame.spec.js | 10 ++++++++-- test/golden-chromium/nested-frames.txt | 5 ----- .../golden-chromium/reconnect-nested-frames.txt | 5 ----- test/keyboard.spec.js | 12 ++++++------ test/launcher.spec.js | 8 +++++++- test/page.spec.js | 4 ++-- test/utils.js | 9 ++++++--- utils/testrunner/Matchers.js | 2 +- 14 files changed, 43 insertions(+), 43 deletions(-) create mode 100644 test/assets/title.html delete mode 100644 test/golden-chromium/nested-frames.txt delete mode 100644 test/golden-chromium/reconnect-nested-frames.txt diff --git a/test/assets/frames/nested-frames.html b/test/assets/frames/nested-frames.html index cb14fe6b..de198758 100644 --- a/test/assets/frames/nested-frames.html +++ b/test/assets/frames/nested-frames.html @@ -21,5 +21,5 @@ async function attachFrame(frameId, url) { return 'kazakh'; } - - + + diff --git a/test/assets/frames/two-frames.html b/test/assets/frames/two-frames.html index 46a50f3f..b2ee853e 100644 --- a/test/assets/frames/two-frames.html +++ b/test/assets/frames/two-frames.html @@ -9,5 +9,5 @@ body iframe { flex-shrink: 1; } - - + + diff --git a/test/assets/input/keyboard.html b/test/assets/input/keyboard.html index 00df1034..9f1d4815 100644 --- a/test/assets/input/keyboard.html +++ b/test/assets/input/keyboard.html @@ -13,7 +13,7 @@ log('Keydown:', event.key, event.code, event.which, modifiers(event)); }); textarea.addEventListener('keypress', event => { - log('Keypress:', event.key, event.code, event.which, event.keyCode, event.charCode, modifiers(event)); + log('Keypress:', event.key, event.code, event.which, event.charCode, modifiers(event)); }); textarea.addEventListener('keyup', event => { log('Keyup:', event.key, event.code, event.which, modifiers(event)); diff --git a/test/assets/title.html b/test/assets/title.html new file mode 100644 index 00000000..88a86ce4 --- /dev/null +++ b/test/assets/title.html @@ -0,0 +1 @@ +Woof-Woof diff --git a/test/assets/wrappedlink.html b/test/assets/wrappedlink.html index 55e9c3f9..429b6e91 100644 --- a/test/assets/wrappedlink.html +++ b/test/assets/wrappedlink.html @@ -26,4 +26,7 @@ a { 123321 diff --git a/test/evaluation.spec.js b/test/evaluation.spec.js index 1df01409..bc1d912f 100644 --- a/test/evaluation.spec.js +++ b/test/evaluation.spec.js @@ -158,9 +158,8 @@ module.exports.addTests = function({testRunner, expect}) { it('should properly serialize null fields', async({page}) => { expect(await page.evaluate(() => ({a: undefined}))).toEqual({}); }); - it_fails_ffox('should return undefined for non-serializable objects', async({page, server}) => { + it('should return undefined for non-serializable objects', async({page, server}) => { expect(await page.evaluate(() => window)).toBe(undefined); - expect(await page.evaluate(() => [Symbol('foo4')])).toBe(undefined); }); it('should fail for circular object', async({page, server}) => { const result = await page.evaluate(() => { @@ -206,17 +205,9 @@ module.exports.addTests = function({testRunner, expect}) { expect(error).toBeTruthy(); expect(error.message).toContain('JSHandles can be evaluated only in the context they were created'); }); - it_fails_ffox('should simulate a user gesture', async({page, server}) => { - await page.evaluate(playAudio); - // also test evaluating strings - await page.evaluate(`(${playAudio})()`); - - function playAudio() { - const audio = document.createElement('audio'); - audio.src = 'data:audio/wav;base64,UklGRiQAAABXQVZFZm10IBAAAAABAAEARKwAAIhYAQACABAAZGF0YQAAAAA='; - // This returns a promise which throws if it was not triggered by a user gesture. - return audio.play(); - } + it('should simulate a user gesture', async({page, server}) => { + const result = await page.evaluate(() => document.execCommand('copy')); + expect(result).toBe(true); }); it_fails_ffox('should throw a nice error after a navigation', async({page, server}) => { const executionContext = await page.mainFrame().executionContext(); diff --git a/test/frame.spec.js b/test/frame.spec.js index 2ed0c19c..043469ab 100644 --- a/test/frame.spec.js +++ b/test/frame.spec.js @@ -68,9 +68,15 @@ module.exports.addTests = function({testRunner, expect}) { }); describe('Frame Management', function() { - it_fails_ffox('should handle nested frames', async({page, server}) => { + it('should handle nested frames', async({page, server}) => { await page.goto(server.PREFIX + '/frames/nested-frames.html'); - expect(utils.dumpFrames(page.mainFrame())).toBeGolden('nested-frames.txt'); + expect(utils.dumpFrames(page.mainFrame())).toEqual([ + 'http://localhost:/frames/nested-frames.html', + ' http://localhost:/frames/two-frames.html (2frames)', + ' http://localhost:/frames/frame.html (uno)', + ' http://localhost:/frames/frame.html (dos)', + ' http://localhost:/frames/frame.html (aframe)' + ]); }); it('should send events when frames are manipulated dynamically', async({page, server}) => { await page.goto(server.EMPTY_PAGE); diff --git a/test/golden-chromium/nested-frames.txt b/test/golden-chromium/nested-frames.txt deleted file mode 100644 index e6270080..00000000 --- a/test/golden-chromium/nested-frames.txt +++ /dev/null @@ -1,5 +0,0 @@ -http://localhost:/frames/nested-frames.html - http://localhost:/frames/two-frames.html - http://localhost:/frames/frame.html - http://localhost:/frames/frame.html - http://localhost:/frames/frame.html \ No newline at end of file diff --git a/test/golden-chromium/reconnect-nested-frames.txt b/test/golden-chromium/reconnect-nested-frames.txt deleted file mode 100644 index e6270080..00000000 --- a/test/golden-chromium/reconnect-nested-frames.txt +++ /dev/null @@ -1,5 +0,0 @@ -http://localhost:/frames/nested-frames.html - http://localhost:/frames/two-frames.html - http://localhost:/frames/frame.html - http://localhost:/frames/frame.html - http://localhost:/frames/frame.html \ No newline at end of file diff --git a/test/keyboard.spec.js b/test/keyboard.spec.js index 1b13abf7..04b41434 100644 --- a/test/keyboard.spec.js +++ b/test/keyboard.spec.js @@ -85,7 +85,7 @@ module.exports.addTests = function({testRunner, expect, FFOX}) { await keyboard.down('!'); // Shift+! will generate a keypress if (modifierKey === 'Shift') - expect(await page.evaluate(() => getResult())).toBe('Keydown: ! Digit1 49 [' + modifierKey + ']\nKeypress: ! Digit1 33 33 33 [' + modifierKey + ']'); + expect(await page.evaluate(() => getResult())).toBe('Keydown: ! Digit1 49 [' + modifierKey + ']\nKeypress: ! Digit1 33 33 [' + modifierKey + ']'); else expect(await page.evaluate(() => getResult())).toBe('Keydown: ! Digit1 49 [' + modifierKey + ']'); @@ -111,20 +111,20 @@ module.exports.addTests = function({testRunner, expect, FFOX}) { await keyboard.up('Meta'); expect(await page.evaluate(() => getResult())).toBe('Keyup: Meta MetaLeft 91 []'); }); - it_fails_ffox('should send proper codes while typing', async({page, server}) => { + it('should send proper codes while typing', async({page, server}) => { await page.goto(server.PREFIX + '/input/keyboard.html'); await page.keyboard.type('!'); expect(await page.evaluate(() => getResult())).toBe( [ 'Keydown: ! Digit1 49 []', - 'Keypress: ! Digit1 33 33 33 []', + 'Keypress: ! Digit1 33 33 []', 'Keyup: ! Digit1 49 []'].join('\n')); await page.keyboard.type('^'); expect(await page.evaluate(() => getResult())).toBe( [ 'Keydown: ^ Digit6 54 []', - 'Keypress: ^ Digit6 94 94 94 []', + 'Keypress: ^ Digit6 94 94 []', 'Keyup: ^ Digit6 54 []'].join('\n')); }); - it_fails_ffox('should send proper codes while typing with shift', async({page, server}) => { + it('should send proper codes while typing with shift', async({page, server}) => { await page.goto(server.PREFIX + '/input/keyboard.html'); const keyboard = page.keyboard; await keyboard.down('Shift'); @@ -132,7 +132,7 @@ module.exports.addTests = function({testRunner, expect, FFOX}) { expect(await page.evaluate(() => getResult())).toBe( [ 'Keydown: Shift ShiftLeft 16 [Shift]', 'Keydown: ~ Backquote 192 [Shift]', // 192 is ` keyCode - 'Keypress: ~ Backquote 126 126 126 [Shift]', // 126 is ~ charCode + 'Keypress: ~ Backquote 126 126 [Shift]', // 126 is ~ charCode 'Keyup: ~ Backquote 192 [Shift]'].join('\n')); await keyboard.up('Shift'); }); diff --git a/test/launcher.spec.js b/test/launcher.spec.js index 06da1444..4553dc6b 100644 --- a/test/launcher.spec.js +++ b/test/launcher.spec.js @@ -339,7 +339,13 @@ module.exports.addTests = function({testRunner, expect, defaultBrowserOptions, p const browser = await puppeteer.connect({browserWSEndpoint}); const pages = await browser.pages(); const restoredPage = pages.find(page => page.url() === server.PREFIX + '/frames/nested-frames.html'); - expect(utils.dumpFrames(restoredPage.mainFrame())).toBeGolden('reconnect-nested-frames.txt'); + expect(utils.dumpFrames(restoredPage.mainFrame())).toEqual([ + 'http://localhost:/frames/nested-frames.html', + ' http://localhost:/frames/two-frames.html (2frames)', + ' http://localhost:/frames/frame.html (uno)', + ' http://localhost:/frames/frame.html (dos)', + ' http://localhost:/frames/frame.html (aframe)', + ]); expect(await restoredPage.evaluate(() => 7 * 8)).toBe(56); await browser.close(); }); diff --git a/test/page.spec.js b/test/page.spec.js index 82c1a4a4..f454ad18 100644 --- a/test/page.spec.js +++ b/test/page.spec.js @@ -940,8 +940,8 @@ module.exports.addTests = function({testRunner, expect, headless, Errors, Device describe('Page.title', function() { it('should return the page title', async({page, server}) => { - await page.goto(server.PREFIX + '/input/button.html'); - expect(await page.title()).toBe('Button test'); + await page.goto(server.PREFIX + '/title.html'); + expect(await page.title()).toBe('Woof-Woof'); }); }); diff --git a/test/utils.js b/test/utils.js index debe12cd..041a930c 100644 --- a/test/utils.js +++ b/test/utils.js @@ -128,13 +128,16 @@ const utils = module.exports = { /** * @param {!Frame} frame * @param {string=} indentation - * @return {string} + * @return {Array} */ dumpFrames: function(frame, indentation) { indentation = indentation || ''; - let result = indentation + frame.url().replace(/:\d{4}\//, ':/'); + let description = frame.url().replace(/:\d{4}\//, ':/'); + if (frame.name()) + description += ' (' + frame.name() + ')'; + const result = [indentation + description]; for (const child of frame.childFrames()) - result += '\n' + utils.dumpFrames(child, ' ' + indentation); + result.push(...utils.dumpFrames(child, ' ' + indentation)); return result; }, diff --git a/utils/testrunner/Matchers.js b/utils/testrunner/Matchers.js index a7d208c2..03e21f9d 100644 --- a/utils/testrunner/Matchers.js +++ b/utils/testrunner/Matchers.js @@ -126,5 +126,5 @@ function stringify(value) { return result; } - return JSON.stringify(stabilize(null, value), stabilize); + return JSON.stringify(stabilize(null, value), stabilize, 2); }