Source code

Revision control

Copy as Markdown

Other Tools

Test Info: Warnings

/* Any copyright is dedicated to the Public Domain.
"use strict";
const CONFIG = [
{
// Just a basic engine that won't be changed.
webExtension: {
id: "engine@search.mozilla.org",
name: "Test search engine",
params: [
{
name: "q",
value: "{searchTerms}",
},
{
name: "channel",
condition: "purpose",
purpose: "contextmenu",
value: "rcs",
},
{
name: "channel",
condition: "purpose",
purpose: "keyword",
value: "fflb",
},
],
suggest_url:
},
appliesTo: [
{
included: { everywhere: true },
default: "yes",
},
],
},
{
// This engine will have the locale swapped when the experiment is set.
webExtension: {
id: "engine-same-name@search.mozilla.org",
default_locale: "en",
searchProvider: {
en: {
name: "engine-same-name",
},
gd: {
name: "engine-same-name",
},
},
},
appliesTo: [
{
included: { everywhere: true },
webExtension: {
locales: ["en"],
},
},
{
included: { everywhere: true },
webExtension: {
locales: ["gd"],
},
experiment: "xpcshell",
},
],
},
];
const CONFIG_V2 = [
{
recordType: "engine",
identifier: "engine",
base: {
name: "Test search engine",
urls: {
search: {
params: [
{
name: "channel",
searchAccessPoint: {
addressbar: "fflb",
contextmenu: "rcs",
},
},
],
searchTermParamName: "q",
},
},
},
variants: [
{
environment: { allRegionsAndLocales: true },
},
],
},
{
recordType: "engine",
identifier: "engine-same-name-en",
base: {
name: "engine-same-name",
urls: {
search: {
searchTermParamName: "q",
},
},
},
variants: [
{
environment: { allRegionsAndLocales: true },
},
],
},
{
recordType: "engine",
identifier: "engine-same-name-gd",
base: {
name: "engine-same-name",
urls: {
search: {
searchTermParamName: "q",
},
},
},
variants: [
{
environment: { allRegionsAndLocales: true, experiment: "xpcshell" },
},
],
},
{
recordType: "defaultEngines",
globalDefault: "engine",
specificDefaults: [],
},
{
recordType: "engineOrders",
orders: [],
},
];
add_setup(async function () {
await SearchTestUtils.useTestEngines(
"data",
null,
SearchUtils.newSearchConfigEnabled ? CONFIG_V2 : CONFIG
);
await AddonTestUtils.promiseStartupManager();
});
// This is to verify that the loaded configuration matches what we expect for
// the test.
add_task(async function test_initial_config_correct() {
await Services.search.init();
const installedEngines = await Services.search.getAppProvidedEngines();
Assert.deepEqual(
installedEngines.map(e => e.identifier),
["engine", "engine-same-name-en"],
"Should have the correct list of engines installed."
);
Assert.equal(
(await Services.search.getDefault()).identifier,
"engine",
"Should have loaded the expected default engine"
);
});
add_task(async function test_config_updated_engine_changes() {
// Update the config.
const reloadObserved =
SearchTestUtils.promiseSearchNotification("engines-reloaded");
const enginesAdded = [];
const enginesModified = [];
const enginesRemoved = [];
function enginesObs(subject, topic, data) {
if (data == SearchUtils.MODIFIED_TYPE.ADDED) {
enginesAdded.push(subject.QueryInterface(Ci.nsISearchEngine).identifier);
} else if (data == SearchUtils.MODIFIED_TYPE.CHANGED) {
enginesModified.push(
subject.QueryInterface(Ci.nsISearchEngine).identifier
);
} else if (data == SearchUtils.MODIFIED_TYPE.REMOVED) {
enginesRemoved.push(subject.QueryInterface(Ci.nsISearchEngine).name);
}
}
Services.obs.addObserver(enginesObs, SearchUtils.TOPIC_ENGINE_MODIFIED);
Services.prefs.setCharPref(
SearchUtils.BROWSER_SEARCH_PREF + "experiment",
"xpcshell"
);
await reloadObserved;
Services.obs.removeObserver(enginesObs, SearchUtils.TOPIC_ENGINE_MODIFIED);
if (SearchUtils.newSearchConfigEnabled) {
// In the new config, engine-same-name-en and engine-same-name-gd are two
// different engine configs and they will be treated as different engines
// and not the same. That's the reason why the assertions are different below.
Assert.deepEqual(
enginesAdded,
["engine-same-name-gd"],
"Should have added the correct engines"
);
Assert.deepEqual(
enginesModified.sort(),
["engine", "engine-same-name-en"],
"Should have modified the expected engines"
);
Assert.deepEqual(
enginesRemoved,
["engine-same-name"],
"Should have removed the expected engine"
);
} else {
Assert.deepEqual(enginesAdded, [], "Should have added the correct engines");
Assert.deepEqual(
enginesModified.sort(),
["engine", "engine-same-name-gd"],
"Should have modified the expected engines"
);
Assert.deepEqual(
enginesRemoved,
[],
"Should have removed the expected engine"
);
}
const installedEngines = await Services.search.getAppProvidedEngines();
Assert.deepEqual(
installedEngines.map(e => e.identifier),
["engine", "engine-same-name-gd"],
"Should have the correct list of engines installed in the expected order."
);
const engineWithSameName = await Services.search.getEngineByName(
"engine-same-name"
);
Assert.equal(
engineWithSameName.getSubmission("test").uri.spec,
"Should have correctly switched to the engine of the same name"
);
Assert.equal(
Services.search.wrappedJSObject._settings.getMetaDataAttribute(
"useSavedOrder"
),
false,
"Should not have set the useSavedOrder preference"
);
});