| <!DOCTYPE html> |
| <meta charset="utf-8" /> |
| <meta viewport="width=device-width, initial-scale=1" /> |
| <script src="/resources/testharness.js"></script> |
| <script src="/resources/testharnessreport.js"></script> |
| <script src="/resources/testdriver.js"></script> |
| <script src="/resources/testdriver-vendor.js"></script> |
| <script type="module"> |
| import { attachIframe, makeCleanup, getOppositeOrientation } from "./resources/orientation-utils.js"; |
| |
| promise_test(async t => { |
| t.add_cleanup(makeCleanup()); |
| await test_driver.bless("request full screen") |
| await document.documentElement.requestFullscreen(); |
| const value = await screen.orientation.lock('any'); |
| assert_equals(value, undefined); |
| }, "Test that screen.orientation.lock returns a promise which will be fulfilled with a void value."); |
| |
| promise_test(async t => { |
| t.add_cleanup(makeCleanup()); |
| await test_driver.bless("request full screen") |
| await document.documentElement.requestFullscreen(); |
| const initialOrientation = screen.orientation.type; |
| const orientations = [ |
| 'any', |
| 'natural', |
| 'portrait', |
| 'landscape', |
| 'portrait-secondary', |
| 'landscape-primary', |
| 'landscape-secondary', |
| 'portrait-primary', |
| ]; |
| for (const orientation of orientations) { |
| try { |
| await screen.orientation.lock(orientation); |
| } catch(err) { |
| if (err.name === "NotSupportedError") { |
| continue; |
| } |
| assert_unreached("Unknown error: " + err); |
| } |
| const { type } = screen.orientation; |
| switch (orientation) { |
| case 'any': |
| break; |
| case 'natural': |
| assert_true(type.endsWith("primary"), `Expected primary orientation for "${orientation}", got "${type}"`); |
| break; |
| case 'portrait': |
| assert_true(type.startsWith("portrait"), `Expected portrait orientation for "${orientation}", got "${type}"`); |
| break; |
| case 'landscape': |
| assert_true(type.startsWith("landscape"), `Expected landscape orientation for "${orientation}", got "${type}"`); |
| break; |
| default: |
| assert_equals(type, orientation, "Expected orientation to change"); |
| break; |
| } |
| await screen.orientation.lock(initialOrientation); |
| } |
| }, "Test that screen.orientation.lock returns a pending promise."); |
| |
| promise_test(async t => { |
| t.add_cleanup(makeCleanup()); |
| await test_driver.bless("request full screen") |
| await document.documentElement.requestFullscreen(); |
| const initialType = screen.orientation.type; |
| const newType = getOppositeOrientation(); |
| const p = screen.orientation.lock(newType); |
| assert_equals(screen.orientation.type, initialType, "Must not change orientation until next spin of event loop"); |
| await p; |
| const finalType = screen.orientation.type; |
| assert_true(finalType.startsWith(newType), `Expected type to start with ${newType}, got "${finalType}"`); |
| }, "Test that screen.orientation.lock() is actually async"); |
| </script> |