local-fonts-disabled-by-permissions-policy.https.sub.html (1444B)
1 <!DOCTYPE html> 2 <meta name="timeout" content="long"> <!-- this is a long-running test at least on some platforms ! --> 3 <body> 4 <script src=/font-access/resources/font-test-utils.js></script> 5 <script src=/resources/testharness.js></script> 6 <script src=/resources/testharnessreport.js></script> 7 <script src=/resources/testdriver.js></script> 8 <script src=/resources/testdriver-vendor.js></script> 9 <script src=/permissions-policy/resources/permissions-policy.js></script> 10 <script> 11 'use strict'; 12 const same_origin_src = '/permissions-policy/resources/permissions-policy-local-fonts.html'; 13 const cross_origin_src = 'https://{{domains[www]}}:{{ports[https][0]}}' + 14 same_origin_src; 15 const header = 'permissions policy header: "local-fonts=()"'; 16 17 font_access_test(async t => { 18 await promise_rejects_dom(t, 'SecurityError', self.queryLocalFonts(), 19 'queryLocalFonts() throws security error when disallowed by ' + 20 'permission policy'); 21 }, header + ' disallows the top-level document.'); 22 23 async_test(t => { 24 test_feature_availability('local-fonts', t, same_origin_src, 25 expect_feature_unavailable_default); 26 }, header + ' disallows same-origin iframes.'); 27 28 async_test(t => { 29 test_feature_availability('local-fonts', t, cross_origin_src, 30 expect_feature_unavailable_default); 31 }, header + ' disallows cross-origin iframes.'); 32 </script> 33 </body>