gecko-dev/dom/tests/browser/browser_focus_steal_from_chrome.js

152 lines
6.7 KiB
JavaScript

add_task(async function() {
requestLongerTimeout(2);
let testingList = [
{ uri: "data:text/html,<body onload=\"setTimeout(function () { document.getElementById('target').focus(); }, 10);\"><input id='target'></body>",
tagName: "INPUT", methodName: "focus" },
{ uri: "data:text/html,<body onload=\"setTimeout(function () { document.getElementById('target').select(); }, 10);\"><input id='target'></body>",
tagName: "INPUT", methodName: "select" },
{ uri: "data:text/html,<body onload=\"setTimeout(function () { document.getElementById('target').focus(); }, 10);\"><a href='about:blank' id='target'>anchor</a></body>",
tagName: "A", methodName: "focus" },
{ uri: "data:text/html,<body onload=\"setTimeout(function () { document.getElementById('target').focus(); }, 10);\"><button id='target'>button</button></body>",
tagName: "BUTTON", methodName: "focus" },
{ uri: "data:text/html,<body onload=\"setTimeout(function () { document.getElementById('target').focus(); }, 10);\"><select id='target'><option>item1</option></select></body>",
tagName: "SELECT", methodName: "focus" },
{ uri: "data:text/html,<body onload=\"setTimeout(function () { document.getElementById('target').focus(); }, 10);\"><textarea id='target'>textarea</textarea></body>",
tagName: "TEXTAREA", methodName: "focus" },
{ uri: "data:text/html,<body onload=\"setTimeout(function () { document.getElementById('target').select(); }, 10);\"><textarea id='target'>textarea</textarea></body>",
tagName: "TEXTAREA", methodName: "select" },
{ uri: "data:text/html,<body onload=\"setTimeout(function () { document.getElementById('target').focus(); }, 10);\"><label id='target'><input></label></body>",
tagName: "INPUT", methodName: "focus of label element" },
{ uri: "data:text/html,<body onload=\"setTimeout(function () { document.getElementById('target').focus(); }, 10);\"><fieldset><legend id='target'>legend</legend><input></fieldset></body>",
tagName: "INPUT", methodName: "focus of legend element" },
{ uri: "data:text/html,<body onload=\"setTimeout(function () {" +
" var element = document.getElementById('target');" +
" var event = document.createEvent('MouseEvent');" +
" event.initMouseEvent('click', true, true, window," +
" 1, 0, 0, 0, 0, false, false, false, false, 0, element);" +
" element.dispatchEvent(event); }, 10);\">" +
"<label id='target'><input></label></body>",
tagName: "INPUT", methodName: "click event on the label element" },
];
await BrowserTestUtils.withNewTab("about:blank", async function(bg) {
await BrowserTestUtils.withNewTab("about:blank", async function(fg) {
for (let test of testingList) {
// Focus the foreground tab's content
fg.focus();
// Load the URIs.
await BrowserTestUtils.loadURI(bg, test.uri);
await BrowserTestUtils.browserLoaded(bg);
await BrowserTestUtils.loadURI(fg, test.uri);
await BrowserTestUtils.browserLoaded(fg);
ok(true, "Test1: Both of the tabs are loaded");
// Confirm that the contents should be able to steal focus from content.
await ContentTask.spawn(fg, test, test => {
return new Promise(res => {
function f() {
let e = content.document.activeElement;
if (e.tagName != test.tagName) {
setTimeout(f, 10);
} else {
is(Services.focus.focusedElement, e,
"the foreground tab's " + test.tagName +
" element isn't focused by the " + test.methodName +
" (Test1: content can steal focus)");
res();
}
}
f();
});
});
await ContentTask.spawn(bg, test, test => {
return new Promise(res => {
function f() {
let e = content.document.activeElement;
if (e.tagName != test.tagName) {
setTimeout(f, 10);
} else {
isnot(Services.focus.focusedElement, e,
"the background tab's " + test.tagName +
" element is focused by the " + test.methodName +
" (Test1: content can steal focus)");
res();
}
}
f();
});
});
if (fg.isRemoteBrowser) {
is(Services.focus.focusedElement, fg,
"Focus should be on the content in the parent process");
}
// Focus chrome
document.getElementById("urlbar").focus();
let originalFocus = Services.focus.focusedElement;
// Load about:blank just to make sure that everything works nicely
await BrowserTestUtils.loadURI(bg, "about:blank");
await BrowserTestUtils.browserLoaded(bg);
await BrowserTestUtils.loadURI(fg, "about:blank");
await BrowserTestUtils.browserLoaded(fg);
// Load the URIs.
await BrowserTestUtils.loadURI(bg, test.uri);
await BrowserTestUtils.browserLoaded(bg);
await BrowserTestUtils.loadURI(fg, test.uri);
await BrowserTestUtils.browserLoaded(fg);
ok(true, "Test2: Both of the tabs are loaded");
// Confirm that the contents should be able to steal focus from content.
await ContentTask.spawn(fg, test, test => {
return new Promise(res => {
function f() {
let e = content.document.activeElement;
if (e.tagName != test.tagName) {
setTimeout(f, 10);
} else {
isnot(Services.focus.focusedElement, e,
"the foreground tab's " + test.tagName +
" element is focused by the " + test.methodName +
" (Test2: content can NOT steal focus)");
res();
}
}
f();
});
});
await ContentTask.spawn(bg, test, test => {
return new Promise(res => {
function f() {
let e = content.document.activeElement;
if (e.tagName != test.tagName) {
setTimeout(f, 10);
} else {
isnot(Services.focus.focusedElement, e,
"the background tab's " + test.tagName +
" element is focused by the " + test.methodName +
" (Test2: content can NOT steal focus)");
res();
}
}
f();
});
});
is(Services.focus.focusedElement, originalFocus,
"The parent process's focus has shifted " +
"(methodName = " + test.methodName + ")" +
" (Test2: content can NOT steal focus)");
}
});
});
});