1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
<!DOCTYPE html>
<html>
<head>
<script src='/resources/testharness.js'></script>
<script src='/resources/testharnessreport.js'></script>
<script src='../resources/permissions-policy-report-json.js'></script>
</head>
<body>
<script>
var t = async_test("PaymentRequest Report Format");
var check_report_format = (reports, observer) => {
let report = reports[0];
assert_equals(report.type, "permissions-policy-violation");
assert_equals(report.url, document.location.href);
assert_equals(report.body.featureId, "payment");
assert_equals(report.body.sourceFile, document.location.href);
assert_equals(typeof report.body.lineNumber, "number");
assert_equals(typeof report.body.columnNumber, "number");
assert_equals(report.body.disposition, "enforce");
check_report_json(report);
};
new ReportingObserver(t.step_func_done(check_report_format),
{types: ['permissions-policy-violation']}).observe();
t.step_func(() => {
assert_throws_dom('SecurityError',
() => new PaymentRequest(
[{ supportedMethods: 'https://example.com/pay' }],
{ total: { label: 'Total', amount: { currency: 'USD', value: 0 }}},
{}).show(),
"PaymentRequest API should not be allowed in this document.");
})();
</script>
</body>
</html>
|