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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
|
<!DOCTYPE html>
<meta charset="utf-8">
<title>Manual 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>
setup({
explicit_done: true,
explicit_timeout: true,
});
const defaultMethods = Object.freeze([
{
supportedMethods: "basic-card",
data: {
supportedNetworks: [ 'visa' ],
},
}
]);
const defaultDetails = Object.freeze({
total: {
label: "Total",
amount: {
currency: "USD",
value: "1.00",
},
},
});
function testHasNoEnrolledInstrument() {
promise_test(async t => {
const request = new PaymentRequest(defaultMethods, defaultDetails);
assert_false(
await request.hasEnrolledInstrument(),
"No test enrolled in the test profile."
);
}, `hasEnrolledInstrument() resolves to false when user has no enrolled instrument.`);
}
function testHasEnrolledInstrument() {
promise_test(async t => {
const request = new PaymentRequest(defaultMethods, defaultDetails);
assert_true(
await request.hasEnrolledInstrument(),
"A card is enrolled in the test profile."
);
}, `hasEnrolledInstrument() resolves to true when user has an enrolled instrument.`);
}
function testHasEnrolledInstrumentAgain() {
promise_test(async t => {
const request = new PaymentRequest(defaultMethods, defaultDetails);
assert_true(
await request.hasEnrolledInstrument(),
"A card is enrolled in the test profile."
);
}, `hasEnrolledInstrument() can be called multiple times if the payment method details are identical.`);
}
</script>
<h2>Manual tests for hasEnrolledInstrument() method</h2>
<p>
Follow the instructions from top to bottom. Click on each button in sequence
without refreshing the page. Some of the tests will bring up the Payment
Request UI and close them automatically. If a payment sheet stays open, the
test has failed.
</p>
<ol>
<li>Follow browser-specific instructions to remove all cards from the test profile.</li>
<li>
<button onclick="testHasNoEnrolledInstrument()">
hasEnrolledInstrument() resolves to false when user has no enrolled instrument.
</button>
</li>
<li>Add a test Visa card to your test profile, e.g. 4012888888881881.</li>
<li>
<button onclick="testHasEnrolledInstrument()">
hasEnrolledInstrument() resolves to true when user has an enrolled instrument.
</button>
</li>
<li>
<button onclick="testHasEnrolledInstrumentAgain()">
hasEnrolledInstrument() can be called multiple times if the payment method
details are identical.
</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">suggested reviewers</a>.
</small>
|