summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/payment-request/payment-response/onpayerdetailchange-attribute-manual.https.html
blob: 5731952c0ebc0e8085cb340b5b7cfc478849fc99 (plain)
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
<!doctype html>
<meta charset=utf-8>
<title>PaymentResponse.prototype.onpayerdetailchange attribute</title>
<script src=/resources/testharness.js></script>
<script src=/resources/testharnessreport.js></script>
<script src="helpers.js"></script>
<script>
function runTest(button, options, expected){
  button.disabled = true;
  promise_test(async () => {
    const response = await getPaymentResponse(options);
    const eventPromise = new Promise(resolve => {
      response.addEventListener("payerdetailchange", resolve);
    });
    const error = button.previousElementSibling.textContent.trim();
    await response.retry({ error });
    const event = await eventPromise;
    assert_true(event instanceof PaymentRequestUpdateEvent);
    for([prop, value] of Object.entries(expected)){
      if (prop === 'payerPhone') {
        // |payerPhone| may optionally adhere to E164 structure, which does not
        // contain formatting, e.g. +180000000 instead of +1-800-000-0000.
        // Strip out the formatting in case the user agent implements E164.
        // https://w3c.github.io/payment-request/#addressinit-dictionary
        value = value.replace(/[-\(\) ]/g, '');
      }
      assert_equals(response[prop], value);
    }
    await response.complete("success");
  }, button.textContent.trim());
}
</script>
<h2>Handling PaymentResponse.prototype.onpayerdetailchange events</h2>
<p>
  Each button will bring up the Payment Request UI window.
  When shown the payment sheet, use any details and hit pay.
</p>
<p>
  When asked to retry the payment:
</p>
<ol>
  <li>
    <p>
      Change payer's name to "pass".
    </p>
    <button onclick="runTest(this, { requestPayerName: true }, { payerName: 'pass' });">
      PaymentRequestUpdateEvent is dispatched when payer name changes.
    </button>
  </li>
  <li>
    <p>
      Change payer's email to "pass@pass.pass".
    </p>
    <button onclick="runTest(this, {requestPayerEmail: true}, { payerEmail: 'pass@pass.pass' });">
      PaymentRequestUpdateEvent is dispatched when payer email changes.
    </button>
  </li>
  <li>
    <p>
      Change payer's phone to "+1-800-000-0000".
    </p>
    <button onclick="runTest(this, {requestPayerPhone: true}, { payerPhone: '+18000000000' })">
      PaymentRequestUpdateEvent is dispatched when payer phone changes.
    </button>
  </li>
  <li>
    <button onclick="done();">DONE!</button>
  </li>
</ol>
<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">owners</a>.
</small>