<!DOCTYPE HTML> <html> <head> <title>Test for Bug 545812</title> <script src="/tests/SimpleTest/SimpleTest.js"></script> <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/> <script src="/tests/SimpleTest/EventUtils.js"></script> <script type="application/javascript" src="file_fullscreen-utils.js"></script> <style> body { background-color: black; } </style> </head> <body> <a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=545812">Mozilla Bug 545812</a> <p id="display"></p> <div id="content" style="display: none"> </div> <pre id="test"> <script type="application/javascript"> /** Tests for Bug 545812 **/ SimpleTest.requestFlakyTimeout("untriaged"); // Run the tests which go full-screen in new windows, as mochitests normally // run in an iframe, which by default will not have the allowfullscreen // attribute set, so full-screen won't work. var gTestWindows = [ { test: "file_fullscreen-single.html" }, { test: "file_fullscreen-multiple.html", prefs: [["full-screen-api.exit-on.windowRaise", false], ["full-screen-api.exit-on.windowOpen", false]] }, { test: "file_fullscreen-rollback.html" }, { test: "file_fullscreen-esc-exit.html" }, { test: "file_fullscreen-denied.html" }, { test: "file_fullscreen-api.html" }, { test: "file_fullscreen-hidden.html" }, { test: "file_fullscreen-focus.html" }, { test: "file_fullscreen-svg-element.html" }, { test: "file_fullscreen-navigation.html" }, { test: "file_fullscreen-scrollbar.html" }, { test: "file_fullscreen-selector.html" }, { test: "file_fullscreen-shadowdom.html" }, { test: "file_fullscreen-top-layer.html" }, { test: "file_fullscreen-backdrop.html" }, { test: "file_fullscreen-nested.html" }, { test: "file_fullscreen-prefixed.html" }, { test: "file_fullscreen-lenient-setters.html" }, { test: "file_fullscreen-table.html" }, { test: "file_fullscreen-event-order.html" }, { test: "file_fullscreen-featurePolicy.html", prefs: [["dom.security.featurePolicy.header.enabled", true], ["dom.security.featurePolicy.webidl.enabled", true]] }, { test: "file_fullscreen-async.html" }, { test: "file_fullscreen-sub-iframe.html" }, { test: "file_fullscreen-with-full-zoom.html" }, { test: "file_fullscreen-resize.html" }, ]; var testWindow = null; var gTestIndex = 0; function finish() { SimpleTest.finish(); } function nextTest() { if (testWindow) { info("Waiting for focus to return to main window"); window.addEventListener("focus", function() { info("main window focused, starting next test"); SimpleTest.executeSoon(runNextTest); }, {once: true}); info("testWindow.close()"); testWindow.close(); } else { SimpleTest.executeSoon(runNextTest); } } function waitForEvent(eventTarget, eventName, checkFn, callback) { eventTarget.addEventListener(eventName, function listener(event) { if (checkFn && !checkFn(event)) { return; } eventTarget.removeEventListener(eventName, listener); callback(); }); } function runNextTest() { if (gTestIndex < gTestWindows.length) { let test = gTestWindows[gTestIndex]; let promise = ("prefs" in test) ? SpecialPowers.pushPrefEnv({"set": test.prefs}) : Promise.resolve(); promise.then(function() { info(`Run test ${test.test}`); testWindow = window.open(test.test, "", "width=500,height=500,scrollbars=yes"); // We'll wait for the window to load, then make sure our window is refocused // before starting the test, which will get kicked off on "focus". // This ensures that we're essentially back on the primary "desktop" on // OS X Lion before we run the test. waitForLoadAndPaint(testWindow, function() { SimpleTest.waitForFocus(function() { info("Were focused"); // For the platforms that support reporting occlusion state (e.g. Mac), // we should wait until the docshell has been activated again, // otherwise, the fullscreen request might be denied. if (testWindow.document.hidden) { info("Waiting for document to unhide"); waitForEvent(testWindow.document, "visibilitychange", () => { return !testWindow.document.hidden; }, testWindow.begin); return; } testWindow.begin(); }, testWindow); }); }); gTestIndex++; } else { SimpleTest.finish(); } } try { window.fullScreen = true; } catch (e) { } is(window.fullScreen, false, "Shouldn't be able to set window fullscreen from content"); // Ensure the full-screen api is enabled, and will be disabled on test exit. // Disable the requirement for trusted contexts only, so the tests are easier // to write addLoadEvent(function() { SpecialPowers.pushPrefEnv({ "set": [ ["full-screen-api.enabled", true], ["full-screen-api.allow-trusted-requests-only", false], ["full-screen-api.transition-duration.enter", "0 0"], ["full-screen-api.transition-duration.leave", "0 0"] ]}, nextTest); }); SimpleTest.waitForExplicitFinish(); </script> </pre> </body> </html>