<!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 PaymentRequest shippingOption attribute</title>
<link rel="help" href="https://w3c.github.io/payment-request/#shippingoption-attribute">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script>
const validMethod = Object.freeze({ supportedMethods: "foo" });
const validMethods = Object.freeze([validMethod]);
const validAmount = Object.freeze({ currency: "USD", value: "5.00" });
const validTotal = Object.freeze({
label: "label",
amount: validAmount,
});
const validDetails = Object.freeze({ total: validTotal });
const validShippingOption = Object.freeze({
id: "valid",
label: "Valid shipping option",
amount: validAmount,
selected: false,
});
const requestShipping = Object.freeze({
requestShipping: true,
});
test(() => {
const request = new PaymentRequest(validMethods, validDetails);
assert_idl_attribute(request, "shippingOption");
}, "Must have a .shippingOption IDL attribute.");
test(() => {
const request = new PaymentRequest(validMethods, validDetails);
assert_equals(request.shippingOption, null, "expected null");
}, ".shippingOption attribute must default to null.");
test(() => {
const detailsWithShippingOptions = Object.assign({}, validDetails, {
shippingOptions: [validShippingOption],
});
const request = new PaymentRequest(
validMethods,
detailsWithShippingOptions,
requestShipping
);
assert_equals(request.shippingOption, null, "expected null");
}, "If there is a single shipping option, but selected is false, then .shippingOption must be null.");
test(() => {
const shippingOption2 = Object.assign({}, validShippingOption, {
id: "valid2",
});
const detailsWithShippingOptions = Object.assign({}, validDetails, {
shippingOptions: [validShippingOption, shippingOption2],
});
const request = new PaymentRequest(
validMethods,
detailsWithShippingOptions,
requestShipping
);
assert_equals(request.shippingOption, null, "expected null");
}, "If there are multiple shipping options all with `selected` set to false, then .shippingOption is null.");
test(() => {
const shippingOption2 = Object.assign({}, validShippingOption, {
id: "pass",
selected: true,
});
const detailsWithShippingOptions = Object.assign({}, validDetails, {
shippingOptions: [shippingOption2, validShippingOption],
});
const request = new PaymentRequest(
validMethods,
detailsWithShippingOptions,
requestShipping
);
assert_equals(request.shippingOption, "pass", "expected 'pass'");
}, "Given multiple shipping options, it must use the selected shipping option for .shippingOption value.");
test(() => {
const shippingOption1 = Object.assign({}, validShippingOption, {
id: "fail",
selected: true,
});
const shippingOption2 = Object.assign({}, validShippingOption, {
id: "pass",
selected: true,
});
const detailsWithShippingOptions = Object.assign({}, validDetails, {
shippingOptions: [shippingOption1, shippingOption2, validShippingOption],
});
const request = new PaymentRequest(
validMethods,
detailsWithShippingOptions,
requestShipping
);
assert_equals(request.shippingOption, "pass", "expected 'pass'");
}, "If there are multiple of the shipping options with selected true, then .shippingOption is the last selected shipping option in order.");
</script>