fune/toolkit/components/glean/tests/browser/browser_labeled_gifft.js
Chris H-C 319a2387c2 Bug 1816454 - Update Glean SDK to v52.3.0 r=TravisLong,supply-chain-reviewers,emilio
Also update some FOG tests that are now incorrect (label limits have been
lifted).

The `default_features = false` on `env_logger` are to avoid a new, duplicate
dependency on hermit-abi.

Differential Revision: https://phabricator.services.mozilla.com/D170816
2023-02-28 16:44:02 +00:00

50 lines
1.4 KiB
JavaScript

/* Any copyright is dedicated to the Public Domain.
* http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
function keyedScalarValue(aScalarName) {
let snapshot = Services.telemetry.getSnapshotForKeyedScalars();
return "parent" in snapshot ? snapshot.parent[aScalarName] : undefined;
}
add_task(async () => {
Assert.equal(
undefined,
Glean.testOnlyIpc.aLabeledCounter.a_label.testGetValue(),
"New labels with no values should return undefined"
);
Glean.testOnlyIpc.aLabeledCounter.a_label.add(1);
Glean.testOnlyIpc.aLabeledCounter.another_label.add(2);
Assert.equal(1, Glean.testOnlyIpc.aLabeledCounter.a_label.testGetValue());
Assert.equal(
2,
Glean.testOnlyIpc.aLabeledCounter.another_label.testGetValue()
);
// What about invalid/__other__?
Assert.equal(
undefined,
Glean.testOnlyIpc.aLabeledCounter.__other__.testGetValue()
);
Glean.testOnlyIpc.aLabeledCounter["1".repeat(72)].add(3);
Assert.throws(
() => Glean.testOnlyIpc.aLabeledCounter.__other__.testGetValue(),
/NS_ERROR_LOSS_OF_SIGNIFICANT_DATA/,
"Can't get the value when you're error'd"
);
let value = keyedScalarValue(
"telemetry.test.another_mirror_for_labeled_counter"
);
Assert.deepEqual(
{
a_label: 1,
another_label: 2,
["1".repeat(72)]: 3,
},
value
);
// AND NOW, FOR THE TRUE TEST:
// Will this leak memory all over the place?
});