diff options
Diffstat (limited to '')
2 files changed, 57 insertions, 0 deletions
diff --git a/testing/web-platform/tests/idle-detection/idle-detection-disabled-by-permissions-policy.https.sub.html b/testing/web-platform/tests/idle-detection/idle-detection-disabled-by-permissions-policy.https.sub.html new file mode 100644 index 0000000000..90317dece7 --- /dev/null +++ b/testing/web-platform/tests/idle-detection/idle-detection-disabled-by-permissions-policy.https.sub.html @@ -0,0 +1,56 @@ +<!DOCTYPE html> +<body> +<script src=/resources/testharness.js></script> +<script src=/resources/testharnessreport.js></script> +<script src=/permissions-policy/resources/permissions-policy.js></script> +<script> +'use strict'; + +const sub = 'https://{{domains[www]}}:{{ports[https][0]}}'; +const same_origin_src = + '/permissions-policy/resources/permissions-policy-idle-detection.html' +const same_origin_worker_frame_src = + '/permissions-policy/resources/permissions-policy-idle-detection-worker.html'; +const cross_origin_src = sub + same_origin_src; +const cross_origin_worker_frame_src = sub + same_origin_worker_frame_src; + +promise_test(async () => { + try { + let idleDetector = new IdleDetector(); + await idleDetector.start(); + assert_unreached('expected promise to reject with SecurityError'); + } catch (error) { + assert_equals(error.name, 'SecurityError'); + } +}, 'Permissions-Policy idle-detection=() explicitly set by top-level frame ' + + 'disallows query in the top-level document.'); + +async_test(t => { + test_feature_availability('new IdleDetector().start()', t, same_origin_src, + expect_feature_unavailable_default); +}, 'Permissions-Policy idle-detection=() explicitly set by top-level frame ' + + 'disallows same-origin iframes.'); + +async_test(t => { + test_feature_availability('new IdleDetector().start()', t, same_origin_worker_frame_src, + expect_feature_unavailable_default); +}, 'Permissions-Policy idle-detection=() explicitly set by top-level frame ' + + 'disallows workers in same-origin iframes.'); + +async_test(t => { + test_feature_availability('new IdleDetector().start()', t, cross_origin_src, + expect_feature_unavailable_default); +}, 'Permissions-Policy idle-detection=() explicitly set by top-level frame ' + + 'disallows cross-origin iframes.'); + +async_test(t => { + test_feature_availability('new IdleDetector().start()', t, cross_origin_worker_frame_src, + expect_feature_unavailable_default); +}, 'Permissions-Policy idle-detection=() explicitly set by top-level frame ' + + 'disallows workers in cross-origin iframes.'); + +fetch_tests_from_worker(new Worker( + 'resources/idle-detection-disabled-by-permissions-policy-worker.js')) + +</script> +</body> diff --git a/testing/web-platform/tests/idle-detection/idle-detection-disabled-by-permissions-policy.https.sub.html.headers b/testing/web-platform/tests/idle-detection/idle-detection-disabled-by-permissions-policy.https.sub.html.headers new file mode 100644 index 0000000000..289463c30d --- /dev/null +++ b/testing/web-platform/tests/idle-detection/idle-detection-disabled-by-permissions-policy.https.sub.html.headers @@ -0,0 +1 @@ +Permissions-Policy: idle-detection=() |