Source code

Revision control

Copy as Markdown

Other Tools

Test Info: Warnings

/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */
/* vim: set sts=2 sw=2 et tw=80: */
"use strict";
function waitForReflow(aWindow) {
return new Promise(resolve => {
aWindow.requestAnimationFrame(() => {
aWindow.requestAnimationFrame(resolve);
});
});
}
add_task(async function fullscreen_size() {
let win = await BrowserTestUtils.openNewBrowserWindow({});
win.gBrowser.selectedBrowser.focus();
info("Enter browser fullscreen mode");
let promise = Promise.all([
BrowserTestUtils.waitForEvent(win, "fullscreen"),
BrowserTestUtils.waitForEvent(win, "resize"),
]);
win.fullScreen = true;
await promise;
info("Await reflow of the chrome window");
await waitForReflow(win);
is(win.innerHeight, win.outerHeight, "Check height");
is(win.innerWidth, win.outerWidth, "Check width");
await BrowserTestUtils.closeWindow(win);
});
add_task(async function fullscreen_size_moz_appearance() {
const win = await BrowserTestUtils.openNewBrowserWindow({});
win.gBrowser.selectedBrowser.focus();
info("Add -moz-appearance style to chrome document");
const style = win.document.createElement("style");
style.innerHTML = `
#main-window {
-moz-appearance: button;
}
`;
win.document.head.appendChild(style);
info("Await reflow of the chrome window");
await waitForReflow(win);
info("Enter browser fullscreen mode");
let promise = Promise.all([
BrowserTestUtils.waitForEvent(win, "fullscreen"),
BrowserTestUtils.waitForEvent(win, "resize"),
]);
win.fullScreen = true;
await promise;
info("Await reflow of the chrome window");
await waitForReflow(win);
is(win.innerHeight, win.outerHeight, "Check height");
is(win.innerWidth, win.outerWidth, `Check width`);
await BrowserTestUtils.closeWindow(win);
});