// |reftest| skip-if(!this.hasOwnProperty('Temporal')) -- Temporal is not enabled unconditionally // Copyright (C) 2023 Igalia, S.L. All rights reserved. // This code is governed by the BSD license found in the LICENSE file. /*--- esid: sec-temporal.plainyearmonth.compare description: > More than one calendar annotation is not syntactical if any have the criical flag features: [Temporal] ---*/ const invalidStrings = [ "1970-01-01[u-ca=iso8601][!u-ca=iso8601]", "1970-01-01[!u-ca=iso8601][u-ca=iso8601]", "1970-01-01[UTC][u-ca=iso8601][!u-ca=iso8601]", "1970-01-01[u-ca=iso8601][foo=bar][!u-ca=iso8601]", "1970-01-01T00:00[u-ca=iso8601][!u-ca=iso8601]", "1970-01-01T00:00[!u-ca=iso8601][u-ca=iso8601]", "1970-01-01T00:00[UTC][u-ca=iso8601][!u-ca=iso8601]", "1970-01-01T00:00[u-ca=iso8601][foo=bar][!u-ca=iso8601]", ]; invalidStrings.forEach((arg) => { assert.throws( RangeError, () => Temporal.PlainYearMonth.compare(arg, new Temporal.PlainYearMonth(2019, 6)), `reject more than one calendar annotation if any critical: ${arg} (first argument)` ); assert.throws( RangeError, () => Temporal.PlainYearMonth.compare(new Temporal.PlainYearMonth(2019, 6), arg), `reject more than one calendar annotation if any critical: ${arg} (second argument)` ); }); reportCompare(0, 0);