Source code
Revision control
Copy as Markdown
Other Tools
Test Info: Warnings
- This test gets skipped with pattern: os == 'win' && socketprocess_networking && fission
- Manifest: toolkit/components/extensions/test/xpcshell/xpcshell-remote.toml includes toolkit/components/extensions/test/xpcshell/xpcshell-common.toml
- Manifest: toolkit/components/extensions/test/xpcshell/xpcshell.toml includes toolkit/components/extensions/test/xpcshell/xpcshell-common.toml
/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */
/* vim: set sts=2 sw=2 et tw=80: */
"use strict";
add_task(async function test_telemetry() {
const { GleanTimingDistribution } = globalThis;
let extension1 = ExtensionTestUtils.loadExtension({
background() {
browser.test.sendMessage("loaded");
},
});
let extension2 = ExtensionTestUtils.loadExtension({
background() {
browser.test.sendMessage("loaded");
},
});
Services.fog.testResetFOG();
assertGleanMetricsNoSamples({
metricId: "backgroundPageLoad",
gleanMetric: Glean.extensionsTiming.backgroundPageLoad,
gleanMetricConstructor: GleanTimingDistribution,
});
assertGleanLabeledMetricEmpty({
metricId: "backgroundPageLoadByAddonid",
gleanMetric: Glean.extensionsTiming.backgroundPageLoadByAddonid,
gleanMetricLabels: [],
});
await extension1.startup();
await extension1.awaitMessage("loaded");
assertGleanMetricsSamplesCount({
metricId: "backgroundPageLoad",
gleanMetric: Glean.extensionsTiming.backgroundPageLoad,
gleanMetricConstructor: GleanTimingDistribution,
expectedSamplesCount: 1,
});
const allAddonsBackgroundPageLoadSum =
Glean.extensionsTiming.backgroundPageLoad.testGetValue()?.sum;
const ext1BackgroundPageLoadSum =
Glean.extensionsTiming.backgroundPageLoadByAddonid.testGetValue()?.[
extension1.id
]?.sum;
Assert.greater(
allAddonsBackgroundPageLoadSum,
0,
`Expect stored values in the backgroundPageLoad Glean metric`
);
Assert.greater(
ext1BackgroundPageLoadSum,
0,
`Expect stored values in the backgroundPageLoadByAddonid Glean metric for extension1`
);
await extension2.startup();
await extension2.awaitMessage("loaded");
assertGleanMetricsSamplesCount({
metricId: "backgroundPageLoad",
gleanMetric: Glean.extensionsTiming.backgroundPageLoad,
gleanMetricConstructor: GleanTimingDistribution,
expectedSamplesCount: 2,
});
Assert.greater(
Glean.extensionsTiming.backgroundPageLoad.testGetValue()?.sum,
allAddonsBackgroundPageLoadSum,
`Expect backgroundPageLoad sum to increae after extension2 is started`
);
Assert.equal(
Glean.extensionsTiming.backgroundPageLoadByAddonid.testGetValue()?.[
extension1.id
]?.sum,
ext1BackgroundPageLoadSum,
`Expect backgroundPageLoadByAddonid Glean for extension1 to not change after extension2 startup`
);
Assert.greater(
Glean.extensionsTiming.backgroundPageLoadByAddonid.testGetValue()?.[
extension2.id
]?.sum,
0,
`Expect stored values in the backgroundPageLoadByAddonid Glean metric for extension2`
);
await extension1.unload();
await extension2.unload();
});