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
|
var tab1, tab2;
function focus_in_navbar() {
var parent = document.activeElement.parentNode;
while (parent && parent.id != "nav-bar") {
parent = parent.parentNode;
}
return parent != null;
}
function test() {
waitForExplicitFinish();
tab1 = BrowserTestUtils.addTab(gBrowser, "about:blank", {
skipAnimation: true,
});
tab2 = BrowserTestUtils.addTab(gBrowser, "about:blank", {
skipAnimation: true,
});
EventUtils.synthesizeMouseAtCenter(tab1, {});
setTimeout(step2, 0);
}
function step2() {
is(gBrowser.selectedTab, tab1, "1st click on tab1 selects tab");
isnot(
document.activeElement,
tab1,
"1st click on tab1 does not activate tab"
);
EventUtils.synthesizeMouseAtCenter(tab1, {});
setTimeout(step3, 0);
}
function step3() {
is(
gBrowser.selectedTab,
tab1,
"2nd click on selected tab1 keeps tab selected"
);
isnot(
document.activeElement,
tab1,
"2nd click on selected tab1 does not activate tab"
);
ok(true, "focusing URLBar then sending 2 Shift+Tab.");
gURLBar.focus();
EventUtils.synthesizeKey("VK_TAB", { shiftKey: true });
info(`Focus is now on Home button (#${document.activeElement.id})`);
EventUtils.synthesizeKey("VK_TAB", { shiftKey: true });
is(gBrowser.selectedTab, tab1, "tab key to selected tab1 keeps tab selected");
is(document.activeElement, tab1, "tab key to selected tab1 activates tab");
EventUtils.synthesizeMouseAtCenter(tab1, {});
setTimeout(step4, 0);
}
function step4() {
is(
gBrowser.selectedTab,
tab1,
"3rd click on activated tab1 keeps tab selected"
);
is(
document.activeElement,
tab1,
"3rd click on activated tab1 keeps tab activated"
);
gBrowser.addEventListener("TabSwitchDone", step5);
EventUtils.synthesizeMouseAtCenter(tab2, {});
}
function step5() {
gBrowser.removeEventListener("TabSwitchDone", step5);
// The tabbox selects a tab within a setTimeout in a bubbling mousedown event
// listener, and focuses the current tab if another tab previously had focus.
is(
gBrowser.selectedTab,
tab2,
"click on tab2 while tab1 is activated selects tab"
);
is(
document.activeElement,
tab2,
"click on tab2 while tab1 is activated activates tab"
);
info("focusing content then sending middle-button mousedown to tab2.");
gBrowser.selectedBrowser.focus();
EventUtils.synthesizeMouseAtCenter(tab2, { button: 1, type: "mousedown" });
setTimeout(step6, 0);
}
function step6() {
is(
gBrowser.selectedTab,
tab2,
"middle-button mousedown on selected tab2 keeps tab selected"
);
isnot(
document.activeElement,
tab2,
"middle-button mousedown on selected tab2 does not activate tab"
);
gBrowser.removeTab(tab2);
gBrowser.removeTab(tab1);
finish();
}
|