element-request-fullscreen-without-user-activation.tentative.https.html (1446B)
1 <!doctype html> 2 <meta charset=utf-8> 3 <title>Element#requestFullscreen() without user activation</title> 4 <link rel="help" href="https://github.com/explainers-by-googlers/html-fullscreen-without-a-gesture"> 5 <script src="/resources/testharness.js"></script> 6 <script src="/resources/testharnessreport.js"></script> 7 <script src="/resources/testdriver.js"></script> 8 <script src="/resources/testdriver-vendor.js"></script> 9 <div id="log"></div> 10 <script> 11 promise_test(async (test) => { 12 const div = document.querySelector("div"); 13 assert_false(navigator.userActivation.isActive, "userActivation.isActive"); 14 await promise_rejects_js(test, TypeError, div.requestFullscreen()); 15 }, `Element#requestFullscreen() rejects without user activation by default`); 16 17 promise_test(async (test) => { 18 test.add_cleanup(() => { 19 if (document.fullscreenElement) return document.exitFullscreen(); 20 }); 21 const descriptor = { name: "fullscreen", allowWithoutGesture: true }; 22 await test_driver.set_permission(descriptor, "granted"); 23 const status = await navigator.permissions.query(descriptor); 24 assert_equals((status).state, "granted", `state should be "granted", as set`); 25 26 const div = document.querySelector("div"); 27 assert_false(navigator.userActivation.isActive, "userActivation.isActive"); 28 await div.requestFullscreen(); 29 }, `Element#requestFullscreen() resolves without user activation with permission`); 30 </script>