1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
/* Any copyright is dedicated to the Public Domain.
* http://creativecommons.org/publicdomain/zero/1.0/ */
/*
* Test of a search engine's telemetryId.
*/
"use strict";
add_setup(async function () {
await SearchTestUtils.useTestEngines("simple-engines");
await AddonTestUtils.promiseStartupManager();
const result = await Services.search.init();
Assert.ok(
Components.isSuccessCode(result),
"Should have initialized the service"
);
useHttpServer();
await SearchTestUtils.promiseNewSearchEngine({
url: `${gDataUrl}engine.xml`,
});
});
function checkIdentifier(engineName, expectedIdentifier, expectedTelemetryId) {
const engine = Services.search.getEngineByName(engineName);
Assert.ok(
engine instanceof Ci.nsISearchEngine,
"Should be derived from nsISearchEngine"
);
Assert.equal(
engine.telemetryId,
expectedTelemetryId,
"Should have the correct telemetry Id"
);
// TODO: Bug 1877721 - We have 3 forms of identifiers which causes confusion,
// we can remove the identifier for nsISearchEngine.
Assert.equal(
engine.identifier,
expectedIdentifier,
"Should have the correct identifier"
);
}
add_task(async function test_from_profile() {
// An engine loaded from the profile directory won't have an identifier,
// because it's not built-in.
checkIdentifier(kTestEngineName, null, `other-${kTestEngineName}`);
});
add_task(async function test_from_telemetry_id() {
checkIdentifier("basic", "basic-telemetry", "basic-telemetry");
});
add_task(async function test_from_webextension_id() {
// If not specified, the telemetry Id is derived from the WebExtension prefix,
// it should not use the WebExtension display name.
checkIdentifier("Simple Engine", "simple", "simple");
});
|