fune/browser/components/uitour/test/browser_UITour3.js
Mike de Boer 481ae95c00 Bug 1524593 - nsISearchService (aka nsIBrowserSearchService, previously) refactor to be mostly an asynchronous, in preparation of WebExtension engines. r=daleharvey
This is a rollup of all the patches that have landed on the cedar project branch:

891252fdd0
Bug 1492475 - Part 1: Migrate most, if not all nsSearchService consumers to use async APIs. r=florian

79b2eb2367
Bug 1492475 - Part 2: Move nsIBrowserSearchService.idl to toolkit/components/search/nsISearchService.idl and update references. r=florian

a947d3cdf0
Bug 1492475 - Part 3: The search service init() method should simply return a Promise. r=florian

c1e172dfac
Bug 1492475 - Part 4: Remove the synchronous initialization flow. r=florian

cd41189eac
Bug 1492475 - Part 5: Since async initialization of the search service now is implicit behavior, remove the distinctive verbiage used internally. r=florian

2ae7189dfa
Bug 1492475 - Part 6: Update the cache build task to work with an actual Promise and re-initialize only once at the same time - all to fix race conditions here. r=florian

c8ee92973f
Bug 1492475 - Part 7: Make the region fetch not block the init flow, to ensure it's as fast as possible. r=florian

c44e674e16
Bug 1492475 - Part 8: Introduce an init flag, which can only be used privately, that allows to explicitly skip waiting for the region check process to complete. r=florian

6c79eaf1d3
Bug 1492475 - Part 9: Update unit tests to stop using 'currentEngine', in favor of 'defaultEngine'. r=Standard8

21b3aa17ee
Bug 1492475 - Part 10: Update unit tests to be fully aware of the new, async signatures of the search service API and remove sync init flow tests. r=mkaply,florian

ce5ba69019
Bug 1492475 - Part 11: Repair incorrect usage of the `identifier` property of nsISearchEngine instances. r=florian

fd177a7994
Bug 1518543 - Fix up the Android (Fennec) nsISearchService shim to work with the new asynchronous API. r=florian

3653d8ee22
Bug 1523708 - Change the search service interaction in the show-heartbeat action to use the new async API. r=florian

Differential Revision: https://phabricator.services.mozilla.com/D18355

--HG--
rename : netwerk/base/nsIBrowserSearchService.idl => toolkit/components/search/nsISearchService.idl
extra : moz-landing-system : lando
2019-02-02 11:27:21 +00:00

192 lines
8.2 KiB
JavaScript

