From 3ecd98d63476e79b594d41d60e436e982c038968 Mon Sep 17 00:00:00 2001 From: Christian Davis Date: Sat, 7 Oct 2017 12:27:38 -0500 Subject: [PATCH] fix(Page.select): synthesized events should bubble This patch fixes `Page.select` to synthesize bubbling events. --- lib/Page.js | 5 ++--- test/assets/input/select.html | 14 ++++++++++++++ test/test.js | 7 +++++++ 3 files changed, 23 insertions(+), 3 deletions(-) diff --git a/lib/Page.js b/lib/Page.js index 0f079a9f..f2b3ffdb 100644 --- a/lib/Page.js +++ b/lib/Page.js @@ -732,9 +732,8 @@ class Page extends EventEmitter { } else { element.value = values.shift(); } - - element.dispatchEvent(new Event('change')); - element.dispatchEvent(new Event('input')); + element.dispatchEvent(new Event('input', { 'bubbles': true })); + element.dispatchEvent(new Event('change', { 'bubbles': true })); }, values); } diff --git a/test/assets/input/select.html b/test/assets/input/select.html index 44a80b46..879a537a 100644 --- a/test/assets/input/select.html +++ b/test/assets/input/select.html @@ -25,6 +25,8 @@ window.result = { onInput: null, onChange: null, + onBubblingChange: null, + onBubblingInput: null, }; let select = document.querySelector('select'); @@ -50,6 +52,18 @@ return option.value; }); }, false); + + document.body.addEventListener('input', () => { + result.onBubblingInput = Array.from(select.querySelectorAll('option:checked')).map((option) => { + return option.value; + }); + }, false); + + document.body.addEventListener('change', () => { + result.onBubblingChange = Array.from(select.querySelectorAll('option:checked')).map((option) => { + return option.value; + }); + }, false); diff --git a/test/test.js b/test/test.js index fd992e84..93235d69 100644 --- a/test/test.js +++ b/test/test.js @@ -2244,6 +2244,13 @@ describe('Page', function() { expect(await page.evaluate(() => result.onChange)).toEqual(['blue', 'green', 'red']); })); + it('should respect event bubbling', SX(async function() { + await page.goto(PREFIX + '/input/select.html'); + await page.select('select', 'blue'); + expect(await page.evaluate(() => result.onBubblingInput)).toEqual(['blue']); + expect(await page.evaluate(() => result.onBubblingChange)).toEqual(['blue']); + })); + it('should work with no options', SX(async function() { await page.goto(PREFIX + '/input/select.html'); await page.evaluate(() => makeEmpty());