Source code

Revision control

Copy as Markdown

Other Tools

// |reftest| skip-if(!this.hasOwnProperty('Temporal')) -- Temporal is not enabled unconditionally
// Copyright (C) 2022 Igalia, S.L. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-temporal.plaintime.compare
description: UTC offset not valid with format that does not include a time
features: [Temporal]
---*/
const validStrings = [
"12:34:56.987654321+00:00",
"12:34:56.987654321+00:00[UTC]",
"12:34:56.987654321+00:00[!UTC]",
"12:34:56.987654321-02:30[America/St_Johns]",
"1976-11-18T12:34:56.987654321+00:00",
"1976-11-18T12:34:56.987654321+00:00[UTC]",
"1976-11-18T12:34:56.987654321+00:00[!UTC]",
"1976-11-18T12:34:56.987654321-02:30[America/St_Johns]",
];
for (const arg of validStrings) {
const result = Temporal.PlainTime.compare(arg, arg);
assert.sameValue(
result,
0,
`"${arg}" is a valid UTC offset with time for PlainTime`
);
}
const invalidStrings = [
"2022-09-15Z",
"2022-09-15Z[UTC]",
"2022-09-15Z[Europe/Vienna]",
"2022-09-15+00:00",
"2022-09-15+00:00[UTC]",
"2022-09-15-02:30",
"2022-09-15-02:30[America/St_Johns]",
];
for (const arg of invalidStrings) {
assert.throws(
RangeError,
() => Temporal.PlainTime.compare(arg, new Temporal.PlainTime(12, 34, 56, 987, 654, 321)),
`"${arg}" UTC offset without time is not valid for PlainTime (first argument)`
);
assert.throws(
RangeError,
() => Temporal.PlainTime.compare(new Temporal.PlainTime(12, 34, 56, 987, 654, 321), arg),
`"${arg}" UTC offset without time is not valid for PlainTime (second argument)`
);
}
reportCompare(0, 0);