/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ "use strict"; registerCleanupFunction(teardown); add_task(async function testVoiceselectDropdownAutoclose() { setup(); await spawnInNewReaderTab(TEST_ARTICLE, async function () { let $ = content.document.querySelector.bind(content.document); await NarrateTestUtils.waitForNarrateToggle(content); $(NarrateTestUtils.TOGGLE).click(); ok( NarrateTestUtils.isVisible($(NarrateTestUtils.POPUP)), "popup is toggled" ); ok( !NarrateTestUtils.isVisible($(NarrateTestUtils.VOICE_OPTIONS)), "voice options are initially hidden" ); $(NarrateTestUtils.VOICE_SELECT).click(); ok( NarrateTestUtils.isVisible($(NarrateTestUtils.VOICE_OPTIONS)), "voice options are toggled" ); $(NarrateTestUtils.TOGGLE).click(); // A focus will follow a real click. $(NarrateTestUtils.TOGGLE).focus(); ok( !NarrateTestUtils.isVisible($(NarrateTestUtils.POPUP)), "narrate popup is dismissed" ); $(NarrateTestUtils.TOGGLE).click(); // A focus will follow a real click. $(NarrateTestUtils.TOGGLE).focus(); ok( NarrateTestUtils.isVisible($(NarrateTestUtils.POPUP)), "narrate popup is showing again" ); ok( !NarrateTestUtils.isVisible($(NarrateTestUtils.VOICE_OPTIONS)), "voice options are hidden after popup comes back" ); }); }); add_task(async function testVoiceselectLabelChange() { setup(); await spawnInNewReaderTab(TEST_ARTICLE, async function () { let $ = content.document.querySelector.bind(content.document); await NarrateTestUtils.waitForNarrateToggle(content); $(NarrateTestUtils.TOGGLE).click(); ok( NarrateTestUtils.isVisible($(NarrateTestUtils.POPUP)), "popup is toggled" ); ok( NarrateTestUtils.selectVoice(content, "urn:moz-tts:fake:lenny"), "voice selected" ); let selectedOption = $(NarrateTestUtils.VOICE_SELECTED); let selectLabel = $(NarrateTestUtils.VOICE_SELECT_LABEL); is( selectedOption.textContent, selectLabel.textContent, "new label matches selected voice" ); }); }); add_task(async function testVoiceselectKeyboard() { setup(); await spawnInNewReaderTab(TEST_ARTICLE, async function () { let $ = content.document.querySelector.bind(content.document); await NarrateTestUtils.waitForNarrateToggle(content); $(NarrateTestUtils.TOGGLE).click(); ok( NarrateTestUtils.isVisible($(NarrateTestUtils.POPUP)), "popup is toggled" ); let eventUtils = NarrateTestUtils.getEventUtils(content); let firstValue = $(NarrateTestUtils.VOICE_SELECTED).dataset.value; ok( !NarrateTestUtils.isVisible($(NarrateTestUtils.VOICE_OPTIONS)), "voice options initially are hidden" ); $(NarrateTestUtils.VOICE_SELECT).focus(); eventUtils.synthesizeKey("KEY_ArrowDown", {}, content); await ContentTaskUtils.waitForCondition( () => $(NarrateTestUtils.VOICE_SELECTED).dataset.value != firstValue, "value changed after pressing ArrowDown key" ); eventUtils.synthesizeKey("KEY_Enter", {}, content); ok( NarrateTestUtils.isVisible($(NarrateTestUtils.VOICE_OPTIONS)), "voice options showing after pressing Enter" ); eventUtils.synthesizeKey("KEY_ArrowUp", {}, content); eventUtils.synthesizeKey("KEY_Enter", {}, content); ok( !NarrateTestUtils.isVisible($(NarrateTestUtils.VOICE_OPTIONS)), "voice options hidden after pressing Enter" ); await ContentTaskUtils.waitForCondition( () => $(NarrateTestUtils.VOICE_SELECTED).dataset.value == firstValue, "value changed back to original after pressing Enter" ); }); });