diff options
Diffstat (limited to 'testing/web-platform/tests/geolocation-API/enabled-on-self-origin-by-permissions-policy.https.sub.html')
-rw-r--r-- | testing/web-platform/tests/geolocation-API/enabled-on-self-origin-by-permissions-policy.https.sub.html | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/testing/web-platform/tests/geolocation-API/enabled-on-self-origin-by-permissions-policy.https.sub.html b/testing/web-platform/tests/geolocation-API/enabled-on-self-origin-by-permissions-policy.https.sub.html new file mode 100644 index 0000000000..d879c1c543 --- /dev/null +++ b/testing/web-platform/tests/geolocation-API/enabled-on-self-origin-by-permissions-policy.https.sub.html @@ -0,0 +1,42 @@ +<!DOCTYPE html> +<body> + <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 src="/permissions-policy/resources/permissions-policy.js"></script> + + <script> + "use strict"; + + const same_origin_src = + "/permissions-policy/resources/permissions-policy-geolocation.html"; + const cross_origin_src = + "https://{{hosts[][]}}:{{ports[https][0]}}" + same_origin_src; + + promise_test(async (t) => { + await test_driver.set_permission({ name: "geolocation" }, "granted"); + await new Promise((resolve, reject) => { + navigator.geolocation.getCurrentPosition(resolve, reject); + }); + }, "Permissions-Policy header geolocation=(self) allows the top-level document."); + + async_test((t) => { + test_feature_availability( + "geolocation", + t, + same_origin_src, + expect_feature_available_default + ); + }, "Permissions-Policy header geolocation=(self) allows same-origin iframes."); + + async_test((t) => { + test_feature_availability( + "geolocation", + t, + cross_origin_src, + expect_feature_unavailable_default + ); + }, "Permissions-Policy header geolocation=(self) disallows cross-origin iframes."); + </script> +</body> |