"use strict";
ChromeUtils.import("resource://testing-common/CustomizableUITestUtils.jsm", this);
let gCUITestUtils = new CustomizableUITestUtils(window);
var gTestTab;
var gContentAPI;
var gContentWindow;
requestLongerTimeout(2);
add_task(setup_UITourTest);
add_UITour_task(async function test_info_icon() {
let popup = document.getElementById("UITourTooltip");
let title = document.getElementById("UITourTooltipTitle");
let desc = document.getElementById("UITourTooltipDescription");
let icon = document.getElementById("UITourTooltipIcon");
let buttons = document.getElementById("UITourTooltipButtons");
// Disable the animation to prevent the mouse clicks from hitting the main
// window during the transition instead of the buttons in the popup.
popup.setAttribute("animate", "false");
await showInfoPromise("urlbar", "a title", "some text", "image.png");
is(title.textContent, "a title", "Popup should have correct title");
is(desc.textContent, "some text", "Popup should have correct description text");
let imageURL = getRootDirectory(gTestPath) + "image.png";
imageURL = imageURL.replace("chrome://mochitests/content/", "https://example.org/");
is(icon.src, imageURL, "Popup should have correct icon shown");
is(buttons.hasChildNodes(), false, "Popup should have no buttons");
});
add_UITour_task(async function test_info_buttons_1() {
let popup = document.getElementById("UITourTooltip");
let title = document.getElementById("UITourTooltipTitle");
let desc = document.getElementById("UITourTooltipDescription");
let icon = document.getElementById("UITourTooltipIcon");
await showInfoPromise("urlbar", "another title", "moar text", "./image.png", "makeButtons");
is(title.textContent, "another title", "Popup should have correct title");
is(desc.textContent, "moar text", "Popup should have correct description text");
let imageURL = getRootDirectory(gTestPath) + "image.png";
imageURL = imageURL.replace("chrome://mochitests/content/", "https://example.org/");
is(icon.src, imageURL, "Popup should have correct icon shown");
let buttons = document.getElementById("UITourTooltipButtons");
is(buttons.childElementCount, 4, "Popup should have four buttons");
is(buttons.children[0].nodeName, "label", "Text label should be a <label>");
is(buttons.children[0].getAttribute("value"), "Regular text", "Text label should have correct value");
is(buttons.children[0].getAttribute("image"), "", "Text should have no image");
is(buttons.children[0].className, "", "Text should have no class");
is(buttons.children[1].nodeName, "button", "Link should be a <button>");
is(buttons.children[1].getAttribute("label"), "Link", "Link should have correct label");
is(buttons.children[1].getAttribute("image"), "", "Link should have no image");
is(buttons.children[1].className, "button-link", "Check link class");
is(buttons.children[2].nodeName, "button", "Button 1 should be a <button>");
is(buttons.children[2].getAttribute("label"), "Button 1", "First button should have correct label");
is(buttons.children[2].getAttribute("image"), "", "First button should have no image");
is(buttons.children[2].className, "", "Button 1 should have no class");
is(buttons.children[3].nodeName, "button", "Button 2 should be a <button>");
is(buttons.children[3].getAttribute("label"), "Button 2", "Second button should have correct label");
is(buttons.children[3].getAttribute("image"), imageURL, "Second button should have correct image");
is(buttons.children[3].className, "button-primary", "Check button 2 class");
let promiseHidden = promisePanelElementHidden(window, popup);
EventUtils.synthesizeMouseAtCenter(buttons.children[2], {}, window);
await promiseHidden;
ok(true, "Popup should close automatically");
let returnValue = await waitForCallbackResultPromise();
is(returnValue.result, "button1", "Correct callback should have been called");
});
add_UITour_task(async function test_info_buttons_2() {
let popup = document.getElementById("UITourTooltip");
let title = document.getElementById("UITourTooltipTitle");
let desc = document.getElementById("UITourTooltipDescription");
let icon = document.getElementById("UITourTooltipIcon");
await showInfoPromise("urlbar", "another title", "moar text", "./image.png", "makeButtons");
is(title.textContent, "another title", "Popup should have correct title");
is(desc.textContent, "moar text", "Popup should have correct description text");
let imageURL = getRootDirectory(gTestPath) + "image.png";
imageURL = imageURL.replace("chrome://mochitests/content/", "https://example.org/");
is(icon.src, imageURL, "Popup should have correct icon shown");
let buttons = document.getElementById("UITourTooltipButtons");
is(buttons.childElementCount, 4, "Popup should have four buttons");
is(buttons.children[1].getAttribute("label"), "Link", "Link should have correct label");
is(buttons.children[1].getAttribute("image"), "", "Link should have no image");
ok(buttons.children[1].classList.contains("button-link"), "Link should have button-link class");
is(buttons.children[2].getAttribute("label"), "Button 1", "First button should have correct label");
is(buttons.children[2].getAttribute("image"), "", "First button should have no image");
is(buttons.children[3].getAttribute("label"), "Button 2", "Second button should have correct label");
is(buttons.children[3].getAttribute("image"), imageURL, "Second button should have correct image");
let promiseHidden = promisePanelElementHidden(window, popup);
EventUtils.synthesizeMouseAtCenter(buttons.children[3], {}, window);
await promiseHidden;
ok(true, "Popup should close automatically");
let returnValue = await waitForCallbackResultPromise();
is(returnValue.result, "button2", "Correct callback should have been called");
});
add_UITour_task(async function test_info_close_button() {
let closeButton = document.getElementById("UITourTooltipClose");
await showInfoPromise("urlbar", "Close me", "X marks the spot", null, null, "makeInfoOptions");
EventUtils.synthesizeMouseAtCenter(closeButton, {}, window);
let returnValue = await waitForCallbackResultPromise();
is(returnValue.result, "closeButton", "Close button callback called");
});
add_UITour_task(async function test_info_target_callback() {
let popup = document.getElementById("UITourTooltip");
await showInfoPromise("appMenu", "I want to know when the target is clicked", "*click*", null, null, "makeInfoOptions");
await gCUITestUtils.openMainMenu();
let returnValue = await waitForCallbackResultPromise();
is(returnValue.result, "target", "target callback called");
is(returnValue.data.target, "appMenu", "target callback was from the appMenu");
is(returnValue.data.type, "popupshown", "target callback was from the mousedown");
// Cleanup.
await hideInfoPromise();
popup.removeAttribute("animate");
});
add_UITour_task(async function test_getConfiguration_selectedSearchEngine() {
let engine = await Services.search.getDefault();
let data = await getConfigurationPromise("selectedSearchEngine");
is(data.searchEngineIdentifier, engine.identifier, "Correct engine identifier");
});
add_UITour_task(async function test_setSearchTerm() {
// Place the search bar in the navigation toolbar temporarily.
await SpecialPowers.pushPrefEnv({ set: [
["browser.search.widget.inNavBar", true],
]});
const TERM = "UITour Search Term";
await gContentAPI.setSearchTerm(TERM);
let searchbar = document.getElementById("searchbar");
// The UITour gets to the searchbar element through a promise, so the value setting
// only happens after a tick.
await waitForConditionPromise(() => searchbar.value == TERM, "Correct term set");
await SpecialPowers.popPrefEnv();
});
add_UITour_task(async function test_clearSearchTerm() {
// Place the search bar in the navigation toolbar temporarily.
await SpecialPowers.pushPrefEnv({ set: [
["browser.search.widget.inNavBar", true],
]});
await gContentAPI.setSearchTerm("");
let searchbar = document.getElementById("searchbar");
// The UITour gets to the searchbar element through a promise, so the value setting
// only happens after a tick.
await waitForConditionPromise(() => searchbar.value == "", "Search term cleared");
await SpecialPowers.popPrefEnv();
});