73 lines
3.3 KiB
HTML
73 lines
3.3 KiB
HTML
<!doctype html>
|
|
<body>
|
|
<script src=/resources/testharness.js></script>
|
|
<script src=/resources/testharnessreport.js></script>
|
|
<script src=/browsing-topics/resources/header-util.sub.js></script>
|
|
<script src=/browsing-topics/resources/load_img.sub.js></script>
|
|
<script src=/browsing-topics/resources/permissions-policy-util.sub.js></script>
|
|
<script src=/common/utils.js></script>
|
|
<script>
|
|
'use strict';
|
|
const header = 'permissions policy header browsing-topics=()';
|
|
|
|
promise_test(async t => {
|
|
try {
|
|
await document.browsingTopics();
|
|
} catch (e) {
|
|
assert_equals(e.message, TOPICS_PERMISSIONS_POLICY_ERROR_MESSAGE);
|
|
return;
|
|
}
|
|
assert_unreached("did not reject");
|
|
}, header + ' disallows document.browsingTopics() in the current page.');
|
|
|
|
async_test(t => {
|
|
test_topics_feature_availability_in_subframe(t, /*is_same_origin=*/true,
|
|
expect_topics_feature_unavailable);
|
|
}, header + ' disallows document.browsingTopics() in same-origin iframes.');
|
|
|
|
async_test(t => {
|
|
test_topics_feature_availability_in_subframe(t, /*is_same_origin=*/false,
|
|
expect_topics_feature_unavailable);
|
|
}, header + ' disallows document.browsingTopics() in cross-origin iframes.');
|
|
|
|
const same_origin_url = '/browsing-topics/resources/check-topics-request-header.py';
|
|
const cross_origin_url = 'https://{{domains[www]}}:{{ports[https][0]}}' +
|
|
same_origin_url;
|
|
|
|
promise_test(async t => {
|
|
let response = await fetch(same_origin_url, {browsingTopics: true});
|
|
let topics_header = await response.text();
|
|
assert_equals(topics_header, "NO_TOPICS_HEADER");
|
|
}, header + 'disallows the \'Sec-Browsing-Topics\' header to be sent for the same-origin topics fetch request.');
|
|
|
|
promise_test(async t => {
|
|
let response = await fetch(cross_origin_url, {browsingTopics: true});
|
|
let topics_header = await response.text();
|
|
assert_equals(topics_header, "NO_TOPICS_HEADER");
|
|
}, header + 'disallows the \'Sec-Browsing-Topics\' header to be sent for the cross-origin topics fetch request.');
|
|
|
|
promise_test(async t => {
|
|
let topics_header = await load_topics_image(
|
|
/*has_browsing_topics_attribute=*/true, /*is_same_origin=*/true);
|
|
assert_equals(topics_header, "NO_TOPICS_HEADER");
|
|
}, header + 'disallows the \'Sec-Browsing-Topics\' header to be sent for the same-origin topics img request.');
|
|
|
|
promise_test(async t => {
|
|
let topics_header = await load_topics_image(
|
|
/*has_browsing_topics_attribute=*/true, /*is_same_origin=*/false);
|
|
assert_equals(topics_header, "NO_TOPICS_HEADER");
|
|
}, header + 'disallows the \'Sec-Browsing-Topics\' header to be sent for the cross-origin topics img request.');
|
|
|
|
async_test(t => {
|
|
test_topics_iframe_navigation_header(
|
|
t, /*has_browsing_topics_attribute=*/true, /*is_same_origin=*/true,
|
|
expect_topics_header_unavailable);
|
|
}, header + ' disallows the \'Sec-Browsing-Topics\' header to be sent for the same-origin iframe navigation request.');
|
|
|
|
async_test(t => {
|
|
test_topics_iframe_navigation_header(
|
|
t, /*has_browsing_topics_attribute=*/true, /*is_same_origin=*/false,
|
|
expect_topics_header_unavailable);
|
|
}, header + ' disallows the \'Sec-Browsing-Topics\' header to be sent for the cross-origin iframe navigation request.');
|
|
</script>
|
|
</body>
|