From 0d913ed477da2620ea42cfb3c63f286011d11dc4 Mon Sep 17 00:00:00 2001 From: Alessio Placitelli Date: Fri, 26 Mar 2021 08:36:04 +0100 Subject: [PATCH] Add a simple test for the Rally id in Glean --- tests/core-addon/unit/Core.test.js | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/tests/core-addon/unit/Core.test.js b/tests/core-addon/unit/Core.test.js index 8d88d512..c2efc046 100644 --- a/tests/core-addon/unit/Core.test.js +++ b/tests/core-addon/unit/Core.test.js @@ -6,7 +6,11 @@ import { strict as assert } from 'assert'; // eslint-disable-next-line node/no-extraneous-import import sinon from 'sinon'; +import Glean from "@mozilla/glean/webext"; + import Core from '../../../core-addon/Core.js'; +import * as rallyMetrics from "../../../public/generated/rally.js"; + // The website to post deletion IDs to. const OFFBOARD_URL = "https://production.rally.mozilla.org/offboard"; @@ -27,7 +31,11 @@ const FAKE_UUID = "c0ffeec0-ffee-c0ff-eec0-ffeec0ffeec0"; const FAKE_WEBSITE = "https://test.website"; describe('Core', function () { - beforeEach(function () { + const testAppId = `core.test.${this.title}`; + + beforeEach(async function() { + await Glean.testResetGlean(testAppId); + // Force the sinon-chrome stubbed API to resolve its promise // in tests. Without the next two lines, tests querying the // `browser.management.getAll` API will be stuck and timeout. @@ -203,6 +211,8 @@ describe('Core', function () { {type: "enrollment", data: {}} ); + assert.equal(await rallyMetrics.id.testGetValue(), FAKE_UUID); + // We expect to store the fake ion ID. assert.ok(this.core._storage.setRallyID.withArgs(FAKE_UUID).calledOnce); assert.ok(this.core._dataCollection.sendEnrollmentPing.calledOnce);