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
|
var expected = [
"TabOpen",
"onStateChange",
"onLocationChange",
"onLinkIconAvailable",
];
var actual = [];
var tabIndex = -1;
this.__defineGetter__("tab", () => gBrowser.tabs[tabIndex]);
function test() {
waitForExplicitFinish();
tabIndex = gBrowser.tabs.length;
gBrowser.addTabsProgressListener(progressListener);
gBrowser.tabContainer.addEventListener("TabOpen", TabOpen);
BrowserTestUtils.addTab(
gBrowser,
"data:text/html,<html><head><link href='about:logo' rel='shortcut icon'>"
);
}
function recordEvent(aName) {
info("got " + aName);
if (!actual.includes(aName)) {
actual.push(aName);
}
if (actual.length == expected.length) {
is(
actual.toString(),
expected.toString(),
"got events and progress notifications in expected order"
);
executeSoon(
// eslint-disable-next-line no-shadow
function (tab) {
gBrowser.removeTab(tab);
gBrowser.removeTabsProgressListener(progressListener);
gBrowser.tabContainer.removeEventListener("TabOpen", TabOpen);
finish();
}.bind(null, tab)
);
}
}
function TabOpen(aEvent) {
if (aEvent.target == tab) {
recordEvent("TabOpen");
}
}
var progressListener = {
onLocationChange: function onLocationChange(aBrowser) {
if (aBrowser == tab.linkedBrowser) {
recordEvent("onLocationChange");
}
},
onStateChange: function onStateChange(aBrowser) {
if (aBrowser == tab.linkedBrowser) {
recordEvent("onStateChange");
}
},
onLinkIconAvailable: function onLinkIconAvailable(aBrowser) {
if (aBrowser == tab.linkedBrowser) {
recordEvent("onLinkIconAvailable");
}
},
};
|