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
|
/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
/* eslint-disable mozilla/no-arbitrary-setTimeout */
// gBrowser.selectedTab.lastAccessed and Date.now() called from this test can't
// run concurrently, and therefore don't always match exactly.
const CURRENT_TIME_TOLERANCE_MS = 15;
function isCurrent(tab, msg) {
const DIFF = Math.abs(Date.now() - tab.lastAccessed);
Assert.lessOrEqual(
DIFF,
CURRENT_TIME_TOLERANCE_MS,
msg + " (difference: " + DIFF + ")"
);
}
function nextStep(fn) {
setTimeout(fn, CURRENT_TIME_TOLERANCE_MS + 10);
}
var originalTab;
var newTab;
function test() {
waitForExplicitFinish();
// This test assumes that time passes between operations. But if the precision
// is low enough, and the test fast enough, an operation, and a successive call
// to Date.now() will have the same time value.
SpecialPowers.pushPrefEnv(
{ set: [["privacy.reduceTimerPrecision", false]] },
function () {
originalTab = gBrowser.selectedTab;
nextStep(step2);
}
);
}
function step2() {
isCurrent(originalTab, "selected tab has the current timestamp");
newTab = BrowserTestUtils.addTab(gBrowser, "about:blank", {
skipAnimation: true,
});
nextStep(step3);
}
function step3() {
Assert.less(
newTab.lastAccessed,
Date.now(),
"new tab hasn't been selected so far"
);
gBrowser.selectedTab = newTab;
isCurrent(newTab, "new tab has the current timestamp after being selected");
nextStep(step4);
}
function step4() {
Assert.less(
originalTab.lastAccessed,
Date.now(),
"original tab has old timestamp after being deselected"
);
isCurrent(
newTab,
"new tab has the current timestamp since it's still selected"
);
gBrowser.removeTab(newTab);
finish();
}
|