summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/fenced-frame/permission-geolocation.https.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /testing/web-platform/tests/fenced-frame/permission-geolocation.https.html
parentInitial commit. (diff)
downloadfirefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz
firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/fenced-frame/permission-geolocation.https.html')
-rw-r--r--testing/web-platform/tests/fenced-frame/permission-geolocation.https.html73
1 files changed, 73 insertions, 0 deletions
diff --git a/testing/web-platform/tests/fenced-frame/permission-geolocation.https.html b/testing/web-platform/tests/fenced-frame/permission-geolocation.https.html
new file mode 100644
index 0000000000..98b5a72b3c
--- /dev/null
+++ b/testing/web-platform/tests/fenced-frame/permission-geolocation.https.html
@@ -0,0 +1,73 @@
+<!DOCTYPE html>
+<title>Test permission of geolocation</title>
+<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="resources/utils.js"></script>
+<script src="/common/utils.js"></script>
+
+<body>
+
+<script>
+
+async function runTest(policy_header_in_primary_page,
+ policy_header_in_fenced_frame_page,
+ allow_attribute_iframe_in_fanced_frame) {
+ const permission_geolocation_key = token();
+ const pipe_for_policy = 'pipe=header(Permissions-Policy,geolocation=self)';
+ const test_runner_url =
+ 'resources/permission-geolocation-test-runner.html?' +
+ (policy_header_in_primary_page ? pipe_for_policy : '');
+ let fenced_frame_url_params = [];
+ if (policy_header_in_fenced_frame_page) {
+ fenced_frame_url_params.push(pipe_for_policy);
+ }
+ if (allow_attribute_iframe_in_fanced_frame) {
+ fenced_frame_url_params.push('load_allow_attribute_iframe=true');
+ }
+ const fenced_frame_url = 'permission-geolocation-inner.html?' +
+ fenced_frame_url_params.join('&');
+
+ const win = window.open(generateURL(test_runner_url,
+ [permission_geolocation_key]));
+ await new Promise(resolve => {
+ win.onload = resolve;
+ });
+
+ const unloadPromise = new Promise(resolve => {
+ win.onunload = resolve;
+ });
+
+ await win.runTest(fenced_frame_url);
+ win.close();
+ await unloadPromise;
+}
+
+promise_test(async t => {
+ await runTest(false, false, false);
+}, 'geolocation permission is not permitted for fenced frames');
+
+promise_test(async t => {
+ await runTest(true, false, false);
+}, 'geolocation permission is not permitted for fenced frames, even if a ' +
+ '`Permissions-Policy` header is sent on the primary page.');
+
+promise_test(async t => {
+ await runTest(false, true, false);
+}, 'geolocation permission is not permitted for fenced frames, even if a ' +
+ '`Permissions-Policy` header is sent on the fenced frame response.');
+
+promise_test(async t => {
+ await runTest(false, false, true);
+}, 'geolocation permission is not permitted for fenced frames, even if an ' +
+ '`allow` attribute is set for an iframe in the fenced frame.');
+
+promise_test(async t => {
+ await runTest(false, true, true);
+}, 'geolocation permission is not permitted for fenced frames, even if a ' +
+ '`Permissions-Policy` header and an `allow` attribute is set for an iframe' +
+ ' in the fenced frame.');
+</script>
+
+</body>