fune/dom/html/test/browser_fullscreen-newtab.js
Kris Maglione 96f3e16d1a Bug 1482091: Part 2 - Remove TelemetryStopwatch.jsm in favor of native implementation. r=chutten
Differential Revision: https://phabricator.services.mozilla.com/D9888

--HG--
extra : rebase_source : a9daea3a9efea37acdbcaecda8bf0b7f69631de4
extra : histedit_source : bb8b416b1387da9de3bd95c7a171f10426a22602
2018-10-25 19:04:01 -07:00

86 lines
3 KiB
JavaScript

"use strict";
// This test tends to trigger a race in the fullscreen time telemetry,
// where the fullscreen enter and fullscreen exit events (which use the
// same histogram ID) overlap. That causes TelemetryStopwatch to log an
// error.
SimpleTest.ignoreAllUncaughtExceptions(true);
const kPage = "http://example.org/browser/" +
"dom/html/test/file_fullscreen-newtab.html";
function getSizeMode() {
return document.documentElement.getAttribute("sizemode");
}
async function runTest() {
await BrowserTestUtils.withNewTab({
gBrowser,
url: kPage
}, async function (browser) {
await ContentTask.spawn(browser, null, function() {
content.document.addEventListener("fullscreenchange", () => {
sendAsyncMessage("Test:FullscreenChange");
});
content.document.addEventListener("fullscreenerror", () => {
sendAsyncMessage("Test:FullscreenError");
});
});
let promiseFsEvents = new Promise(resolve => {
let countFsChange = 0;
let countFsError = 0;
function checkAndResolve() {
if (countFsChange > 0 && countFsError > 0) {
ok(false, "Got both fullscreenchange and fullscreenerror events");
} else if (countFsChange > 2) {
ok(false, "Got too many fullscreenchange events");
} else if (countFsError > 1) {
ok(false, "Got too many fullscreenerror events");
} else if (countFsChange == 2 || countFsError == 1) {
resolve();
}
}
let mm = browser.messageManager;
mm.addMessageListener("Test:FullscreenChange", () => {
info("Got fullscreenchange event");
++countFsChange;
checkAndResolve();
});
mm.addMessageListener("Test:FullscreenError", () => {
info("Got fullscreenerror event");
++countFsError;
checkAndResolve();
});
});
let promiseNewTab =
BrowserTestUtils.waitForNewTab(gBrowser, "about:blank");
await BrowserTestUtils.synthesizeMouseAtCenter("#link", {}, browser);
let [newtab] = await Promise.all([promiseNewTab, promiseFsEvents]);
await BrowserTestUtils.removeTab(newtab);
// Ensure the browser exits fullscreen state in reasonable time.
await Promise.race([
BrowserTestUtils.waitForCondition(() => getSizeMode() == "normal"),
new Promise(resolve => setTimeout(resolve, 2000))
]);
ok(!window.fullScreen, "The chrome window should not be in fullscreen");
ok(!document.fullscreen, "The chrome document should not be in fullscreen");
});
}
add_task(async function () {
await pushPrefs(
["full-screen-api.unprefix.enabled", true],
["full-screen-api.transition-duration.enter", "0 0"],
["full-screen-api.transition-duration.leave", "0 0"]);
await runTest();
});
add_task(async function () {
await pushPrefs(
["full-screen-api.unprefix.enabled", true],
["full-screen-api.transition-duration.enter", "200 200"],
["full-screen-api.transition-duration.leave", "200 200"]);
await runTest();
});