diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /testing/web-platform/tests/payment-request/PaymentRequestUpdateEvent | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/payment-request/PaymentRequestUpdateEvent')
3 files changed, 126 insertions, 0 deletions
diff --git a/testing/web-platform/tests/payment-request/PaymentRequestUpdateEvent/constructor.http.html b/testing/web-platform/tests/payment-request/PaymentRequestUpdateEvent/constructor.http.html new file mode 100644 index 0000000000..db7765f7bf --- /dev/null +++ b/testing/web-platform/tests/payment-request/PaymentRequestUpdateEvent/constructor.http.html @@ -0,0 +1,12 @@ +<!DOCTYPE html> +<!-- Copyright © 2017 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). --> +<meta charset="utf-8"> +<title>Test for PaymentRequestUpdateEvent Constructor (insecure)</title> +<link rel="help" href="https://w3c.github.io/browser-payment-api/#paymentrequestupdateevent-interface"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script> +test(() => { + assert_false("PaymentRequestUpdateEvent" in Window); +}, "PaymentRequestUpdateEvent constructor must not be exposed in insecure context"); +</script> diff --git a/testing/web-platform/tests/payment-request/PaymentRequestUpdateEvent/constructor.https.html b/testing/web-platform/tests/payment-request/PaymentRequestUpdateEvent/constructor.https.html new file mode 100644 index 0000000000..3de0469e9c --- /dev/null +++ b/testing/web-platform/tests/payment-request/PaymentRequestUpdateEvent/constructor.https.html @@ -0,0 +1,52 @@ +<!DOCTYPE html> +<!-- Copyright © 2017 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). --> +<meta charset="utf-8"> +<title>Test for PaymentRequestUpdateEvent Constructor</title> +<link rel="help" href="https://w3c.github.io/browser-payment-api/#constructor"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script> +const examplePay = Object.freeze({ supportedMethods: "https://example.com/pay" }); +const defaultMethods = Object.freeze([examplePay]); +const defaultDetails = Object.freeze({ + total: { + label: "Total", + amount: { + currency: "USD", + value: "1.00", + }, + }, +}); + +test(() => { + try { + new PaymentRequestUpdateEvent("test"); + } catch (err) { + assert_unreached(`Unexpected exception: ${err.message}`); + } +}, "PaymentRequestUpdateEvent can be constructed in secure-context"); + +test(() => { + const ev = new PaymentRequestUpdateEvent("test", { + bubbles: true, + cancelable: true, + composed: true, + }); + assert_false(ev.isTrusted, "constructed in script, so not be trusted"); + assert_true(ev.bubbles, "set by EventInitDict"); + assert_true(ev.cancelable, "set by EventInitDict"); + assert_true(ev.composed, "set by EventInitDict"); + assert_equals(ev.target, null, "initially null"); + assert_equals(ev.type, "test"); +}, "PaymentRequestUpdateEvent can be constructed with an EventInitDict, even if not trusted"); + +test(() => { + const request = new PaymentRequest(defaultMethods, defaultDetails); + const ev = new PaymentRequestUpdateEvent("test"); + request.addEventListener("test", evt => { + assert_equals(ev, evt); + }); + request.dispatchEvent(ev); +}, "PaymentRequestUpdateEvent can be dispatched, even if not trusted"); + +</script> diff --git a/testing/web-platform/tests/payment-request/PaymentRequestUpdateEvent/updatewith-method.https.html b/testing/web-platform/tests/payment-request/PaymentRequestUpdateEvent/updatewith-method.https.html new file mode 100644 index 0000000000..9a60fe7a4c --- /dev/null +++ b/testing/web-platform/tests/payment-request/PaymentRequestUpdateEvent/updatewith-method.https.html @@ -0,0 +1,62 @@ +<!DOCTYPE html> +<!-- Copyright © 2017 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). --> +<meta charset="utf-8"> +<title>Test for PaymentRequestUpdateEvent's updateWith() method</title> +<link rel="help" href="https://w3c.github.io/browser-payment-api/#updatewith-method"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script> +const examplePay = Object.freeze({ supportedMethods: "https://example.com/pay" }); +const defaultMethods = Object.freeze([examplePay]); +const defaultDetails = Object.freeze({ + total: { + label: "Total", + amount: { + currency: "USD", + value: "1.00", + }, + }, +}); + +test(() => { + // Smoke test - checks target is set as expected + const request = new PaymentRequest(defaultMethods, defaultDetails); + const ev = new PaymentRequestUpdateEvent("test"); + request.dispatchEvent(ev); + assert_equals(ev.target, request, "The request and the target at the same"); +}, "Let target be the request which is dispatching the event."); + +// Github issue: https://github.com/w3c/browser-payment-api/issues/546 +test(() => { + const untrustedEvents = [ + new PaymentRequestUpdateEvent("just a test") + ].forEach(ev => { + assert_throws_dom( + "InvalidStateError", + () => { + ev.updateWith(Promise.resolve()); + }, + `untrusted event of type "${ev.type}" must throw "InvalidStateError"` + ); + }); +}, `Calling .updateWith() with an undispatched untrusted event throws "InvalidStateError"`); + +// Github issue: https://github.com/w3c/browser-payment-api/issues/546 +test(() => { + const request = new PaymentRequest(defaultMethods, defaultDetails); + const untrustedEvents = [ + new PaymentRequestUpdateEvent("just a test") + ].map(ev => { + request.dispatchEvent(ev); // set .target and dispatch flag + // unstrusted event. + assert_throws_dom( + "InvalidStateError", + () => { + ev.updateWith(Promise.resolve()) + }, + `untrusted event of type "${ev.type}" must throw "InvalidStateError"` + ); + }); +}, `Calling .updateWith() with a dispatched, untrusted event, throws "InvalidStateError"`); + +</script> |