| <!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'; |
| var relative_path = '/permissions-policy/resources/permissions-policy-payment.html'; |
| var base_src = '/permissions-policy/resources/redirect-on-load.html#'; |
| var same_origin_src = base_src + relative_path; |
| var cross_origin_src = base_src + 'https://{{domains[www]}}:{{ports[https][0]}}' + |
| relative_path; |
| var header = 'permissions policy allow="payment"'; |
| |
| async_test(t => { |
| test_feature_availability( |
| 'PaymentRequest()', t, same_origin_src, |
| expect_feature_available_default, 'payment'); |
| }, header + ' allows same-origin navigation in an iframe.'); |
| |
| async_test(t => { |
| test_feature_availability( |
| 'PaymentRequest()', t, cross_origin_src, |
| expect_feature_unavailable_default, 'payment'); |
| }, header + ' disallows cross-origin navigation in an iframe.'); |
| |
| async_test(t => { |
| test_feature_availability( |
| 'PaymentRequest()', t, same_origin_src, |
| expect_feature_available_default, 'payment', 'allowpaymentrequest'); |
| }, header + ' allowpaymentrequest=true allows same-origin navigation in an iframe.'); |
| |
| async_test(t => { |
| test_feature_availability( |
| 'PaymentRequest()', t, cross_origin_src, |
| expect_feature_unavailable_default, 'payment', 'allowpaymentrequest'); |
| }, header + ' allowpaymentrequest=true disallows cross-origin navigation in an iframe.'); |
| </script> |
| </body> |