DXR is a code search and navigation tool aimed at making sense of large projects. It supports full-text and regex searches as well as structural queries.

Mercurial (8d30b15ca8f9)

VCS Links

Line Code
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 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
<!DOCTYPE html>
<meta charset="utf-8">
<title>Tests for PaymentRequest.hasEnrolledInstrument() method</title>
<link rel="help" href="https://w3c.github.io/payment-request/#hasenrolledinstrument-method">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/testdriver.js"></script>
<script src='/resources/testdriver-vendor.js'></script>
<script>
"use strict";
const unsupportedMethods = [
  { supportedMethods: "this-is-not-supported" },
  { supportedMethods: "https://not.supported" },
];
const defaultMethods = Object.freeze([
  {
    supportedMethods: "basic-card",
    data: {
      supportedNetworks: [ 'visa' ],
    },
  }
]);
const defaultDetails = Object.freeze({
  total: {
    label: "Total",
    amount: {
      currency: "USD",
      value: "1.00",
    },
  },
});

promise_test(async t => {
  const request = new PaymentRequest(unsupportedMethods, defaultDetails);
  assert_false(
    await request.hasEnrolledInstrument(),
    "hasEnrolledInstrument() should resolve to false."
  );
}, `hasEnrolledInstrument() resolves to false for unsupported payment methods.`);

promise_test(async t => {
  const request = new PaymentRequest(defaultMethods, defaultDetails);
  const [acceptPromise, hasEnrolledInstrumentPromise] = await test_driver.bless(
      "show payment request",
      () => {
        const acceptPromise = request.show();  // Sets state to "interactive"
        const hasEnrolledInstrumentPromise = request.hasEnrolledInstrument();
        return [acceptPromise, hasEnrolledInstrumentPromise];
      });
  await promise_rejects(t, "InvalidStateError", hasEnrolledInstrumentPromise);

  await request.abort();
  await promise_rejects(t, "AbortError", acceptPromise);
}, `If request.[[state]] is "interactive", then return a promise rejected with an "InvalidStateError" DOMException.`);

promise_test(async t => {
  const request = new PaymentRequest(defaultMethods, defaultDetails);
  const [abortPromise, acceptPromise] = await test_driver.bless( "show payment request", () => {
    const acceptPromise = request.show();  // Sets state to "interactive"
    acceptPromise.catch(() => {});  // no-op, just to handle unhandled rejection in devtools.
    const abortPromise =request.abort();  // Sets state to "closed"
    return [abortPromise, acceptPromise];
  });
  await abortPromise;
  await promise_rejects(t, "AbortError", acceptPromise);

  const hasEnrolledInstrumentPromise = request.hasEnrolledInstrument();
  await promise_rejects(t, "InvalidStateError", hasEnrolledInstrumentPromise);
}, `If request.[[state]] is "closed", then return a promise rejected with an "InvalidStateError" DOMException.`);
</script>

<small>
  If you find a buggy test, please <a href="https://github.com/web-platform-tests/wpt/issues">file a bug</a>
  and tag one of the <a href="https://github.com/web-platform-tests/wpt/blob/master/payment-request/META.yml">suggested reviewers</a>.
</small>