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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
"use strict";
async function installFile(filename) {
const ChromeRegistry = Cc["@mozilla.org/chrome/chrome-registry;1"].getService(
Ci.nsIChromeRegistry
);
let chromeUrl = Services.io.newURI(gTestPath);
let fileUrl = ChromeRegistry.convertChromeURL(chromeUrl);
let file = fileUrl.QueryInterface(Ci.nsIFileURL).file;
file.leafName = filename;
let MockFilePicker = SpecialPowers.MockFilePicker;
MockFilePicker.init(window);
MockFilePicker.setFiles([file]);
MockFilePicker.afterOpenCallback = MockFilePicker.cleanup;
let { document } = await BrowserOpenAddonsMgr("addons://list/extension");
// Do the install...
await waitAboutAddonsViewLoaded(document);
let installButton = document.querySelector('[action="install-from-file"]');
installButton.click();
}
add_task(async function test_install_extension_from_local_file() {
// Clear any telemetry data that might be from a separate test.
Services.telemetry.clearEvents();
// Listen for the first installId so we can check it later.
let firstInstallId = null;
AddonManager.addInstallListener({
onNewInstall(install) {
firstInstallId = install.installId;
AddonManager.removeInstallListener(this);
},
});
// Install the add-ons.
await testInstallMethod(installFile, "installLocal");
// Check we got an installId.
ok(
firstInstallId != null && !isNaN(firstInstallId),
"There was an installId found"
);
// Check the telemetry.
let snapshot = Services.telemetry.snapshotEvents(
Ci.nsITelemetry.DATASET_PRERELEASE_CHANNELS,
true
);
// Make sure we got some data.
ok(
snapshot.parent && !!snapshot.parent.length,
"Got parent telemetry events in the snapshot"
);
// Only look at the related events after stripping the timestamp and category.
let relatedEvents = snapshot.parent
.filter(
([timestamp, category, method, object]) =>
category == "addonsManager" &&
method == "action" &&
object == "aboutAddons"
)
.map(relatedEvent => relatedEvent.slice(4, 6));
// testInstallMethod installs the extension three times.
Assert.deepEqual(
relatedEvents,
[
[firstInstallId.toString(), { action: "installFromFile", view: "list" }],
[
(++firstInstallId).toString(),
{ action: "installFromFile", view: "list" },
],
[
(++firstInstallId).toString(),
{ action: "installFromFile", view: "list" },
],
],
"The telemetry is recorded correctly"
);
});
|