diff --git a/tests/helpers/browser-detect.js b/tests/helpers/browser-detect.js index a8e28d55e..986cd0d2e 100644 --- a/tests/helpers/browser-detect.js +++ b/tests/helpers/browser-detect.js @@ -5,3 +5,6 @@ export const isIE11 = !window.ActiveXObject && 'ActiveXObject' in window; export const isIE = 'ActiveXObject' in window; export const isEdge = navigator.userAgent.indexOf('Edge') >= 0; + +// Unlike Chrome, Firefox emits `selectionchange` events. +export const isFirefox = navigator.userAgent.indexOf('Firefox') >= 0; diff --git a/tests/unit/dom/fill-in-test.js b/tests/unit/dom/fill-in-test.js index fba2b887c..d25a69556 100644 --- a/tests/unit/dom/fill-in-test.js +++ b/tests/unit/dom/fill-in-test.js @@ -6,13 +6,15 @@ import { _registerHook, } from '@ember/test-helpers'; import { buildInstrumentedElement, insertElement } from '../../helpers/events'; -import { isIE11 } from '../../helpers/browser-detect'; +import { isIE11, isFirefox } from '../../helpers/browser-detect'; import hasEmberVersion from '@ember/test-helpers/has-ember-version'; let clickSteps = ['focus', 'focusin', 'input', 'change']; if (isIE11) { clickSteps = ['focusin', 'input', 'change', 'focus']; +} else if (isFirefox) { + clickSteps.push('selectionchange'); } module('DOM Helper: fillIn', function (hooks) { @@ -226,7 +228,8 @@ module('DOM Helper: fillIn', function (hooks) { await setupContext(context); await fillIn(element, 'foo'); - assert.verifySteps(clickSteps); + // For this specific case, Firefox does not emit `selectionchange`. + assert.verifySteps(clickSteps.filter((s) => s !== 'selectionchange')); assert.strictEqual( document.activeElement, element, @@ -255,7 +258,8 @@ module('DOM Helper: fillIn', function (hooks) { await setupContext(context); await fillIn(`#${element.id}`, ''); - assert.verifySteps(clickSteps); + // For this specific case, Firefox does not emit `selectionchange`. + assert.verifySteps(clickSteps.filter((s) => s !== 'selectionchange')); assert.strictEqual( document.activeElement, element, diff --git a/tests/unit/dom/type-in-test.js b/tests/unit/dom/type-in-test.js index 14d6556be..776135c81 100644 --- a/tests/unit/dom/type-in-test.js +++ b/tests/unit/dom/type-in-test.js @@ -6,7 +6,7 @@ import { _registerHook, } from '@ember/test-helpers'; import { buildInstrumentedElement, insertElement } from '../../helpers/events'; -import { isIE11 } from '../../helpers/browser-detect'; +import { isIE11, isFirefox } from '../../helpers/browser-detect'; import { debounce } from '@ember/runloop'; import { Promise } from 'rsvp'; import hasEmberVersion from '@ember/test-helpers/has-ember-version'; @@ -49,6 +49,27 @@ if (isIE11) { 'change', 'focus', ]; +} else if (isFirefox) { + expectedEvents = [ + 'focus', + 'focusin', + 'keydown', + 'keypress', + 'input', + 'keyup', + 'selectionchange', + 'keydown', + 'keypress', + 'input', + 'keyup', + 'selectionchange', + 'keydown', + 'keypress', + 'input', + 'keyup', + 'change', + 'selectionchange', + ]; } module('DOM Helper: typeIn', function (hooks) { @@ -164,7 +185,9 @@ module('DOM Helper: typeIn', function (hooks) { element.setAttribute('contenteditable', 'true'); await typeIn(element, 'foo'); - assert.verifySteps(expectedEvents); + // For this specific case, Firefox does not emit `selectionchange`. + assert.verifySteps(expectedEvents.filter((s) => s !== 'selectionchange')); + assert.strictEqual( document.activeElement, element, @@ -302,7 +325,7 @@ module('DOM Helper: typeIn', function (hooks) { await assert.rejects( typeIn(element, tooLongString).finally(() => { // should throw before the second input event (or second keyup for IE) - const expectedNumberOfSteps = isIE11 ? 6 : 8; + const expectedNumberOfSteps = isIE11 ? 6 : isFirefox ? 9 : 8; assert.verifySteps(expectedEvents.slice(0, expectedNumberOfSteps)); }), new Error("Can not `typeIn` with text: 'fo' that exceeds maxlength: '1'.") @@ -355,7 +378,7 @@ module('DOM Helper: typeIn', function (hooks) { await assert.rejects( typeIn(element, tooLongString).finally(() => { // should throw before the second input event (or second keyup for IE) - const expectedNumberOfSteps = isIE11 ? 6 : 8; + const expectedNumberOfSteps = isIE11 ? 6 : isFirefox ? 9 : 8; assert.verifySteps(expectedEvents.slice(0, expectedNumberOfSteps)); }), new Error("Can not `typeIn` with text: 'fo' that exceeds maxlength: '1'.")