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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
/* Tests that use TelemetryTestUtils.assertEvents (at the very least, those with
* `{ process: "content" }`) seem to be super flaky and intermittent-prone when they
* share a file with other telemetry tests, so each one gets its own file.
*/
add_task(async function test_experiment_messaging_system_impressions() {
registerCleanupFunction(() => {
ASRouter.resetMessageState();
});
const LOCALE = Services.locale.appLocaleAsBCP47;
let experimentId = `pb_newtab_${Math.random()}`;
let doExperimentCleanup = await setupMSExperimentWithMessage({
id: experimentId,
template: "pb_newtab",
content: {
hideDefault: true,
promoEnabled: true,
infoEnabled: true,
infoBody: "fluent:about-private-browsing-info-title",
promoLinkText: "fluent:about-private-browsing-prominent-cta",
infoLinkUrl: "http://foo.example.com/%LOCALE%",
promoButton: {
action: {
data: {
args: "https://bar.example.com/%LOCALE%",
where: "tabshifted",
},
type: "OPEN_URL",
},
},
},
frequency: {
lifetime: 2,
},
// Priority ensures this message is picked over the one in
// OnboardingMessageProvider
priority: 5,
targeting: "true",
});
Services.telemetry.clearEvents();
let { win: win1, tab: tab1 } = await openTabAndWaitForRender();
await SpecialPowers.spawn(tab1, [LOCALE], async function (locale) {
is(
content.document
.querySelector(".promo button")
.classList.contains("primary"),
true,
"should render the promo button as a button"
);
});
let event = await waitForTelemetryEvent("normandy", experimentId);
ok(
event[1] == "normandy" &&
event[2] == "expose" &&
event[3] == "nimbus_experiment" &&
event[4].includes(experimentId) &&
event[5].featureId == "pbNewtab",
"recorded telemetry for expose"
);
Services.telemetry.clearEvents();
let { win: win2, tab: tab2 } = await openTabAndWaitForRender();
await SpecialPowers.spawn(tab2, [LOCALE], async function (locale) {
is(
content.document
.querySelector(".promo button")
.classList.contains("primary"),
true,
"should render the promo button as a button"
);
});
let event2 = await waitForTelemetryEvent("normandy", experimentId);
ok(
event2[1] == "normandy" &&
event2[2] == "expose" &&
event2[3] == "nimbus_experiment" &&
event2[4].includes(experimentId) &&
event2[5].featureId == "pbNewtab",
"recorded telemetry for expose"
);
Services.telemetry.clearEvents();
let { win: win3, tab: tab3 } = await openTabAndWaitForRender();
await SpecialPowers.spawn(tab3, [], async function () {
is(
content.document.querySelector(".promo button"),
null,
"should no longer render the experiment message after 2 impressions"
);
});
// Verify that the telemetry events array does not
// contain an expose event for pbNewtab
info("Should not have promo expose");
TelemetryTestUtils.assertEvents([], {
category: "normandy",
method: "expose",
object: "nimbus_experiment",
extra_keys: {
featureId: "pbNewtab",
},
});
Services.telemetry.clearEvents();
await BrowserTestUtils.closeWindow(win1);
await BrowserTestUtils.closeWindow(win2);
await BrowserTestUtils.closeWindow(win3);
await doExperimentCleanup();
});
|