From 7184313667460e099c93126c807fe9a93241dd19 Mon Sep 17 00:00:00 2001 From: Philip Chimento Date: Fri, 24 May 2024 13:54:48 -0700 Subject: [PATCH] Temporal: Remove PlainTime.toPlainDateTime/toZonedDateTime methods See tc39/proposal-temporal#2848 --- ...ent-builtin-calendar-no-array-iteration.js | 21 ---- ...ields-called-with-null-prototype-fields.js | 16 --- ...argument-constructor-in-calendar-fields.js | 14 --- .../argument-duplicate-calendar-fields.js | 16 --- .../toPlainDateTime/argument-leap-second.js | 27 ---- .../toPlainDateTime/argument-number.js | 25 ---- .../toPlainDateTime/argument-plaindatetime.js | 21 ---- ...t-propertybag-calendar-case-insensitive.js | 17 --- ...rgument-propertybag-calendar-iso-string.js | 26 ---- ...gument-propertybag-calendar-leap-second.js | 21 ---- .../argument-propertybag-calendar-number.js | 26 ---- .../argument-propertybag-calendar-string.js | 17 --- ...rgument-propertybag-calendar-wrong-type.js | 43 ------- ...argument-propertybag-calendar-year-zero.js | 25 ---- .../argument-proto-in-calendar-fields.js | 14 --- ...-string-calendar-annotation-invalid-key.js | 22 ---- .../argument-string-calendar-annotation.js | 31 ----- ...ment-string-critical-unknown-annotation.js | 25 ---- .../argument-string-date-with-utc-offset.js | 46 ------- .../argument-string-invalid.js | 61 ---------- .../argument-string-multiple-calendar.js | 29 ----- .../argument-string-multiple-time-zone.js | 25 ---- .../argument-string-time-separators.js | 27 ---- .../argument-string-time-zone-annotation.js | 36 ------ .../argument-string-unknown-annotation.js | 30 ----- .../argument-string-with-utc-designator.js | 21 ---- .../toPlainDateTime/argument-wrong-type.js | 40 ------ .../argument-zoneddatetime-convert.js | 19 --- .../argument-zoneddatetime-slots.js | 37 ------ ...one-getoffsetnanosecondsfor-non-integer.js | 16 --- ...ne-getoffsetnanosecondsfor-not-callable.js | 20 --- ...ne-getoffsetnanosecondsfor-out-of-range.js | 16 --- ...zone-getoffsetnanosecondsfor-wrong-type.js | 25 ---- .../prototype/toPlainDateTime/basic.js | 22 ---- .../prototype/toPlainDateTime/branding.js | 24 ---- .../prototype/toPlainDateTime/builtin.js | 33 ----- ...romfields-called-with-options-undefined.js | 16 --- .../calendar-fields-iterable.js | 31 ----- .../calendar-temporal-object.js | 27 ---- .../infinity-throws-rangeerror.js | 23 ---- .../prototype/toPlainDateTime/length.js | 25 ---- .../prototype/toPlainDateTime/limits.js | 39 ------ .../prototype/toPlainDateTime/name.js | 23 ---- .../toPlainDateTime/not-a-constructor.js | 21 ---- .../prototype/toPlainDateTime/prop-desc.js | 21 ---- .../prototype/toPlainDateTime/year-zero.js | 23 ---- ...ent-builtin-calendar-no-array-iteration.js | 21 ---- ...ields-called-with-null-prototype-fields.js | 16 --- ...argument-constructor-in-calendar-fields.js | 14 --- .../argument-duplicate-calendar-fields.js | 16 --- .../toZonedDateTime/argument-leap-second.js | 26 ---- .../toZonedDateTime/argument-number.js | 25 ---- .../toZonedDateTime/argument-plaindatetime.js | 29 ----- .../toZonedDateTime/argument-primitive.js | 23 ---- ...t-propertybag-calendar-case-insensitive.js | 16 --- ...rgument-propertybag-calendar-iso-string.js | 25 ---- ...gument-propertybag-calendar-leap-second.js | 20 --- .../argument-propertybag-calendar-number.js | 26 ---- .../argument-propertybag-calendar-string.js | 16 --- ...rgument-propertybag-calendar-wrong-type.js | 43 ------- ...argument-propertybag-calendar-year-zero.js | 25 ---- ...argument-propertybag-missing-properties.js | 22 ---- .../argument-proto-in-calendar-fields.js | 14 --- ...-string-calendar-annotation-invalid-key.js | 22 ---- .../argument-string-calendar-annotation.js | 30 ----- ...ment-string-critical-unknown-annotation.js | 25 ---- .../argument-string-date-with-utc-offset.js | 45 ------- .../argument-string-invalid.js | 61 ---------- .../argument-string-multiple-calendar.js | 29 ----- .../argument-string-multiple-time-zone.js | 25 ---- .../argument-string-time-separators.js | 26 ---- .../argument-string-time-zone-annotation.js | 35 ------ .../argument-string-unknown-annotation.js | 29 ----- .../argument-string-with-utc-designator.js | 21 ---- .../toZonedDateTime/argument-wrong-type.js | 40 ------ .../argument-zoneddatetime-convert.js | 19 --- .../argument-zoneddatetime-slots.js | 37 ------ ...one-getoffsetnanosecondsfor-non-integer.js | 16 --- ...ne-getoffsetnanosecondsfor-not-callable.js | 20 --- ...ne-getoffsetnanosecondsfor-out-of-range.js | 16 --- ...zone-getoffsetnanosecondsfor-wrong-type.js | 25 ---- .../prototype/toZonedDateTime/basic.js | 24 ---- .../prototype/toZonedDateTime/branding.js | 24 ---- .../prototype/toZonedDateTime/builtin.js | 33 ----- ...romfields-called-with-options-undefined.js | 16 --- .../calendar-fields-iterable.js | 31 ----- .../calendar-temporal-object.js | 27 ---- ...secondsfor-maximum-forward-offset-shift.js | 46 ------- ...dsfor-out-of-range-forward-offset-shift.js | 41 ------- ...nstantsfor-called-with-iso8601-calendar.js | 55 --------- ...stantsfor-maximum-backward-offset-shift.js | 50 -------- ...sfor-out-of-range-backward-offset-shift.js | 46 ------- .../infinity-throws-rangeerror.js | 23 ---- .../prototype/toZonedDateTime/length.js | 25 ---- .../prototype/toZonedDateTime/name.js | 23 ---- .../toZonedDateTime/not-a-constructor.js | 21 ---- .../toZonedDateTime/order-of-operations.js | 115 ------------------ .../plaindate-infinity-throws-rangeerror.js | 23 ---- .../prototype/toZonedDateTime/prop-desc.js | 21 ---- .../timezone-case-insensitive.js | 14 --- ...one-getoffsetnanosecondsfor-non-integer.js | 19 --- ...ne-getoffsetnanosecondsfor-not-callable.js | 23 ---- ...ne-getoffsetnanosecondsfor-out-of-range.js | 19 --- ...zone-getoffsetnanosecondsfor-wrong-type.js | 28 ----- ...imezone-getpossibleinstantsfor-iterable.js | 42 ------- .../timezone-string-datetime.js | 62 ---------- .../timezone-string-leap-second.js | 17 --- .../timezone-string-multiple-offsets.js | 14 --- .../timezone-string-year-zero.js | 21 ---- .../toZonedDateTime/timezone-string.js | 36 ------ .../toZonedDateTime/timezone-wrong-type.js | 39 ------ .../prototype/toZonedDateTime/year-zero.js | 23 ---- .../infinity-throws-rangeerror.js | 21 ---- .../plaindate-infinity-throws-rangeerror.js | 21 ---- .../timezone-string-datetime.js | 22 ---- 115 files changed, 3146 deletions(-) delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-builtin-calendar-no-array-iteration.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-calendar-datefromfields-called-with-null-prototype-fields.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-constructor-in-calendar-fields.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-duplicate-calendar-fields.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-leap-second.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-number.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-plaindatetime.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-case-insensitive.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-iso-string.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-leap-second.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-number.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-string.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-wrong-type.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-year-zero.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-proto-in-calendar-fields.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-calendar-annotation-invalid-key.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-calendar-annotation.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-critical-unknown-annotation.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-date-with-utc-offset.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-invalid.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-multiple-calendar.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-multiple-time-zone.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-time-separators.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-time-zone-annotation.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-unknown-annotation.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-with-utc-designator.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-wrong-type.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-convert.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-slots.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-non-integer.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-not-callable.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-out-of-range.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-wrong-type.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/basic.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/branding.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/builtin.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-datefromfields-called-with-options-undefined.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-fields-iterable.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-temporal-object.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/infinity-throws-rangeerror.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/length.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/limits.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/name.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/not-a-constructor.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/prop-desc.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/year-zero.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-builtin-calendar-no-array-iteration.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-calendar-datefromfields-called-with-null-prototype-fields.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-constructor-in-calendar-fields.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-duplicate-calendar-fields.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-leap-second.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-number.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-plaindatetime.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-primitive.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-case-insensitive.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-iso-string.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-leap-second.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-number.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-string.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-wrong-type.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-year-zero.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-missing-properties.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-proto-in-calendar-fields.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-calendar-annotation-invalid-key.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-calendar-annotation.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-critical-unknown-annotation.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-date-with-utc-offset.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-invalid.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-multiple-calendar.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-multiple-time-zone.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-time-separators.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-time-zone-annotation.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-unknown-annotation.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-with-utc-designator.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-wrong-type.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-convert.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-slots.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-non-integer.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-not-callable.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-out-of-range.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-wrong-type.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/basic.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/branding.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/builtin.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-datefromfields-called-with-options-undefined.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-fields-iterable.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-temporal-object.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getoffsetnanosecondsfor-maximum-forward-offset-shift.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getoffsetnanosecondsfor-out-of-range-forward-offset-shift.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-called-with-iso8601-calendar.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-maximum-backward-offset-shift.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-out-of-range-backward-offset-shift.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/infinity-throws-rangeerror.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/length.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/name.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/not-a-constructor.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/order-of-operations.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/plaindate-infinity-throws-rangeerror.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/prop-desc.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-case-insensitive.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-non-integer.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-not-callable.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-out-of-range.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-wrong-type.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getpossibleinstantsfor-iterable.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-datetime.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-leap-second.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-multiple-offsets.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-year-zero.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-wrong-type.js delete mode 100644 test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/year-zero.js delete mode 100644 test/intl402/Temporal/PlainTime/prototype/toPlainDateTime/infinity-throws-rangeerror.js delete mode 100644 test/intl402/Temporal/PlainTime/prototype/toZonedDateTime/plaindate-infinity-throws-rangeerror.js delete mode 100644 test/intl402/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-datetime.js diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-builtin-calendar-no-array-iteration.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-builtin-calendar-no-array-iteration.js deleted file mode 100644 index f338977a77..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-builtin-calendar-no-array-iteration.js +++ /dev/null @@ -1,21 +0,0 @@ -// 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.plaintime.prototype.toplaindatetime -description: > - Calling the method with a property bag argument with a builtin calendar causes - no observable array iteration when getting the calendar fields. -features: [Temporal] ----*/ - -const arrayPrototypeSymbolIteratorOriginal = Array.prototype[Symbol.iterator]; -Array.prototype[Symbol.iterator] = function arrayIterator() { - throw new Test262Error("Array should not be iterated"); -} - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -const arg = { year: 2000, month: 5, day: 2, calendar: "iso8601" }; -instance.toPlainDateTime(arg); - -Array.prototype[Symbol.iterator] = arrayPrototypeSymbolIteratorOriginal; diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-calendar-datefromfields-called-with-null-prototype-fields.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-calendar-datefromfields-called-with-null-prototype-fields.js deleted file mode 100644 index 58e3993362..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-calendar-datefromfields-called-with-null-prototype-fields.js +++ /dev/null @@ -1,16 +0,0 @@ -// 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.prototype.toplaindatetime -description: > - Calendar.dateFromFields method is called with a null-prototype fields object -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const calendar = TemporalHelpers.calendarCheckFieldsPrototypePollution(); -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -const arg = { year: 2000, month: 5, day: 2, calendar }; -instance.toPlainDateTime(arg); -assert.sameValue(calendar.dateFromFieldsCallCount, 1, "dateFromFields should be called on the property bag's calendar"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-constructor-in-calendar-fields.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-constructor-in-calendar-fields.js deleted file mode 100644 index d7980dc0fd..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-constructor-in-calendar-fields.js +++ /dev/null @@ -1,14 +0,0 @@ -// 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.plaintime.prototype.toplaindatetime -description: If a calendar's fields() method returns a field named 'constructor', PrepareTemporalFields should throw a RangeError. -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const calendar = TemporalHelpers.calendarWithExtraFields(['constructor']); -const arg = {year: 2023, month: 5, monthCode: 'M05', day: 1, calendar: calendar}; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -assert.throws(RangeError, () => instance.toPlainDateTime(arg)); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-duplicate-calendar-fields.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-duplicate-calendar-fields.js deleted file mode 100644 index ad36cecc7b..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-duplicate-calendar-fields.js +++ /dev/null @@ -1,16 +0,0 @@ -// 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.plaintime.prototype.toplaindatetime -description: If a calendar's fields() method returns duplicate field names, PrepareTemporalFields should throw a RangeError. -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -for (const extra_fields of [['foo', 'foo'], ['day'], ['month'], ['monthCode'], ['year']]) { - const calendar = TemporalHelpers.calendarWithExtraFields(extra_fields); - const arg = { year: 2023, month: 5, monthCode: 'M05', day: 1, calendar: calendar }; - const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - - assert.throws(RangeError, () => instance.toPlainDateTime(arg)); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-leap-second.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-leap-second.js deleted file mode 100644 index ea1ee61223..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-leap-second.js +++ /dev/null @@ -1,27 +0,0 @@ -// 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.prototype.toplaindatetime -description: Leap second is a valid ISO string for PlainDate -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -let arg = "2016-12-31T23:59:60"; -const result1 = instance.toPlainDateTime(arg); -TemporalHelpers.assertPlainDateTime( - result1, - 2016, 12, "M12", 31, 12, 34, 56, 987, 654, 321, - "leap second is a valid ISO string for PlainDate" -); - -arg = { year: 2016, month: 12, day: 31, hour: 23, minute: 59, second: 60 }; -const result2 = instance.toPlainDateTime(arg); -TemporalHelpers.assertPlainDateTime( - result2, - 2016, 12, "M12", 31, 12, 34, 56, 987, 654, 321, - "second: 60 is ignored in property bag for PlainDate" -); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-number.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-number.js deleted file mode 100644 index 73096305c6..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-number.js +++ /dev/null @@ -1,25 +0,0 @@ -// 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.prototype.toplaindatetime -description: A number cannot be used in place of a Temporal.PlainDate -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const numbers = [ - 1, - 19761118, - -19761118, - 1234567890, -]; - -for (const arg of numbers) { - assert.throws( - TypeError, - () => instance.toPlainDateTime(arg), - 'Numbers cannot be used in place of an ISO string for PlainDate' - ); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-plaindatetime.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-plaindatetime.js deleted file mode 100644 index 6ea0d4cc4e..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-plaindatetime.js +++ /dev/null @@ -1,21 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.toplaindatetime -description: Fast path for converting Temporal.PlainDateTime to Temporal.PlainDate by reading internal slots -info: | - sec-temporal.plaintime.prototype.toplaindatetime step 3: - 3. Set _temporalDate_ to ? ToTemporalDate(_temporalDate_). - sec-temporal-totemporaldate step 2.b: - b. If _item_ has an [[InitializedTemporalDateTime]] internal slot, then - i. Return ! CreateTemporalDate(_item_.[[ISOYear]], _item_.[[ISOMonth]], _item_.[[ISODay]], _item_.[[Calendar]]). -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -TemporalHelpers.checkPlainDateTimeConversionFastPath((datetime) => { - const time = new Temporal.PlainTime(6, 54, 32, 123, 456, 789); - const result = time.toPlainDateTime(datetime); - TemporalHelpers.assertPlainDateTime(result, 2000, 5, "M05", 2, 6, 54, 32, 123, 456, 789); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-case-insensitive.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-case-insensitive.js deleted file mode 100644 index 8c759f73db..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-case-insensitive.js +++ /dev/null @@ -1,17 +0,0 @@ -// 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.prototype.toplaindatetime -description: The calendar name is case-insensitive -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const calendar = "IsO8601"; - -const arg = { year: 1976, monthCode: "M11", day: 18, calendar }; -const result = instance.toPlainDateTime(arg); -TemporalHelpers.assertPlainDateTime(result, 1976, 11, "M11", 18, 12, 34, 56, 987, 654, 321, "Calendar is case-insensitive"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-iso-string.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-iso-string.js deleted file mode 100644 index f15caa7bee..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-iso-string.js +++ /dev/null @@ -1,26 +0,0 @@ -// Copyright (C) 2024 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: An ISO 8601 string can be converted to a calendar ID in Calendar -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -for (const calendar of [ - "2020-01-01", - "2020-01-01[u-ca=iso8601]", - "2020-01-01T00:00:00.000000000", - "2020-01-01T00:00:00.000000000[u-ca=iso8601]", - "01-01", - "01-01[u-ca=iso8601]", - "2020-01", - "2020-01[u-ca=iso8601]", -]) { - const arg = { year: 1976, monthCode: "M11", day: 18, calendar }; - const result = instance.toPlainDateTime(arg); - TemporalHelpers.assertPlainDateTime(result, 1976, 11, "M11", 18, 12, 34, 56, 987, 654, 321, `Calendar created from string "${calendar}"`); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-leap-second.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-leap-second.js deleted file mode 100644 index 21a0901132..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-leap-second.js +++ /dev/null @@ -1,21 +0,0 @@ -// 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.prototype.toplaindatetime -description: Leap second is a valid ISO string for a calendar in a property bag -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const calendar = "2016-12-31T23:59:60"; - -const arg = { year: 1976, monthCode: "M11", day: 18, calendar }; -const result = instance.toPlainDateTime(arg); -TemporalHelpers.assertPlainDateTime( - result, - 1976, 11, "M11", 18, 12, 34, 56, 987, 654, 321, - "leap second is a valid ISO string for calendar" -); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-number.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-number.js deleted file mode 100644 index 0bf7766f5d..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-number.js +++ /dev/null @@ -1,26 +0,0 @@ -// 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.prototype.toplaindatetime -description: A number as calendar in a property bag is not accepted -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const numbers = [ - 1, - 19970327, - -19970327, - 1234567890, -]; - -for (const calendar of numbers) { - const arg = { year: 1976, monthCode: "M11", day: 18, calendar }; - assert.throws( - TypeError, - () => instance.toPlainDateTime(arg), - "Numbers cannot be used as a calendar" - ); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-string.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-string.js deleted file mode 100644 index 247205057e..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-string.js +++ /dev/null @@ -1,17 +0,0 @@ -// 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.prototype.toplaindatetime -description: A calendar ID is valid input for Calendar -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const calendar = "iso8601"; - -const arg = { year: 1976, monthCode: "M11", day: 18, calendar }; -const result = instance.toPlainDateTime(arg); -TemporalHelpers.assertPlainDateTime(result, 1976, 11, "M11", 18, 12, 34, 56, 987, 654, 321, `Calendar created from string "${calendar}"`); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-wrong-type.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-wrong-type.js deleted file mode 100644 index e01decab47..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-wrong-type.js +++ /dev/null @@ -1,43 +0,0 @@ -// 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.prototype.toplaindatetime -description: > - Appropriate error thrown when a calendar property from a property bag cannot - be converted to a calendar object or string -features: [BigInt, Symbol, Temporal] ----*/ - -const timeZone = new Temporal.TimeZone("UTC"); -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const primitiveTests = [ - [null, "null"], - [true, "boolean"], - ["", "empty string"], - [1, "number that doesn't convert to a valid ISO string"], - [1n, "bigint"], -]; - -for (const [calendar, description] of primitiveTests) { - const arg = { year: 2019, monthCode: "M11", day: 1, calendar }; - assert.throws( - typeof calendar === 'string' ? RangeError : TypeError, - () => instance.toPlainDateTime(arg), - `${description} does not convert to a valid ISO string` - ); -} - -const typeErrorTests = [ - [Symbol(), "symbol"], - [{}, "plain object that doesn't implement the protocol"], - [new Temporal.TimeZone("UTC"), "time zone instance"], - [Temporal.Calendar, "Temporal.Calendar, object"], - [Temporal.Calendar.prototype, "Temporal.Calendar.prototype, object"], // fails brand check in dateFromFields() -]; - -for (const [calendar, description] of typeErrorTests) { - const arg = { year: 2019, monthCode: "M11", day: 1, calendar }; - assert.throws(TypeError, () => instance.toPlainDateTime(arg), `${description} is not a valid property bag and does not convert to a string`); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-year-zero.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-year-zero.js deleted file mode 100644 index d38f883b16..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-propertybag-calendar-year-zero.js +++ /dev/null @@ -1,25 +0,0 @@ -// 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.prototype.toplaindatetime -description: Negative zero, as an extended year, is rejected -features: [Temporal, arrow-function] ----*/ - -const invalidStrings = [ - "-000000-10-31", - "-000000-10-31T17:45", - "-000000-10-31T17:45Z", - "-000000-10-31T17:45+01:00", - "-000000-10-31T17:45+00:00[UTC]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((str) => { - const arg = { year: 1976, month: 11, day: 18, calendar: str }; - assert.throws( - RangeError, - () => instance.toPlainDateTime(arg), - "reject minus zero as extended year" - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-proto-in-calendar-fields.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-proto-in-calendar-fields.js deleted file mode 100644 index 13b391418d..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-proto-in-calendar-fields.js +++ /dev/null @@ -1,14 +0,0 @@ -// 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.plaintime.prototype.toplaindatetime -description: If a calendar's fields() method returns a field named '__proto__', PrepareTemporalFields should throw a RangeError. -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const calendar = TemporalHelpers.calendarWithExtraFields(['__proto__']); -const arg = {year: 2023, month: 5, monthCode: 'M05', day: 1, calendar: calendar}; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -assert.throws(RangeError, () => instance.toPlainDateTime(arg)); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-calendar-annotation-invalid-key.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-calendar-annotation-invalid-key.js deleted file mode 100644 index a43626e456..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-calendar-annotation-invalid-key.js +++ /dev/null @@ -1,22 +0,0 @@ -// Copyright (C) 2024 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: Annotation keys are lowercase-only -features: [Temporal] ----*/ - -const invalidStrings = [ - ["1970-01-01[U-CA=iso8601]", "invalid capitalized key"], - ["1970-01-01[u-CA=iso8601]", "invalid partially-capitalized key"], - ["1970-01-01[FOO=bar]", "invalid capitalized unrecognized key"], -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach(([arg, descr]) => { - assert.throws( - RangeError, - () => instance.toPlainDateTime(arg), - `annotation keys must be lowercase: ${arg} - ${descr}` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-calendar-annotation.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-calendar-annotation.js deleted file mode 100644 index a0d745c9ae..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-calendar-annotation.js +++ /dev/null @@ -1,31 +0,0 @@ -// 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.prototype.toplaindatetime -description: Various forms of calendar annotation; critical flag has no effect -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -const tests = [ - ["2000-05-02[u-ca=iso8601]", "without time or time zone"], - ["2000-05-02[UTC][u-ca=iso8601]", "with time zone and no time"], - ["2000-05-02T15:23[u-ca=iso8601]", "without time zone"], - ["2000-05-02T15:23[UTC][u-ca=iso8601]", "with time zone"], - ["2000-05-02T15:23[!u-ca=iso8601]", "with ! and no time zone"], - ["2000-05-02T15:23[UTC][!u-ca=iso8601]", "with ! and time zone"], - ["2000-05-02T15:23[u-ca=iso8601][u-ca=discord]", "second annotation ignored"], -]; - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -tests.forEach(([arg, description]) => { - const result = instance.toPlainDateTime(arg); - - TemporalHelpers.assertPlainDateTime( - result, - 2000, 5, "M05", 2, 12, 34, 56, 987, 654, 321, - `calendar annotation (${description})` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-critical-unknown-annotation.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-critical-unknown-annotation.js deleted file mode 100644 index cc0677cf38..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-critical-unknown-annotation.js +++ /dev/null @@ -1,25 +0,0 @@ -// 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.prototype.toplaindatetime -description: Unknown annotations with critical flag are rejected -features: [Temporal] ----*/ - -const invalidStrings = [ - "1970-01-01[!foo=bar]", - "1970-01-01T00:00[!foo=bar]", - "1970-01-01T00:00[UTC][!foo=bar]", - "1970-01-01T00:00[u-ca=iso8601][!foo=bar]", - "1970-01-01T00:00[UTC][!foo=bar][u-ca=iso8601]", - "1970-01-01T00:00[foo=bar][!_foo-bar0=Dont-Ignore-This-99999999999]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((arg) => { - assert.throws( - RangeError, - () => instance.toPlainDateTime(arg), - `reject unknown annotation with critical flag: ${arg}` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-date-with-utc-offset.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-date-with-utc-offset.js deleted file mode 100644 index 6690958207..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-date-with-utc-offset.js +++ /dev/null @@ -1,46 +0,0 @@ -// 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.prototype.toplaindatetime -description: UTC offset not valid with format that does not include a time -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const validStrings = [ - "2000-05-02T00+00:00", - "2000-05-02T00+00:00[UTC]", - "2000-05-02T00+00:00[!UTC]", - "2000-05-02T00-02:30[America/St_Johns]", -]; - -for (const arg of validStrings) { - const result = instance.toPlainDateTime(arg); - - TemporalHelpers.assertPlainDateTime( - result, - 2000, 5, "M05", 2, 12, 34, 56, 987, 654, 321, - `"${arg}" is a valid UTC offset with time for PlainDate` - ); -} - -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, - () => instance.toPlainDateTime(arg), - `"${arg}" UTC offset without time is not valid for PlainDate` - ); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-invalid.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-invalid.js deleted file mode 100644 index 768f1dba07..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-invalid.js +++ /dev/null @@ -1,61 +0,0 @@ -// 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.prototype.toplaindatetime -description: > - RangeError thrown if an invalid ISO string (or syntactically valid ISO string - that is not supported) is used as a PlainDate -features: [Temporal, arrow-function] ----*/ - -const invalidStrings = [ - // invalid ISO strings: - "", - "invalid iso8601", - "2020-01-00", - "2020-01-32", - "2020-02-30", - "2021-02-29", - "2020-00-01", - "2020-13-01", - "2020-01-01T", - "2020-01-01T25:00:00", - "2020-01-01T01:60:00", - "2020-01-01T01:60:61", - "2020-01-01junk", - "2020-01-01T00:00:00junk", - "2020-01-01T00:00:00+00:00junk", - "2020-01-01T00:00:00+00:00[UTC]junk", - "2020-01-01T00:00:00+00:00[UTC][u-ca=iso8601]junk", - "02020-01-01", - "2020-001-01", - "2020-01-001", - "2020-01-01T001", - "2020-01-01T01:001", - "2020-01-01T01:01:001", - // valid, but forms not supported in Temporal: - "2020-W01-1", - "2020-001", - "+0002020-01-01", - // valid, but this calendar must not exist: - "2020-01-01[u-ca=notexist]", - // may be valid in other contexts, but insufficient information for PlainDate: - "2020-01", - "+002020-01", - "01-01", - "2020-W01", - "P1Y", - "-P12Y", - // valid, but outside the supported range: - "-999999-01-01", - "+999999-01-01", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -for (const arg of invalidStrings) { - assert.throws( - RangeError, - () => instance.toPlainDateTime(arg), - `"${arg}" should not be a valid ISO string for a PlainDate` - ); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-multiple-calendar.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-multiple-calendar.js deleted file mode 100644 index ee035cef28..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-multiple-calendar.js +++ /dev/null @@ -1,29 +0,0 @@ -// 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.plaintime.prototype.toplaindatetime -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]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((arg) => { - assert.throws( - RangeError, - () => instance.toPlainDateTime(arg), - `reject more than one calendar annotation if any critical: ${arg}` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-multiple-time-zone.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-multiple-time-zone.js deleted file mode 100644 index f9ec99ba89..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-multiple-time-zone.js +++ /dev/null @@ -1,25 +0,0 @@ -// 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.prototype.toplaindatetime -description: More than one time zone annotation is not syntactical -features: [Temporal] ----*/ - -const invalidStrings = [ - "1970-01-01[UTC][UTC]", - "1970-01-01T00:00[UTC][UTC]", - "1970-01-01T00:00[!UTC][UTC]", - "1970-01-01T00:00[UTC][!UTC]", - "1970-01-01T00:00[UTC][u-ca=iso8601][UTC]", - "1970-01-01T00:00[UTC][foo=bar][UTC]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((arg) => { - assert.throws( - RangeError, - () => instance.toPlainDateTime(arg), - `reject more than one time zone annotation: ${arg}` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-time-separators.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-time-separators.js deleted file mode 100644 index 47f1ddfe8b..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-time-separators.js +++ /dev/null @@ -1,27 +0,0 @@ -// 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.prototype.toplaindatetime -description: Time separator in string argument can vary -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -const tests = [ - ["2000-05-02T15:23", "uppercase T"], - ["2000-05-02t15:23", "lowercase T"], - ["2000-05-02 15:23", "space between date and time"], -]; - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -tests.forEach(([arg, description]) => { - const result = instance.toPlainDateTime(arg); - - TemporalHelpers.assertPlainDateTime( - result, - 2000, 5, "M05", 2, 12, 34, 56, 987, 654, 321, - `variant time separators (${description})` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-time-zone-annotation.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-time-zone-annotation.js deleted file mode 100644 index 346595ccb1..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-time-zone-annotation.js +++ /dev/null @@ -1,36 +0,0 @@ -// 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.prototype.toplaindatetime -description: Various forms of time zone annotation; critical flag has no effect -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -const tests = [ - ["2000-05-02[Asia/Kolkata]", "named, with no time"], - ["2000-05-02[!Europe/Vienna]", "named, with ! and no time"], - ["2000-05-02[+00:00]", "numeric, with no time"], - ["2000-05-02[!-02:30]", "numeric, with ! and no time"], - ["2000-05-02T15:23[America/Sao_Paulo]", "named, with no offset"], - ["2000-05-02T15:23[!Asia/Tokyo]", "named, with ! and no offset"], - ["2000-05-02T15:23[-02:30]", "numeric, with no offset"], - ["2000-05-02T15:23[!+00:00]", "numeric, with ! and no offset"], - ["2000-05-02T15:23+00:00[America/New_York]", "named, with offset"], - ["2000-05-02T15:23+00:00[!UTC]", "named, with offset and !"], - ["2000-05-02T15:23+00:00[+01:00]", "numeric, with offset"], - ["2000-05-02T15:23+00:00[!-08:00]", "numeric, with offset and !"], -]; - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -tests.forEach(([arg, description]) => { - const result = instance.toPlainDateTime(arg); - - TemporalHelpers.assertPlainDateTime( - result, - 2000, 5, "M05", 2, 12, 34, 56, 987, 654, 321, - `time zone annotation (${description})` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-unknown-annotation.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-unknown-annotation.js deleted file mode 100644 index e881419758..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-unknown-annotation.js +++ /dev/null @@ -1,30 +0,0 @@ -// 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.prototype.toplaindatetime -description: Various forms of unknown annotation -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -const tests = [ - ["2000-05-02[foo=bar]", "without time"], - ["2000-05-02T15:23[foo=bar]", "alone"], - ["2000-05-02T15:23[UTC][foo=bar]", "with time zone"], - ["2000-05-02T15:23[u-ca=iso8601][foo=bar]", "with calendar"], - ["2000-05-02T15:23[UTC][foo=bar][u-ca=iso8601]", "with time zone and calendar"], - ["2000-05-02T15:23[foo=bar][_foo-bar0=Ignore-This-999999999999]", "with another unknown annotation"], -]; - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -tests.forEach(([arg, description]) => { - const result = instance.toPlainDateTime(arg); - - TemporalHelpers.assertPlainDateTime( - result, - 2000, 5, "M05", 2, 12, 34, 56, 987, 654, 321, - `unknown annotation (${description})` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-with-utc-designator.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-with-utc-designator.js deleted file mode 100644 index eae48d0ee2..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-string-with-utc-designator.js +++ /dev/null @@ -1,21 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: RangeError thrown if a string with UTC designator is used as a PlainDate -features: [Temporal, arrow-function] ----*/ - -const invalidStrings = [ - "2019-10-01T09:00:00Z", - "2019-10-01T09:00:00Z[UTC]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((arg) => { - assert.throws( - RangeError, - () => instance.toPlainDateTime(arg), - "String with UTC designator should not be valid as a PlainDate" - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-wrong-type.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-wrong-type.js deleted file mode 100644 index 913093c44d..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-wrong-type.js +++ /dev/null @@ -1,40 +0,0 @@ -// 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.prototype.toplaindatetime -description: > - Appropriate error thrown when argument cannot be converted to a valid string - or property bag for PlainDate -features: [BigInt, Symbol, Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const primitiveTests = [ - [undefined, "undefined"], - [null, "null"], - [true, "boolean"], - ["", "empty string"], - [1, "number that doesn't convert to a valid ISO string"], - [1n, "bigint"], -]; - -for (const [arg, description] of primitiveTests) { - assert.throws( - typeof arg === 'string' ? RangeError : TypeError, - () => instance.toPlainDateTime(arg), - `${description} does not convert to a valid ISO string` - ); -} - -const typeErrorTests = [ - [Symbol(), "symbol"], - [{}, "plain object"], - [Temporal.PlainDate, "Temporal.PlainDate, object"], - [Temporal.PlainDate.prototype, "Temporal.PlainDate.prototype, object"], -]; - -for (const [arg, description] of typeErrorTests) { - assert.throws(TypeError, () => instance.toPlainDateTime(arg), `${description} is not a valid property bag and does not convert to a string`); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-convert.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-convert.js deleted file mode 100644 index 3aad3b6aa4..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-convert.js +++ /dev/null @@ -1,19 +0,0 @@ -// 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.prototype.toplaindatetime -description: An exception from TimeZone#getOffsetNanosecondsFor() is propagated. -features: [Temporal] ----*/ - -class TZ extends Temporal.TimeZone { - constructor() { super("UTC") } - getOffsetNanosecondsFor() { throw new Test262Error() } -} - -const tz = new TZ(); -const arg = new Temporal.ZonedDateTime(0n, tz); -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -assert.throws(Test262Error, () => instance.toPlainDateTime(arg)); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-slots.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-slots.js deleted file mode 100644 index 29ab87384c..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-slots.js +++ /dev/null @@ -1,37 +0,0 @@ -// 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.prototype.toplaindatetime -description: Getters are not called when converting a ZonedDateTime to a PlainDate. -includes: [compareArray.js] -features: [Temporal] ----*/ - -const actual = []; -const prototypeDescrs = Object.getOwnPropertyDescriptors(Temporal.ZonedDateTime.prototype); -const getters = ["year", "month", "monthCode", "day", "hour", "minute", "second", "millisecond", "microsecond", "nanosecond", "calendar"]; - -for (const property of getters) { - Object.defineProperty(Temporal.ZonedDateTime.prototype, property, { - get() { - actual.push(`get ${property}`); - const value = prototypeDescrs[property].get.call(this); - return { - toString() { - actual.push(`toString ${property}`); - return value.toString(); - }, - valueOf() { - actual.push(`valueOf ${property}`); - return value; - }, - }; - }, - }); -} - -const arg = new Temporal.ZonedDateTime(0n, "UTC"); -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -instance.toPlainDateTime(arg); -assert.compareArray(actual, []); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-non-integer.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-non-integer.js deleted file mode 100644 index 0ca2efd3bd..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-non-integer.js +++ /dev/null @@ -1,16 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: RangeError thrown if time zone reports an offset that is not an integer number of nanoseconds -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -[3600_000_000_000.5, NaN, -Infinity, Infinity].forEach((wrongOffset) => { - const timeZone = TemporalHelpers.specificOffsetTimeZone(wrongOffset); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const datetime = new Temporal.ZonedDateTime(1_000_000_000_987_654_321n, timeZone); - assert.throws(RangeError, () => time.toPlainDateTime(datetime)); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-not-callable.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-not-callable.js deleted file mode 100644 index b424d28c23..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-not-callable.js +++ /dev/null @@ -1,20 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: TypeError thrown if timeZone.getOffsetNanosecondsFor is not callable -features: [BigInt, Symbol, Temporal, arrow-function] ----*/ - -[undefined, null, true, Math.PI, 'string', Symbol('sym'), 42n, {}].forEach((notCallable) => { - const timeZone = new Temporal.TimeZone("UTC"); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const datetime = new Temporal.ZonedDateTime(1_000_000_000_987_654_321n, timeZone); - timeZone.getOffsetNanosecondsFor = notCallable; - assert.throws( - TypeError, - () => time.toPlainDateTime(datetime), - `Uncallable ${notCallable === null ? 'null' : typeof notCallable} getOffsetNanosecondsFor should throw TypeError` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-out-of-range.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-out-of-range.js deleted file mode 100644 index 1de8ae240b..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-out-of-range.js +++ /dev/null @@ -1,16 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: RangeError thrown if time zone reports an offset that is out of range -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -[-86400_000_000_000, 86400_000_000_000].forEach((wrongOffset) => { - const timeZone = TemporalHelpers.specificOffsetTimeZone(wrongOffset); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const datetime = new Temporal.ZonedDateTime(1_000_000_000_987_654_321n, timeZone); - assert.throws(RangeError, () => time.toPlainDateTime(datetime)); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-wrong-type.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-wrong-type.js deleted file mode 100644 index 99bde536c2..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-wrong-type.js +++ /dev/null @@ -1,25 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: TypeError thrown if time zone reports an offset that is not a Number -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -[ - undefined, - null, - true, - "+01:00", - Symbol(), - 3600_000_000_000n, - {}, - { valueOf() { return 3600_000_000_000; } }, -].forEach((wrongOffset) => { - const timeZone = TemporalHelpers.specificOffsetTimeZone(wrongOffset); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const datetime = new Temporal.ZonedDateTime(1_000_000_000_987_654_321n, timeZone); - assert.throws(TypeError, () => time.toPlainDateTime(datetime)); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/basic.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/basic.js deleted file mode 100644 index 500a3e891f..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/basic.js +++ /dev/null @@ -1,22 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.toplaindatetime -description: Basic tests for toPlainDateTime(). -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -const plainTime = Temporal.PlainTime.from("11:30:23.123456789"); - -const plainDate = plainTime.toPlainDateTime(Temporal.PlainDate.from("1976-11-18")); -TemporalHelpers.assertPlainDateTime(plainDate, 1976, 11, "M11", 18, 11, 30, 23, 123, 456, 789, "PlainDate"); - -const optionBag = plainTime.toPlainDateTime({ year: 1976, month: 11, day: 18 }); -TemporalHelpers.assertPlainDateTime(optionBag, 1976, 11, "M11", 18, 11, 30, 23, 123, 456, 789, "option bag"); - -const string = plainTime.toPlainDateTime("1976-11-18"); -TemporalHelpers.assertPlainDateTime(string, 1976, 11, "M11", 18, 11, 30, 23, 123, 456, 789, "string"); - -assert.throws(TypeError, () => plainTime.toPlainDateTime({ year: 1976 }), "missing properties"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/branding.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/branding.js deleted file mode 100644 index 55c91392b5..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/branding.js +++ /dev/null @@ -1,24 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: Throw a TypeError if the receiver is invalid -features: [Symbol, Temporal] ----*/ - -const toPlainDateTime = Temporal.PlainTime.prototype.toPlainDateTime; - -assert.sameValue(typeof toPlainDateTime, "function"); - -const args = [new Temporal.PlainDate(2022, 6, 22)]; - -assert.throws(TypeError, () => toPlainDateTime.apply(undefined, args), "undefined"); -assert.throws(TypeError, () => toPlainDateTime.apply(null, args), "null"); -assert.throws(TypeError, () => toPlainDateTime.apply(true, args), "true"); -assert.throws(TypeError, () => toPlainDateTime.apply("", args), "empty string"); -assert.throws(TypeError, () => toPlainDateTime.apply(Symbol(), args), "symbol"); -assert.throws(TypeError, () => toPlainDateTime.apply(1, args), "1"); -assert.throws(TypeError, () => toPlainDateTime.apply({}, args), "plain object"); -assert.throws(TypeError, () => toPlainDateTime.apply(Temporal.PlainTime, args), "Temporal.PlainTime"); -assert.throws(TypeError, () => toPlainDateTime.apply(Temporal.PlainTime.prototype, args), "Temporal.PlainTime.prototype"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/builtin.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/builtin.js deleted file mode 100644 index 25f4d61902..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/builtin.js +++ /dev/null @@ -1,33 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: > - Tests that Temporal.PlainTime.prototype.toPlainDateTime - meets the requirements for built-in objects defined by the - introduction of chapter 17 of the ECMAScript Language Specification. -info: | - Built-in functions that are not constructors do not have a "prototype" property unless - otherwise specified in the description of a particular function. - - Unless specified otherwise, a built-in object that is callable as a function is a built-in - function object with the characteristics described in 10.3. Unless specified otherwise, the - [[Extensible]] internal slot of a built-in object initially has the value true. - - Unless otherwise specified every built-in function and every built-in constructor has the - Function prototype object [...] as the value of its [[Prototype]] internal slot. -features: [Temporal] ----*/ - -assert.sameValue(Object.isExtensible(Temporal.PlainTime.prototype.toPlainDateTime), - true, "Built-in objects must be extensible."); - -assert.sameValue(Object.prototype.toString.call(Temporal.PlainTime.prototype.toPlainDateTime), - "[object Function]", "Object.prototype.toString"); - -assert.sameValue(Object.getPrototypeOf(Temporal.PlainTime.prototype.toPlainDateTime), - Function.prototype, "prototype"); - -assert.sameValue(Temporal.PlainTime.prototype.toPlainDateTime.hasOwnProperty("prototype"), - false, "prototype property"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-datefromfields-called-with-options-undefined.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-datefromfields-called-with-options-undefined.js deleted file mode 100644 index 5a594f23a4..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-datefromfields-called-with-options-undefined.js +++ /dev/null @@ -1,16 +0,0 @@ -// 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.prototype.toplaindatetime -description: > - Calendar.dateFromFields method is called with undefined as the options value - when call originates internally -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const calendar = TemporalHelpers.calendarFromFieldsUndefinedOptions(); -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321, calendar); -instance.toPlainDateTime({ year: 2000, month: 5, day: 3, calendar }); -assert.sameValue(calendar.dateFromFieldsCallCount, 1); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-fields-iterable.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-fields-iterable.js deleted file mode 100644 index b7f5e7bee7..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-fields-iterable.js +++ /dev/null @@ -1,31 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: Verify the result of calendar.fields() is treated correctly. -info: | - sec-temporal.plaintime.prototype.toplaindatetime step 3: - 3. Set _temporalDate_ to ? ToTemporalDate(_temporalDate_). - sec-temporal-totemporaldate step 2.c: - c. Let _fieldNames_ be ? CalendarFields(_calendar_, « *"day"*, *"month"*, *"monthCode"*, *"year"* »). - sec-temporal-calendarfields step 4: - 4. Let _result_ be ? IterableToList(_fieldsArray_). -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -const expected = [ - "day", - "month", - "monthCode", - "year", -]; - -const time = new Temporal.PlainTime(13, 3); -const calendar = TemporalHelpers.calendarFieldsIterable(); -time.toPlainDateTime({ year: 2000, month: 5, day: 3, calendar }); - -assert.sameValue(calendar.fieldsCallCount, 1, "fields() method called once"); -assert.compareArray(calendar.fieldsCalledWith[0], expected, "fields() method called with correct args"); -assert(calendar.iteratorExhausted[0], "iterated through the whole iterable"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-temporal-object.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-temporal-object.js deleted file mode 100644 index 97146e9264..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/calendar-temporal-object.js +++ /dev/null @@ -1,27 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: Fast path for converting other Temporal objects to Temporal.Calendar by reading internal slots -info: | - sec-temporal.plaintime.prototype.toplaindatetime step 3: - 3. Set _temporalDate_ to ? ToTemporalDate(_temporalDate_). - sec-temporal-totemporaldate step 2.c: - c. Let _calendar_ be ? GetTemporalCalendarWithISODefault(_item_). - sec-temporal-gettemporalcalendarwithisodefault step 2: - 2. Return ? ToTemporalCalendarWithISODefault(_calendar_). - sec-temporal-totemporalcalendarwithisodefault step 2: - 3. Return ? ToTemporalCalendar(_temporalCalendarLike_). - sec-temporal-totemporalcalendar step 1.a: - a. If _temporalCalendarLike_ has an [[InitializedTemporalDate]], [[InitializedTemporalDateTime]], [[InitializedTemporalMonthDay]], [[InitializedTemporalYearMonth]], or [[InitializedTemporalZonedDateTime]] internal slot, then - i. Return _temporalCalendarLike_.[[Calendar]]. -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -TemporalHelpers.checkToTemporalCalendarFastPath((temporalObject, calendar) => { - const time = new Temporal.PlainTime(13, 3); - const result = time.toPlainDateTime({ year: 2000, month: 5, day: 3, calendar: temporalObject }); - assert.sameValue(result.getCalendar(), calendar, "Temporal object coerced to calendar"); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/infinity-throws-rangeerror.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/infinity-throws-rangeerror.js deleted file mode 100644 index 95ed40d0ee..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/infinity-throws-rangeerror.js +++ /dev/null @@ -1,23 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -description: Throws if any value in the property bag is Infinity or -Infinity -esid: sec-temporal.plaintime.prototype.toplaindatetime -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(15); -const base = { year: 2000, month: 5, day: 2 }; - -[Infinity, -Infinity].forEach((inf) => { - ["year", "month", "day"].forEach((prop) => { - assert.throws(RangeError, () => instance.toPlainDateTime({ ...base, [prop]: inf }), `${prop} property cannot be ${inf}`); - - const calls = []; - const obj = TemporalHelpers.toPrimitiveObserver(calls, inf, prop); - assert.throws(RangeError, () => instance.toPlainDateTime({ ...base, [prop]: obj })); - assert.compareArray(calls, [`get ${prop}.valueOf`, `call ${prop}.valueOf`], "it fails after fetching the primitive value"); - }); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/length.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/length.js deleted file mode 100644 index 151a4b4259..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/length.js +++ /dev/null @@ -1,25 +0,0 @@ -// Copyright (C) 2020 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: Temporal.PlainTime.prototype.toPlainDateTime.length is 1 -info: | - Every built-in function object, including constructors, has a "length" property whose value is - an integer. Unless otherwise specified, this value is equal to the largest number of named - arguments shown in the subclause headings for the function description. Optional parameters - (which are indicated with brackets: [ ]) or rest parameters (which are shown using the form - «...name») are not included in the default argument count. - - Unless otherwise specified, the "length" property of a built-in function object has the - attributes { [[Writable]]: false, [[Enumerable]]: false, [[Configurable]]: true }. -includes: [propertyHelper.js] -features: [Temporal] ----*/ - -verifyProperty(Temporal.PlainTime.prototype.toPlainDateTime, "length", { - value: 1, - writable: false, - enumerable: false, - configurable: true, -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/limits.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/limits.js deleted file mode 100644 index fcde863d64..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/limits.js +++ /dev/null @@ -1,39 +0,0 @@ -// 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.prototype.toplaindatetime -description: Checking limits of representable PlainDateTime -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -const midnight = new Temporal.PlainTime(0, 0); -const firstNs = new Temporal.PlainTime(0, 0, 0, 0, 0, 1); -const lastNs = new Temporal.PlainTime(23, 59, 59, 999, 999, 999); -const min = new Temporal.PlainDate(-271821, 4, 19); -const max = new Temporal.PlainDate(275760, 9, 13); - -assert.throws( - RangeError, - () => midnight.toPlainDateTime(min), - "Cannot go below representable limit" -); - -TemporalHelpers.assertPlainDateTime( - midnight.toPlainDateTime(max), - 275760, 9, "M09", 13, 0, 0, 0, 0, 0, 0, - "Midnight of maximum representable PlainDate" -); - -TemporalHelpers.assertPlainDateTime( - firstNs.toPlainDateTime(min), - -271821, 4, "M04", 19, 0, 0, 0, 0, 0, 1, - "Computing the minimum (earliest) representable PlainDateTime" -); - -TemporalHelpers.assertPlainDateTime( - lastNs.toPlainDateTime(max), - 275760, 9, "M09", 13, 23, 59, 59, 999, 999, 999, - "Computing the maximum (latest) representable PlainDateTime" -); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/name.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/name.js deleted file mode 100644 index 0096b44aff..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/name.js +++ /dev/null @@ -1,23 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: Temporal.PlainTime.prototype.toPlainDateTime.name is "toPlainDateTime". -info: | - Every built-in function object, including constructors, that is not identified as an anonymous - function has a "name" property whose value is a String. Unless otherwise specified, this value - is the name that is given to the function in this specification. - - Unless otherwise specified, the "name" property of a built-in function object, if it exists, - has the attributes { [[Writable]]: false, [[Enumerable]]: false, [[Configurable]]: true }. -includes: [propertyHelper.js] -features: [Temporal] ----*/ - -verifyProperty(Temporal.PlainTime.prototype.toPlainDateTime, "name", { - value: "toPlainDateTime", - writable: false, - enumerable: false, - configurable: true, -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/not-a-constructor.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/not-a-constructor.js deleted file mode 100644 index e6ccf089c8..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/not-a-constructor.js +++ /dev/null @@ -1,21 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: > - Temporal.PlainTime.prototype.toPlainDateTime does not implement [[Construct]], is not new-able -info: | - Built-in function objects that are not identified as constructors do not implement the - [[Construct]] internal method unless otherwise specified in the description of a particular - function. -includes: [isConstructor.js] -features: [Reflect.construct, Temporal] ----*/ - -assert.throws(TypeError, () => { - new Temporal.PlainTime.prototype.toPlainDateTime(); -}, "Calling as constructor"); - -assert.sameValue(isConstructor(Temporal.PlainTime.prototype.toPlainDateTime), false, - "isConstructor(Temporal.PlainTime.prototype.toPlainDateTime)"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/prop-desc.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/prop-desc.js deleted file mode 100644 index 6258633f33..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/prop-desc.js +++ /dev/null @@ -1,21 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.toplaindatetime -description: The "toPlainDateTime" property of Temporal.PlainTime.prototype -includes: [propertyHelper.js] -features: [Temporal] ----*/ - -assert.sameValue( - typeof Temporal.PlainTime.prototype.toPlainDateTime, - "function", - "`typeof PlainTime.prototype.toPlainDateTime` is `function`" -); - -verifyProperty(Temporal.PlainTime.prototype, "toPlainDateTime", { - writable: true, - enumerable: false, - configurable: true, -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/year-zero.js b/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/year-zero.js deleted file mode 100644 index e08a6d0305..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toPlainDateTime/year-zero.js +++ /dev/null @@ -1,23 +0,0 @@ -// 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.prototype.toplaindatetime -description: Negative zero, as an extended year, is rejected -features: [Temporal, arrow-function] ----*/ - -const invalidStrings = [ - "-000000-10-31", - "-000000-10-31T00:45", - "-000000-10-31T00:45+01:00", - "-000000-10-31T00:45+00:00[UTC]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((arg) => { - assert.throws( - RangeError, - () => instance.toPlainDateTime(arg), - "reject minus zero as extended year" - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-builtin-calendar-no-array-iteration.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-builtin-calendar-no-array-iteration.js deleted file mode 100644 index 27b29d272c..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-builtin-calendar-no-array-iteration.js +++ /dev/null @@ -1,21 +0,0 @@ -// 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.plaintime.prototype.tozoneddatetime -description: > - Calling the method with a property bag argument with a builtin calendar causes - no observable array iteration when getting the calendar fields. -features: [Temporal] ----*/ - -const arrayPrototypeSymbolIteratorOriginal = Array.prototype[Symbol.iterator]; -Array.prototype[Symbol.iterator] = function arrayIterator() { - throw new Test262Error("Array should not be iterated"); -} - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -const arg = { year: 2000, month: 5, day: 2, calendar: "iso8601" }; -instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); - -Array.prototype[Symbol.iterator] = arrayPrototypeSymbolIteratorOriginal; diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-calendar-datefromfields-called-with-null-prototype-fields.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-calendar-datefromfields-called-with-null-prototype-fields.js deleted file mode 100644 index 7075d69c23..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-calendar-datefromfields-called-with-null-prototype-fields.js +++ /dev/null @@ -1,16 +0,0 @@ -// 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.prototype.tozoneddatetime -description: > - Calendar.dateFromFields method is called with a null-prototype fields object -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const calendar = TemporalHelpers.calendarCheckFieldsPrototypePollution(); -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -const arg = { year: 2000, month: 5, day: 2, calendar }; -instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); -assert.sameValue(calendar.dateFromFieldsCallCount, 1, "dateFromFields should be called on the property bag's calendar"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-constructor-in-calendar-fields.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-constructor-in-calendar-fields.js deleted file mode 100644 index cbae8d4bdc..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-constructor-in-calendar-fields.js +++ /dev/null @@ -1,14 +0,0 @@ -// 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.plaintime.prototype.tozoneddatetime -description: If a calendar's fields() method returns a field named 'constructor', PrepareTemporalFields should throw a RangeError. -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const calendar = TemporalHelpers.calendarWithExtraFields(['constructor']); -const arg = {year: 2023, month: 5, monthCode: 'M05', day: 1, calendar: calendar}; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -assert.throws(RangeError, () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" })); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-duplicate-calendar-fields.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-duplicate-calendar-fields.js deleted file mode 100644 index 5485aea3ab..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-duplicate-calendar-fields.js +++ /dev/null @@ -1,16 +0,0 @@ -// 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.plaintime.prototype.tozoneddatetime -description: If a calendar's fields() method returns duplicate field names, PrepareTemporalFields should throw a RangeError. -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -for (const extra_fields of [['foo', 'foo'], ['day'], ['month'], ['monthCode'], ['year']]) { - const calendar = TemporalHelpers.calendarWithExtraFields(extra_fields); - const arg = { year: 2023, month: 5, monthCode: 'M05', day: 1, calendar: calendar }; - const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - - assert.throws(RangeError, () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" })); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-leap-second.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-leap-second.js deleted file mode 100644 index b882057429..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-leap-second.js +++ /dev/null @@ -1,26 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Leap second is a valid ISO string for PlainDate -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -let arg = "2016-12-31T23:59:60"; -const result1 = instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); -assert.sameValue( - result1.epochNanoseconds, - 1_483_187_696_987_654_321n, - "leap second is a valid ISO string for PlainDate" -); - -arg = { year: 2016, month: 12, day: 31, hour: 23, minute: 59, second: 60 }; -const result2 = instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); -assert.sameValue( - result2.epochNanoseconds, - 1_483_187_696_987_654_321n, - "second: 60 is ignored in property bag for PlainDate" -); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-number.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-number.js deleted file mode 100644 index 073eda26cd..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-number.js +++ /dev/null @@ -1,25 +0,0 @@ -// 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.prototype.tozoneddatetime -description: A number cannot be used in place of a Temporal.PlainDate -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const numbers = [ - 1, - 19761118, - -19761118, - 1234567890, -]; - -for (const arg of numbers) { - assert.throws( - TypeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - 'Numbers cannot be used in place of an ISO string for PlainDate' - ); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-plaindatetime.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-plaindatetime.js deleted file mode 100644 index fafd121de4..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-plaindatetime.js +++ /dev/null @@ -1,29 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.tozoneddatetime -description: Fast path for converting Temporal.PlainDateTime to Temporal.PlainDate by reading internal slots -info: | - sec-temporal.plaintime.prototype.tozoneddatetime step 5: - 5. Let _temporalDate_ be ? ToTemporalDate(_temporalDateLike_). - sec-temporal-totemporaldate step 2.b: - b. If _item_ has an [[InitializedTemporalDateTime]] internal slot, then - i. Return ! CreateTemporalDate(_item_.[[ISOYear]], _item_.[[ISOMonth]], _item_.[[ISODay]], _item_.[[Calendar]]). -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -TemporalHelpers.checkPlainDateTimeConversionFastPath((datetime) => { - const time = new Temporal.PlainTime(6, 54, 32, 123, 456, 789); - const result = time.toZonedDateTime({ plainDate: datetime, timeZone: "UTC" }); - assert.sameValue(result.year, 2000, "year result"); - assert.sameValue(result.month, 5, "month result"); - assert.sameValue(result.day, 2, "day result"); - assert.sameValue(result.hour, 6, "hour result"); - assert.sameValue(result.minute, 54, "minute result"); - assert.sameValue(result.second, 32, "second result"); - assert.sameValue(result.millisecond, 123, "millisecond result"); - assert.sameValue(result.microsecond, 456, "microsecond result"); - assert.sameValue(result.nanosecond, 789, "nanosecond result"); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-primitive.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-primitive.js deleted file mode 100644 index 9cef2cdeff..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-primitive.js +++ /dev/null @@ -1,23 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.tozoneddatetime -description: TypeError thrown if a primitive is passed as the argument -info: | - Temporal.PlainTime.prototype.toZonedDateTime ( item ) - - 3. If Type(item) is not Object, then - a. Throw a TypeError exception. -features: [Symbol, Temporal] ----*/ - -const instance = Temporal.PlainTime.from("00:00"); - -assert.throws(TypeError, () => instance.toZonedDateTime(undefined), "undefined"); -assert.throws(TypeError, () => instance.toZonedDateTime(null), "null"); -assert.throws(TypeError, () => instance.toZonedDateTime(true), "true"); -assert.throws(TypeError, () => instance.toZonedDateTime(""), "empty string"); -assert.throws(TypeError, () => instance.toZonedDateTime(Symbol()), "symbol"); -assert.throws(TypeError, () => instance.toZonedDateTime(1), "1"); -assert.throws(TypeError, () => instance.toZonedDateTime(1n), "1n"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-case-insensitive.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-case-insensitive.js deleted file mode 100644 index d9565e0d59..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-case-insensitive.js +++ /dev/null @@ -1,16 +0,0 @@ -// 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.prototype.tozoneddatetime -description: The calendar name is case-insensitive -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const calendar = "IsO8601"; - -const arg = { year: 1976, monthCode: "M11", day: 18, calendar }; -const result = instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); -assert.sameValue(result.epochNanoseconds, 217_168_496_987_654_321n, "Calendar is case-insensitive"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-iso-string.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-iso-string.js deleted file mode 100644 index 61f5112e54..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-iso-string.js +++ /dev/null @@ -1,25 +0,0 @@ -// Copyright (C) 2024 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: An ISO 8601 string can be converted to a calendar ID in Calendar -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -for (const calendar of [ - "2020-01-01", - "2020-01-01[u-ca=iso8601]", - "2020-01-01T00:00:00.000000000", - "2020-01-01T00:00:00.000000000[u-ca=iso8601]", - "01-01", - "01-01[u-ca=iso8601]", - "2020-01", - "2020-01[u-ca=iso8601]", -]) { - const arg = { year: 1976, monthCode: "M11", day: 18, calendar }; - const result = instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); - assert.sameValue(result.epochNanoseconds, 217_168_496_987_654_321n, `Calendar created from string "${calendar}"`); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-leap-second.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-leap-second.js deleted file mode 100644 index ad0bda9c19..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-leap-second.js +++ /dev/null @@ -1,20 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Leap second is a valid ISO string for a calendar in a property bag -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const calendar = "2016-12-31T23:59:60"; - -const arg = { year: 1976, monthCode: "M11", day: 18, calendar }; -const result = instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); -assert.sameValue( - result.epochNanoseconds, - 217_168_496_987_654_321n, - "leap second is a valid ISO string for calendar" -); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-number.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-number.js deleted file mode 100644 index 7c47cd3918..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-number.js +++ /dev/null @@ -1,26 +0,0 @@ -// 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.prototype.tozoneddatetime -description: A number as calendar in a property bag is not accepted -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const numbers = [ - 1, - 19970327, - -19970327, - 1234567890, -]; - -for (const calendar of numbers) { - const arg = { year: 1976, monthCode: "M11", day: 18, calendar }; - assert.throws( - TypeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - "Numbers cannot be used as a calendar" - ); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-string.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-string.js deleted file mode 100644 index 1180aadc8b..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-string.js +++ /dev/null @@ -1,16 +0,0 @@ -// 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.prototype.tozoneddatetime -description: A calendar ID is valid input for Calendar -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const calendar = "iso8601"; - -const arg = { year: 1976, monthCode: "M11", day: 18, calendar }; -const result = instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); -assert.sameValue(result.epochNanoseconds, 217_168_496_987_654_321n, `Calendar created from string "${calendar}"`); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-wrong-type.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-wrong-type.js deleted file mode 100644 index 310fb0569c..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-wrong-type.js +++ /dev/null @@ -1,43 +0,0 @@ -// 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.prototype.tozoneddatetime -description: > - Appropriate error thrown when a calendar property from a property bag cannot - be converted to a calendar object or string -features: [BigInt, Symbol, Temporal] ----*/ - -const timeZone = new Temporal.TimeZone("UTC"); -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const primitiveTests = [ - [null, "null"], - [true, "boolean"], - ["", "empty string"], - [1, "number that doesn't convert to a valid ISO string"], - [1n, "bigint"], -]; - -for (const [calendar, description] of primitiveTests) { - const arg = { year: 2019, monthCode: "M11", day: 1, calendar }; - assert.throws( - typeof calendar === 'string' ? RangeError : TypeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - `${description} does not convert to a valid ISO string` - ); -} - -const typeErrorTests = [ - [Symbol(), "symbol"], - [{}, "plain object that doesn't implement the protocol"], - [new Temporal.TimeZone("UTC"), "time zone instance"], - [Temporal.Calendar, "Temporal.Calendar, object"], - [Temporal.Calendar.prototype, "Temporal.Calendar.prototype, object"], // fails brand check in dateFromFields() -]; - -for (const [calendar, description] of typeErrorTests) { - const arg = { year: 2019, monthCode: "M11", day: 1, calendar }; - assert.throws(TypeError, () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), `${description} is not a valid property bag and does not convert to a string`); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-year-zero.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-year-zero.js deleted file mode 100644 index 48e03d27ac..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-calendar-year-zero.js +++ /dev/null @@ -1,25 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Negative zero, as an extended year, is rejected -features: [Temporal, arrow-function] ----*/ - -const invalidStrings = [ - "-000000-10-31", - "-000000-10-31T17:45", - "-000000-10-31T17:45Z", - "-000000-10-31T17:45+01:00", - "-000000-10-31T17:45+00:00[UTC]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((str) => { - const arg = { year: 1976, month: 11, day: 18, calendar: str }; - assert.throws( - RangeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - "reject minus zero as extended year" - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-missing-properties.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-missing-properties.js deleted file mode 100644 index 7fea34546c..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-propertybag-missing-properties.js +++ /dev/null @@ -1,22 +0,0 @@ -// 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.tozoneddatetime -description: Both plainDate and timeZone properties need to not be undefined. -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(); -const plainDate = new Temporal.PlainDate(2022, 5, 19); -const timeZone = new Temporal.TimeZone("UTC"); -assert.throws(TypeError, () => instance.toZonedDateTime({}), - "no properties"); -assert.throws(TypeError, () => instance.toZonedDateTime({ plainDate }), - "only plainDate"); -assert.throws(TypeError, () => instance.toZonedDateTime({ plainDate, timeZone: undefined }), - "timeZone explicitly undefined"); -assert.throws(TypeError, () => instance.toZonedDateTime({ timeZone }), - "only timeZone"); -assert.throws(TypeError, () => instance.toZonedDateTime({ plainDate: undefined, timeZone }), - "plainDate explicitly undefined"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-proto-in-calendar-fields.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-proto-in-calendar-fields.js deleted file mode 100644 index fc7dbc35e7..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-proto-in-calendar-fields.js +++ /dev/null @@ -1,14 +0,0 @@ -// 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.plaintime.prototype.tozoneddatetime -description: If a calendar's fields() method returns a field named '__proto__', PrepareTemporalFields should throw a RangeError. -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const calendar = TemporalHelpers.calendarWithExtraFields(['__proto__']); -const arg = {year: 2023, month: 5, monthCode: 'M05', day: 1, calendar: calendar}; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -assert.throws(RangeError, () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" })); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-calendar-annotation-invalid-key.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-calendar-annotation-invalid-key.js deleted file mode 100644 index ca20c7806e..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-calendar-annotation-invalid-key.js +++ /dev/null @@ -1,22 +0,0 @@ -// Copyright (C) 2024 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: Annotation keys are lowercase-only -features: [Temporal] ----*/ - -const invalidStrings = [ - ["1970-01-01[U-CA=iso8601]", "invalid capitalized key"], - ["1970-01-01[u-CA=iso8601]", "invalid partially-capitalized key"], - ["1970-01-01[FOO=bar]", "invalid capitalized unrecognized key"], -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach(([arg, descr]) => { - assert.throws( - RangeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - `annotation keys must be lowercase: ${arg} - ${descr}` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-calendar-annotation.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-calendar-annotation.js deleted file mode 100644 index 028035f122..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-calendar-annotation.js +++ /dev/null @@ -1,30 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Various forms of calendar annotation; critical flag has no effect -features: [Temporal] ----*/ - -const tests = [ - ["2000-05-02[u-ca=iso8601]", "without time or time zone"], - ["2000-05-02[UTC][u-ca=iso8601]", "with time zone and no time"], - ["2000-05-02T15:23[u-ca=iso8601]", "without time zone"], - ["2000-05-02T15:23[UTC][u-ca=iso8601]", "with time zone"], - ["2000-05-02T15:23[!u-ca=iso8601]", "with ! and no time zone"], - ["2000-05-02T15:23[UTC][!u-ca=iso8601]", "with ! and time zone"], - ["2000-05-02T15:23[u-ca=iso8601][u-ca=discord]", "second annotation ignored"], -]; - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -tests.forEach(([arg, description]) => { - const result = instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); - - assert.sameValue( - result.epochNanoseconds, - 957_270_896_987_654_321n, - `calendar annotation (${description})` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-critical-unknown-annotation.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-critical-unknown-annotation.js deleted file mode 100644 index 243bedfad1..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-critical-unknown-annotation.js +++ /dev/null @@ -1,25 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Unknown annotations with critical flag are rejected -features: [Temporal] ----*/ - -const invalidStrings = [ - "1970-01-01[!foo=bar]", - "1970-01-01T00:00[!foo=bar]", - "1970-01-01T00:00[UTC][!foo=bar]", - "1970-01-01T00:00[u-ca=iso8601][!foo=bar]", - "1970-01-01T00:00[UTC][!foo=bar][u-ca=iso8601]", - "1970-01-01T00:00[foo=bar][!_foo-bar0=Dont-Ignore-This-99999999999]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((arg) => { - assert.throws( - RangeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - `reject unknown annotation with critical flag: ${arg}` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-date-with-utc-offset.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-date-with-utc-offset.js deleted file mode 100644 index 24266beb1c..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-date-with-utc-offset.js +++ /dev/null @@ -1,45 +0,0 @@ -// 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.prototype.tozoneddatetime -description: UTC offset not valid with format that does not include a time -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const validStrings = [ - "2000-05-02T00+00:00", - "2000-05-02T00+00:00[UTC]", - "2000-05-02T00+00:00[!UTC]", - "2000-05-02T00-02:30[America/St_Johns]", -]; - -for (const arg of validStrings) { - const result = instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); - - assert.sameValue( - result.epochNanoseconds, - 957_270_896_987_654_321n, - `"${arg}" is a valid UTC offset with time for PlainDate` - ); -} - -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, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - `"${arg}" UTC offset without time is not valid for PlainDate` - ); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-invalid.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-invalid.js deleted file mode 100644 index 7eee26a343..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-invalid.js +++ /dev/null @@ -1,61 +0,0 @@ -// 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.prototype.tozoneddatetime -description: > - RangeError thrown if an invalid ISO string (or syntactically valid ISO string - that is not supported) is used as a PlainDate -features: [Temporal, arrow-function] ----*/ - -const invalidStrings = [ - // invalid ISO strings: - "", - "invalid iso8601", - "2020-01-00", - "2020-01-32", - "2020-02-30", - "2021-02-29", - "2020-00-01", - "2020-13-01", - "2020-01-01T", - "2020-01-01T25:00:00", - "2020-01-01T01:60:00", - "2020-01-01T01:60:61", - "2020-01-01junk", - "2020-01-01T00:00:00junk", - "2020-01-01T00:00:00+00:00junk", - "2020-01-01T00:00:00+00:00[UTC]junk", - "2020-01-01T00:00:00+00:00[UTC][u-ca=iso8601]junk", - "02020-01-01", - "2020-001-01", - "2020-01-001", - "2020-01-01T001", - "2020-01-01T01:001", - "2020-01-01T01:01:001", - // valid, but forms not supported in Temporal: - "2020-W01-1", - "2020-001", - "+0002020-01-01", - // valid, but this calendar must not exist: - "2020-01-01[u-ca=notexist]", - // may be valid in other contexts, but insufficient information for PlainDate: - "2020-01", - "+002020-01", - "01-01", - "2020-W01", - "P1Y", - "-P12Y", - // valid, but outside the supported range: - "-999999-01-01", - "+999999-01-01", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -for (const arg of invalidStrings) { - assert.throws( - RangeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - `"${arg}" should not be a valid ISO string for a PlainDate` - ); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-multiple-calendar.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-multiple-calendar.js deleted file mode 100644 index 42894d3285..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-multiple-calendar.js +++ /dev/null @@ -1,29 +0,0 @@ -// 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.plaintime.prototype.tozoneddatetime -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]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((arg) => { - assert.throws( - RangeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - `reject more than one calendar annotation if any critical: ${arg}` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-multiple-time-zone.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-multiple-time-zone.js deleted file mode 100644 index bddfb924ee..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-multiple-time-zone.js +++ /dev/null @@ -1,25 +0,0 @@ -// 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.prototype.tozoneddatetime -description: More than one time zone annotation is not syntactical -features: [Temporal] ----*/ - -const invalidStrings = [ - "1970-01-01[UTC][UTC]", - "1970-01-01T00:00[UTC][UTC]", - "1970-01-01T00:00[!UTC][UTC]", - "1970-01-01T00:00[UTC][!UTC]", - "1970-01-01T00:00[UTC][u-ca=iso8601][UTC]", - "1970-01-01T00:00[UTC][foo=bar][UTC]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((arg) => { - assert.throws( - RangeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - `reject more than one time zone annotation: ${arg}` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-time-separators.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-time-separators.js deleted file mode 100644 index bcc6e52056..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-time-separators.js +++ /dev/null @@ -1,26 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Time separator in string argument can vary -features: [Temporal] ----*/ - -const tests = [ - ["2000-05-02T15:23", "uppercase T"], - ["2000-05-02t15:23", "lowercase T"], - ["2000-05-02 15:23", "space between date and time"], -]; - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -tests.forEach(([arg, description]) => { - const result = instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); - - assert.sameValue( - result.epochNanoseconds, - 957_270_896_987_654_321n, - `variant time separators (${description})` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-time-zone-annotation.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-time-zone-annotation.js deleted file mode 100644 index 5473e64c1a..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-time-zone-annotation.js +++ /dev/null @@ -1,35 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Various forms of time zone annotation; critical flag has no effect -features: [Temporal] ----*/ - -const tests = [ - ["2000-05-02[Asia/Kolkata]", "named, with no time"], - ["2000-05-02[!Europe/Vienna]", "named, with ! and no time"], - ["2000-05-02[+00:00]", "numeric, with no time"], - ["2000-05-02[!-02:30]", "numeric, with ! and no time"], - ["2000-05-02T15:23[America/Sao_Paulo]", "named, with no offset"], - ["2000-05-02T15:23[!Asia/Tokyo]", "named, with ! and no offset"], - ["2000-05-02T15:23[-02:30]", "numeric, with no offset"], - ["2000-05-02T15:23[!+00:00]", "numeric, with ! and no offset"], - ["2000-05-02T15:23+00:00[America/New_York]", "named, with offset"], - ["2000-05-02T15:23+00:00[!UTC]", "named, with offset and !"], - ["2000-05-02T15:23+00:00[+01:00]", "numeric, with offset"], - ["2000-05-02T15:23+00:00[!-08:00]", "numeric, with offset and !"], -]; - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -tests.forEach(([arg, description]) => { - const result = instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); - - assert.sameValue( - result.epochNanoseconds, - 957_270_896_987_654_321n, - `time zone annotation (${description})` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-unknown-annotation.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-unknown-annotation.js deleted file mode 100644 index 2c829f7076..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-unknown-annotation.js +++ /dev/null @@ -1,29 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Various forms of unknown annotation -features: [Temporal] ----*/ - -const tests = [ - ["2000-05-02[foo=bar]", "without time"], - ["2000-05-02T15:23[foo=bar]", "alone"], - ["2000-05-02T15:23[UTC][foo=bar]", "with time zone"], - ["2000-05-02T15:23[u-ca=iso8601][foo=bar]", "with calendar"], - ["2000-05-02T15:23[UTC][foo=bar][u-ca=iso8601]", "with time zone and calendar"], - ["2000-05-02T15:23[foo=bar][_foo-bar0=Ignore-This-999999999999]", "with another unknown annotation"], -]; - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -tests.forEach(([arg, description]) => { - const result = instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); - - assert.sameValue( - result.epochNanoseconds, - 957_270_896_987_654_321n, - `unknown annotation (${description})` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-with-utc-designator.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-with-utc-designator.js deleted file mode 100644 index c02d4f4da6..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-string-with-utc-designator.js +++ /dev/null @@ -1,21 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: RangeError thrown if a string with UTC designator is used as a PlainDate -features: [Temporal, arrow-function] ----*/ - -const invalidStrings = [ - "2019-10-01T09:00:00Z", - "2019-10-01T09:00:00Z[UTC]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((arg) => { - assert.throws( - RangeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - "String with UTC designator should not be valid as a PlainDate" - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-wrong-type.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-wrong-type.js deleted file mode 100644 index aefa92f3af..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-wrong-type.js +++ /dev/null @@ -1,40 +0,0 @@ -// 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.prototype.tozoneddatetime -description: > - Appropriate error thrown when argument cannot be converted to a valid string - or property bag for PlainDate -features: [BigInt, Symbol, Temporal] ----*/ - -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -const primitiveTests = [ - [null, "null"], - [true, "boolean"], - ["", "empty string"], - [1, "number that doesn't convert to a valid ISO string"], - [1n, "bigint"], -]; - -for (const [arg, description] of primitiveTests) { - assert.throws( - typeof arg === 'string' ? RangeError : TypeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - `${description} does not convert to a valid ISO string` - ); -} - -const typeErrorTests = [ - [undefined, "undefined"], // plainDate property is required - [Symbol(), "symbol"], - [{}, "plain object"], - [Temporal.PlainDate, "Temporal.PlainDate, object"], - [Temporal.PlainDate.prototype, "Temporal.PlainDate.prototype, object"], -]; - -for (const [arg, description] of typeErrorTests) { - assert.throws(TypeError, () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), `${description} is not a valid property bag and does not convert to a string`); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-convert.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-convert.js deleted file mode 100644 index 34e609e36c..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-convert.js +++ /dev/null @@ -1,19 +0,0 @@ -// 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.prototype.tozoneddatetime -description: An exception from TimeZone#getOffsetNanosecondsFor() is propagated. -features: [Temporal] ----*/ - -class TZ extends Temporal.TimeZone { - constructor() { super("UTC") } - getOffsetNanosecondsFor() { throw new Test262Error() } -} - -const tz = new TZ(); -const arg = new Temporal.ZonedDateTime(0n, tz); -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - -assert.throws(Test262Error, () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" })); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-slots.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-slots.js deleted file mode 100644 index 9f1421e04f..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-slots.js +++ /dev/null @@ -1,37 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Getters are not called when converting a ZonedDateTime to a PlainDate. -includes: [compareArray.js] -features: [Temporal] ----*/ - -const actual = []; -const prototypeDescrs = Object.getOwnPropertyDescriptors(Temporal.ZonedDateTime.prototype); -const getters = ["year", "month", "monthCode", "day", "hour", "minute", "second", "millisecond", "microsecond", "nanosecond", "calendar"]; - -for (const property of getters) { - Object.defineProperty(Temporal.ZonedDateTime.prototype, property, { - get() { - actual.push(`get ${property}`); - const value = prototypeDescrs[property].get.call(this); - return { - toString() { - actual.push(`toString ${property}`); - return value.toString(); - }, - valueOf() { - actual.push(`valueOf ${property}`); - return value; - }, - }; - }, - }); -} - -const arg = new Temporal.ZonedDateTime(0n, "UTC"); -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }); -assert.compareArray(actual, []); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-non-integer.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-non-integer.js deleted file mode 100644 index 09cba3a722..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-non-integer.js +++ /dev/null @@ -1,16 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: RangeError thrown if time zone reports an offset that is not an integer number of nanoseconds -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -[3600_000_000_000.5, NaN, -Infinity, Infinity].forEach((wrongOffset) => { - const timeZone = TemporalHelpers.specificOffsetTimeZone(wrongOffset); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const datetime = new Temporal.ZonedDateTime(1_000_000_000_987_654_321n, timeZone); - assert.throws(RangeError, () => time.toZonedDateTime({ plainDate: datetime, timeZone: "UTC" })); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-not-callable.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-not-callable.js deleted file mode 100644 index 69a1c6db87..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-not-callable.js +++ /dev/null @@ -1,20 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: TypeError thrown if timeZone.getOffsetNanosecondsFor is not callable -features: [BigInt, Symbol, Temporal, arrow-function] ----*/ - -[undefined, null, true, Math.PI, 'string', Symbol('sym'), 42n, {}].forEach((notCallable) => { - const timeZone = new Temporal.TimeZone("UTC"); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const datetime = new Temporal.ZonedDateTime(1_000_000_000_987_654_321n, timeZone); - timeZone.getOffsetNanosecondsFor = notCallable; - assert.throws( - TypeError, - () => time.toZonedDateTime({ plainDate: datetime, timeZone: "UTC" }), - `Uncallable ${notCallable === null ? 'null' : typeof notCallable} getOffsetNanosecondsFor should throw TypeError` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-out-of-range.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-out-of-range.js deleted file mode 100644 index 005fdab7d8..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-out-of-range.js +++ /dev/null @@ -1,16 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: RangeError thrown if time zone reports an offset that is out of range -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -[-86400_000_000_000, 86400_000_000_000].forEach((wrongOffset) => { - const timeZone = TemporalHelpers.specificOffsetTimeZone(wrongOffset); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const datetime = new Temporal.ZonedDateTime(1_000_000_000_987_654_321n, timeZone); - assert.throws(RangeError, () => time.toZonedDateTime({ plainDate: datetime, timeZone: "UTC" })); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-wrong-type.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-wrong-type.js deleted file mode 100644 index eb8ce9d574..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/argument-zoneddatetime-timezone-getoffsetnanosecondsfor-wrong-type.js +++ /dev/null @@ -1,25 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: TypeError thrown if time zone reports an offset that is not a Number -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -[ - undefined, - null, - true, - "+01:00", - Symbol(), - 3600_000_000_000n, - {}, - { valueOf() { return 3600_000_000_000; } }, -].forEach((wrongOffset) => { - const timeZone = TemporalHelpers.specificOffsetTimeZone(wrongOffset); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const datetime = new Temporal.ZonedDateTime(1_000_000_000_987_654_321n, timeZone); - assert.throws(TypeError, () => time.toZonedDateTime({ plainDate: datetime, timeZone: "UTC" })); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/basic.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/basic.js deleted file mode 100644 index 3b1afd5c8e..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/basic.js +++ /dev/null @@ -1,24 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.tozoneddatetime -description: Basic tests for toZonedDateTime(). -features: [Temporal] ----*/ - -const plainTime = Temporal.PlainTime.from('12:00'); -const plainDate = Temporal.PlainDate.from('2020-07-08'); -const timeZone = Temporal.TimeZone.from('-07:00'); - -const objects = plainTime.toZonedDateTime({ timeZone, plainDate }); -assert.sameValue(objects.epochNanoseconds, 1594234800000000000n, "objects: epochNanoseconds"); -assert.sameValue(objects.getTimeZone(), timeZone, "objects: timeZone"); - -const timeZoneString = plainTime.toZonedDateTime({ timeZone: "-07:00", plainDate }); -assert.sameValue(timeZoneString.epochNanoseconds, 1594234800000000000n, "timeZone string: epochNanoseconds"); -assert.sameValue(timeZoneString.timeZoneId, "-07:00", "timeZone string: timeZone"); - -const plainDateString = plainTime.toZonedDateTime({ timeZone, plainDate: "2020-07-08" }); -assert.sameValue(plainDateString.epochNanoseconds, 1594234800000000000n, "plainDate string: epochNanoseconds"); -assert.sameValue(plainDateString.getTimeZone(), timeZone, "plainDate string: timeZone"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/branding.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/branding.js deleted file mode 100644 index 8da0b7e0c6..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/branding.js +++ /dev/null @@ -1,24 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: Throw a TypeError if the receiver is invalid -features: [Symbol, Temporal] ----*/ - -const toZonedDateTime = Temporal.PlainTime.prototype.toZonedDateTime; - -assert.sameValue(typeof toZonedDateTime, "function"); - -const args = [{ plainDate: "2022-05-19", timeZone: "UTC" }]; - -assert.throws(TypeError, () => toZonedDateTime.apply(undefined, args), "undefined"); -assert.throws(TypeError, () => toZonedDateTime.apply(null, args), "null"); -assert.throws(TypeError, () => toZonedDateTime.apply(true, args), "true"); -assert.throws(TypeError, () => toZonedDateTime.apply("", args), "empty string"); -assert.throws(TypeError, () => toZonedDateTime.apply(Symbol(), args), "symbol"); -assert.throws(TypeError, () => toZonedDateTime.apply(1, args), "1"); -assert.throws(TypeError, () => toZonedDateTime.apply({}, args), "plain object"); -assert.throws(TypeError, () => toZonedDateTime.apply(Temporal.PlainTime, args), "Temporal.PlainTime"); -assert.throws(TypeError, () => toZonedDateTime.apply(Temporal.PlainTime.prototype, args), "Temporal.PlainTime.prototype"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/builtin.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/builtin.js deleted file mode 100644 index 24d45e9e63..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/builtin.js +++ /dev/null @@ -1,33 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: > - Tests that Temporal.PlainTime.prototype.toZonedDateTime - meets the requirements for built-in objects defined by the - introduction of chapter 17 of the ECMAScript Language Specification. -info: | - Built-in functions that are not constructors do not have a "prototype" property unless - otherwise specified in the description of a particular function. - - Unless specified otherwise, a built-in object that is callable as a function is a built-in - function object with the characteristics described in 10.3. Unless specified otherwise, the - [[Extensible]] internal slot of a built-in object initially has the value true. - - Unless otherwise specified every built-in function and every built-in constructor has the - Function prototype object [...] as the value of its [[Prototype]] internal slot. -features: [Temporal] ----*/ - -assert.sameValue(Object.isExtensible(Temporal.PlainTime.prototype.toZonedDateTime), - true, "Built-in objects must be extensible."); - -assert.sameValue(Object.prototype.toString.call(Temporal.PlainTime.prototype.toZonedDateTime), - "[object Function]", "Object.prototype.toString"); - -assert.sameValue(Object.getPrototypeOf(Temporal.PlainTime.prototype.toZonedDateTime), - Function.prototype, "prototype"); - -assert.sameValue(Temporal.PlainTime.prototype.toZonedDateTime.hasOwnProperty("prototype"), - false, "prototype property"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-datefromfields-called-with-options-undefined.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-datefromfields-called-with-options-undefined.js deleted file mode 100644 index e6b9fc3e12..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-datefromfields-called-with-options-undefined.js +++ /dev/null @@ -1,16 +0,0 @@ -// 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.prototype.tozoneddatetime -description: > - Calendar.dateFromFields method is called with undefined as the options value - when call originates internally -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const calendar = TemporalHelpers.calendarFromFieldsUndefinedOptions(); -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321, calendar); -instance.toZonedDateTime({ plainDate: { year: 2000, month: 5, day: 3, calendar }, timeZone: new Temporal.TimeZone("UTC") }); -assert.sameValue(calendar.dateFromFieldsCallCount, 1); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-fields-iterable.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-fields-iterable.js deleted file mode 100644 index 9bf110f06d..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-fields-iterable.js +++ /dev/null @@ -1,31 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: Verify the result of calendar.fields() is treated correctly. -info: | - sec-temporal.plaintime.prototype.tozoneddatetime step 5: - 3. Let _temporalDate_ be ? ToTemporalDate(_temporalDateLike_). - sec-temporal-totemporaldate step 2.c: - c. Let _fieldNames_ be ? CalendarFields(_calendar_, « *"day"*, *"month"*, *"monthCode"*, *"year"* »). - sec-temporal-calendarfields step 4: - 4. Let _result_ be ? IterableToList(_fieldsArray_). -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -const expected = [ - "day", - "month", - "monthCode", - "year", -]; - -const time = new Temporal.PlainTime(13, 3); -const calendar = TemporalHelpers.calendarFieldsIterable(); -time.toZonedDateTime({ plainDate: { year: 2000, month: 5, day: 3, calendar }, timeZone: "UTC" }); - -assert.sameValue(calendar.fieldsCallCount, 1, "fields() method called once"); -assert.compareArray(calendar.fieldsCalledWith[0], expected, "fields() method called with correct args"); -assert(calendar.iteratorExhausted[0], "iterated through the whole iterable"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-temporal-object.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-temporal-object.js deleted file mode 100644 index 23372a953a..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/calendar-temporal-object.js +++ /dev/null @@ -1,27 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: Fast path for converting other Temporal objects to Temporal.Calendar by reading internal slots -info: | - sec-temporal.plaintime.prototype.tozoneddatetime step 5: - 5. Let _temporalDate_ be ? ToTemporalDate(_temporalDateLike_). - sec-temporal-totemporaldate step 2.c: - c. Let _calendar_ be ? GetTemporalCalendarWithISODefault(_item_). - sec-temporal-gettemporalcalendarwithisodefault step 2: - 2. Return ? ToTemporalCalendarWithISODefault(_calendar_). - sec-temporal-totemporalcalendarwithisodefault step 2: - 3. Return ? ToTemporalCalendar(_temporalCalendarLike_). - sec-temporal-totemporalcalendar step 1.a: - a. If _temporalCalendarLike_ has an [[InitializedTemporalDate]], [[InitializedTemporalDateTime]], [[InitializedTemporalMonthDay]], [[InitializedTemporalYearMonth]], or [[InitializedTemporalZonedDateTime]] internal slot, then - i. Return _temporalCalendarLike_.[[Calendar]]. -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -TemporalHelpers.checkToTemporalCalendarFastPath((temporalObject, calendar) => { - const time = new Temporal.PlainTime(13, 3); - const result = time.toZonedDateTime({ timeZone: "UTC", plainDate: { year: 2000, month: 5, day: 3, calendar: temporalObject } }); - assert.sameValue(result.getCalendar(), calendar, "Temporal object coerced to calendar"); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getoffsetnanosecondsfor-maximum-forward-offset-shift.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getoffsetnanosecondsfor-maximum-forward-offset-shift.js deleted file mode 100644 index 1c26db2f2f..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getoffsetnanosecondsfor-maximum-forward-offset-shift.js +++ /dev/null @@ -1,46 +0,0 @@ -// Copyright (C) 2024 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: > - UTC offset shift returned by adjacent invocations of getOffsetNanosecondsFor - in DisambiguatePossibleInstants can be at most 24 hours. -features: [Temporal] -info: | - DisambiguatePossibleInstants: - 18. If abs(_nanoseconds_) > nsPerDay, throw a *RangeError* exception. ----*/ - -let calls = 0; - -class Shift24Hour extends Temporal.TimeZone { - id = 'TestTimeZone'; - _shiftEpochNs = 12n * 3600n * 1_000_000_000n; // 1970-01-01T12:00Z - - constructor() { - super('UTC'); - } - - getOffsetNanosecondsFor(instant) { - calls++; - if (instant.epochNanoseconds < this._shiftEpochNs) return -12 * 3600e9; - return 12 * 3600e9; - } - - getPossibleInstantsFor(plainDateTime) { - const [utcInstant] = super.getPossibleInstantsFor(plainDateTime); - const { year, month, day } = plainDateTime; - - if (year < 1970) return [utcInstant.subtract({ hours: 12 })]; - if (year === 1970 && month === 1 && day === 1) return []; - return [utcInstant.add({ hours: 12 })]; - } -} - -const timeZone = new Shift24Hour(); - -const instance = new Temporal.PlainTime(12); -instance.toZonedDateTime({ timeZone, plainDate: new Temporal.PlainDate(1970, 1, 1) }); - -assert(calls >= 2, "getOffsetNanosecondsFor should be called at least twice"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getoffsetnanosecondsfor-out-of-range-forward-offset-shift.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getoffsetnanosecondsfor-out-of-range-forward-offset-shift.js deleted file mode 100644 index 37516d1663..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getoffsetnanosecondsfor-out-of-range-forward-offset-shift.js +++ /dev/null @@ -1,41 +0,0 @@ -// Copyright (C) 2024 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: > - UTC offset shift returned by adjacent invocations of getOffsetNanosecondsFor - in DisambiguatePossibleInstants cannot be greater than 24 hours. -features: [Temporal] -info: | - DisambiguatePossibleInstants: - 18. If abs(_nanoseconds_) > nsPerDay, throw a *RangeError* exception. ----*/ - -class ShiftLonger24Hour extends Temporal.TimeZone { - id = 'TestTimeZone'; - _shiftEpochNs = 12n * 3600n * 1_000_000_000n; // 1970-01-01T12:00Z - - constructor() { - super('UTC'); - } - - getOffsetNanosecondsFor(instant) { - if (instant.epochNanoseconds < this._shiftEpochNs) return -12 * 3600e9; - return 12 * 3600e9 + 1; - } - - getPossibleInstantsFor(plainDateTime) { - const [utcInstant] = super.getPossibleInstantsFor(plainDateTime); - const { year, month, day } = plainDateTime; - - if (year < 1970) return [utcInstant.subtract({ hours: 12 })]; - if (year === 1970 && month === 1 && day === 1) return []; - return [utcInstant.add({ hours: 12, nanoseconds: 1 })]; - } -} - -const timeZone = new ShiftLonger24Hour(); - -const instance = new Temporal.PlainTime(12); -assert.throws(RangeError, () => instance.toZonedDateTime({ timeZone, plainDate: new Temporal.PlainDate(1970, 1, 1) }), "RangeError should be thrown"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-called-with-iso8601-calendar.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-called-with-iso8601-calendar.js deleted file mode 100644 index ba43853d0a..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-called-with-iso8601-calendar.js +++ /dev/null @@ -1,55 +0,0 @@ -// 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.plaintime.prototype.tozoneddatetime -description: > - Time zone's getPossibleInstantsFor is called with a PlainDateTime with the - built-in ISO 8601 calendar -features: [Temporal] -info: | - DisambiguatePossibleInstants: - 2. Let _n_ be _possibleInstants_'s length. - ... - 5. Assert: _n_ = 0. - ... - 19. If _disambiguation_ is *"earlier"*, then - ... - c. Let _earlierDateTime_ be ! CreateTemporalDateTime(..., *"iso8601"*). - d. Set _possibleInstants_ to ? GetPossibleInstantsFor(_timeZone_, _earlierDateTime_). - ... - 20. Assert: _disambiguation_ is *"compatible"* or *"later"*. - ... - 23. Let _laterDateTime_ be ! CreateTemporalDateTime(..., *"iso8601"*). - 24. Set _possibleInstants_ to ? GetPossibleInstantsFor(_timeZone_, _laterDateTime_). ----*/ - -class SkippedDateTime extends Temporal.TimeZone { - constructor() { - super("UTC"); - this.calls = 0; - } - - getPossibleInstantsFor(dateTime) { - // Calls occur in pairs. For the first one return no possible instants so - // that DisambiguatePossibleInstants will call it again - if (this.calls++ % 2 == 0) { - return []; - } - - assert.sameValue( - dateTime.getISOFields().calendar, - "iso8601", - "getPossibleInstantsFor called with dateTime with built-in ISO 8601 calendar" - ); - return super.getPossibleInstantsFor(dateTime); - } -} - -const nonBuiltinISOCalendar = new Temporal.Calendar("iso8601"); -const timeZone = new SkippedDateTime(); - -const instance = new Temporal.PlainTime(12, 34, 56); -instance.toZonedDateTime({ timeZone, plainDate: new Temporal.PlainDate(2000, 5, 2, nonBuiltinISOCalendar) }); - -assert.sameValue(timeZone.calls, 2, "getPossibleInstantsFor should have been called 2 times"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-maximum-backward-offset-shift.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-maximum-backward-offset-shift.js deleted file mode 100644 index 2a6b9ee08d..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-maximum-backward-offset-shift.js +++ /dev/null @@ -1,50 +0,0 @@ -// Copyright (C) 2024 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: > - UTC offset shift returned by getPossibleInstantsFor can be at most 24 hours. -features: [Temporal] -info: | - GetPossibleInstantsFor: - 5.b.i. Let _numResults_ be _list_'s length. - ii. If _numResults_ > 1, then - 1. Let _epochNs_ be a new empty List. - 2. For each value _instant_ in list, do - a. Append _instant_.[[EpochNanoseconds]] to the end of the List _epochNs_. - 3. Let _min_ be the least element of the List _epochNs_. - 4. Let _max_ be the greatest element of the List _epochNs_. - 5. If abs(ℝ(_max_ - _min_)) > nsPerDay, throw a *RangeError* exception. ----*/ - -let calls = 0; - -class Shift24Hour extends Temporal.TimeZone { - id = 'TestTimeZone'; - - constructor() { - super('UTC'); - } - - getOffsetNanosecondsFor(instant) { - return 0; - } - - getPossibleInstantsFor(plainDateTime) { - calls++; - const utc = new Temporal.TimeZone("UTC"); - const [utcInstant] = utc.getPossibleInstantsFor(plainDateTime); - return [ - utcInstant.subtract({ hours: 12 }), - utcInstant.add({ hours: 12 }) - ]; - } -} - -const timeZone = new Shift24Hour(); - -const instance = new Temporal.PlainTime(12); -instance.toZonedDateTime({ timeZone, plainDate: new Temporal.PlainDate(1970, 1, 1) }); - -assert(calls >= 1, "getPossibleInstantsFor should be called at least once"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-out-of-range-backward-offset-shift.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-out-of-range-backward-offset-shift.js deleted file mode 100644 index cc5d7dd654..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/getpossibleinstantsfor-out-of-range-backward-offset-shift.js +++ /dev/null @@ -1,46 +0,0 @@ -// Copyright (C) 2024 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: > - UTC offset shift returned by getPossibleInstantsFor can be at most 24 hours. -features: [Temporal] -info: | - GetPossibleInstantsFor: - 5.b.i. Let _numResults_ be _list_'s length. - ii. If _numResults_ > 1, then - 1. Let _epochNs_ be a new empty List. - 2. For each value _instant_ in list, do - a. Append _instant_.[[EpochNanoseconds]] to the end of the List _epochNs_. - 3. Let _min_ be the least element of the List _epochNs_. - 4. Let _max_ be the greatest element of the List _epochNs_. - 5. If abs(ℝ(_max_ - _min_)) > nsPerDay, throw a *RangeError* exception. ----*/ - -class ShiftLonger24Hour extends Temporal.TimeZone { - id = 'TestTimeZone'; - - constructor() { - super('UTC'); - } - - getOffsetNanosecondsFor(instant) { - return 0; - } - - getPossibleInstantsFor(plainDateTime) { - const utc = new Temporal.TimeZone("UTC"); - const [utcInstant] = utc.getPossibleInstantsFor(plainDateTime); - return [ - utcInstant.subtract({ hours: 12, nanoseconds: 1 }), - utcInstant.add({ hours: 12 }), - utcInstant, // add a third value in case the implementation doesn't sort - ]; - } -} - -const timeZone = new ShiftLonger24Hour(); - -const instance = new Temporal.PlainTime(12); -assert.throws(RangeError, () => instance.toZonedDateTime({ timeZone, plainDate: new Temporal.PlainDate(1970, 1, 1) }), "RangeError should be thrown"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/infinity-throws-rangeerror.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/infinity-throws-rangeerror.js deleted file mode 100644 index 7061b0fc39..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/infinity-throws-rangeerror.js +++ /dev/null @@ -1,23 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -description: Throws if any value in the property bag is Infinity or -Infinity -esid: sec-temporal.plaintime.prototype.tozoneddatetime -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(15); -const base = { year: 2000, month: 5, day: 2 }; - -[Infinity, -Infinity].forEach((inf) => { - ["year", "month", "day"].forEach((prop) => { - assert.throws(RangeError, () => instance.toZonedDateTime({ timeZone: "UTC", plainDate: { ...base, [prop]: inf } }), `${prop} property cannot be ${inf}`); - - const calls = []; - const obj = TemporalHelpers.toPrimitiveObserver(calls, inf, prop); - assert.throws(RangeError, () => instance.toZonedDateTime({ timeZone: "UTC", plainDate: { ...base, [prop]: obj } })); - assert.compareArray(calls, [`get ${prop}.valueOf`, `call ${prop}.valueOf`], "it fails after fetching the primitive value"); - }); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/length.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/length.js deleted file mode 100644 index 62a7caaa07..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/length.js +++ /dev/null @@ -1,25 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: Temporal.PlainTime.prototype.toZonedDateTime.length is 1 -info: | - Every built-in function object, including constructors, has a "length" property whose value is - an integer. Unless otherwise specified, this value is equal to the largest number of named - arguments shown in the subclause headings for the function description. Optional parameters - (which are indicated with brackets: [ ]) or rest parameters (which are shown using the form - «...name») are not included in the default argument count. - - Unless otherwise specified, the "length" property of a built-in function object has the - attributes { [[Writable]]: false, [[Enumerable]]: false, [[Configurable]]: true }. -includes: [propertyHelper.js] -features: [Temporal] ----*/ - -verifyProperty(Temporal.PlainTime.prototype.toZonedDateTime, "length", { - value: 1, - writable: false, - enumerable: false, - configurable: true, -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/name.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/name.js deleted file mode 100644 index 53fd0fe9f2..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/name.js +++ /dev/null @@ -1,23 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: Temporal.PlainTime.prototype.toZonedDateTime.name is "toZonedDateTime". -info: | - Every built-in function object, including constructors, that is not identified as an anonymous - function has a "name" property whose value is a String. Unless otherwise specified, this value - is the name that is given to the function in this specification. - - Unless otherwise specified, the "name" property of a built-in function object, if it exists, - has the attributes { [[Writable]]: false, [[Enumerable]]: false, [[Configurable]]: true }. -includes: [propertyHelper.js] -features: [Temporal] ----*/ - -verifyProperty(Temporal.PlainTime.prototype.toZonedDateTime, "name", { - value: "toZonedDateTime", - writable: false, - enumerable: false, - configurable: true, -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/not-a-constructor.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/not-a-constructor.js deleted file mode 100644 index 279ec0b92e..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/not-a-constructor.js +++ /dev/null @@ -1,21 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: > - Temporal.PlainTime.prototype.toZonedDateTime does not implement [[Construct]], is not new-able -info: | - Built-in function objects that are not identified as constructors do not implement the - [[Construct]] internal method unless otherwise specified in the description of a particular - function. -includes: [isConstructor.js] -features: [Reflect.construct, Temporal] ----*/ - -assert.throws(TypeError, () => { - new Temporal.PlainTime.prototype.toZonedDateTime(); -}, "Calling as constructor"); - -assert.sameValue(isConstructor(Temporal.PlainTime.prototype.toZonedDateTime), false, - "isConstructor(Temporal.PlainTime.prototype.toZonedDateTime)"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/order-of-operations.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/order-of-operations.js deleted file mode 100644 index ff8d14d0eb..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/order-of-operations.js +++ /dev/null @@ -1,115 +0,0 @@ -// 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.plaintime.prototype.tozoneddatetime -description: User code calls happen in the correct order -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -const actual = []; -const expected = [ - "get item.plainDate", - "get item.plainDate.calendar", - "has item.plainDate.calendar.dateAdd", - "has item.plainDate.calendar.dateFromFields", - "has item.plainDate.calendar.dateUntil", - "has item.plainDate.calendar.day", - "has item.plainDate.calendar.dayOfWeek", - "has item.plainDate.calendar.dayOfYear", - "has item.plainDate.calendar.daysInMonth", - "has item.plainDate.calendar.daysInWeek", - "has item.plainDate.calendar.daysInYear", - "has item.plainDate.calendar.fields", - "has item.plainDate.calendar.id", - "has item.plainDate.calendar.inLeapYear", - "has item.plainDate.calendar.mergeFields", - "has item.plainDate.calendar.month", - "has item.plainDate.calendar.monthCode", - "has item.plainDate.calendar.monthDayFromFields", - "has item.plainDate.calendar.monthsInYear", - "has item.plainDate.calendar.weekOfYear", - "has item.plainDate.calendar.year", - "has item.plainDate.calendar.yearMonthFromFields", - "has item.plainDate.calendar.yearOfWeek", - "get item.plainDate.calendar.dateFromFields", - "get item.plainDate.calendar.fields", - "call item.plainDate.calendar.fields", - "get item.plainDate.day", - "get item.plainDate.day.valueOf", - "call item.plainDate.day.valueOf", - "get item.plainDate.month", - "get item.plainDate.month.valueOf", - "call item.plainDate.month.valueOf", - "get item.plainDate.monthCode", - "get item.plainDate.monthCode.toString", - "call item.plainDate.monthCode.toString", - "get item.plainDate.year", - "get item.plainDate.year.valueOf", - "call item.plainDate.year.valueOf", - "call item.plainDate.calendar.dateFromFields", - "get item.timeZone", - "has item.timeZone.getOffsetNanosecondsFor", - "has item.timeZone.getPossibleInstantsFor", - "has item.timeZone.id", - "get item.timeZone.getOffsetNanosecondsFor", - "get item.timeZone.getPossibleInstantsFor", - "call item.timeZone.getPossibleInstantsFor", -]; - -const calendar = TemporalHelpers.calendarObserver(actual, "item.plainDate.calendar"); -const instance = new Temporal.PlainTime(2, 30); - -const dstTimeZone = TemporalHelpers.springForwardFallBackTimeZone(); -const timeZone = TemporalHelpers.timeZoneObserver(actual, "item.timeZone", { - getOffsetNanosecondsFor: dstTimeZone.getOffsetNanosecondsFor, - getPossibleInstantsFor: dstTimeZone.getPossibleInstantsFor, -}); - -const plainDate = TemporalHelpers.propertyBagObserver(actual, { - year: 2000, - month: 1, - monthCode: "M01", - day: 1, - calendar, -}, "item.plainDate"); -instance.toZonedDateTime(TemporalHelpers.propertyBagObserver(actual, { - plainDate, - timeZone, -}, "item")); -assert.compareArray(actual, expected, "order of operations at normal wall-clock time"); -actual.splice(0); // clear - -const fallBackPlainDate = TemporalHelpers.propertyBagObserver(actual, { - year: 2000, - month: 10, - monthCode: "M10", - day: 29, - calendar, -}, "item.plainDate"); -const fallBackInstance = new Temporal.PlainTime(1, 30); -fallBackInstance.toZonedDateTime(TemporalHelpers.propertyBagObserver(actual, { - plainDate: fallBackPlainDate, - timeZone, -}, "item")); -assert.compareArray(actual, expected, "order of operations at repeated wall-clock time"); -actual.splice(0); // clear - -const springForwardPlainDate = TemporalHelpers.propertyBagObserver(actual, { - year: 2000, - month: 4, - monthCode: "M04", - day: 2, - calendar, -}, "item.plainDate"); -instance.toZonedDateTime(TemporalHelpers.propertyBagObserver(actual, { - plainDate: springForwardPlainDate, - timeZone, -}, "item")); -assert.compareArray(actual, expected.concat([ - "call item.timeZone.getOffsetNanosecondsFor", - "call item.timeZone.getOffsetNanosecondsFor", - "call item.timeZone.getPossibleInstantsFor", -]), "order of operations at skipped wall-clock time"); -actual.splice(0); // clear diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/plaindate-infinity-throws-rangeerror.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/plaindate-infinity-throws-rangeerror.js deleted file mode 100644 index a17f45bbeb..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/plaindate-infinity-throws-rangeerror.js +++ /dev/null @@ -1,23 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -description: Throws if any value in the property bag is Infinity or -Infinity -esid: sec-temporal.plaintime.prototype.tozoneddatetime -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(15); -const base = { year: 2000, month: 5, day: 2 }; - -[Infinity, -Infinity].forEach((inf) => { - ["year", "month", "day"].forEach((prop) => { - assert.throws(RangeError, () => instance.toZonedDateTime({ timeZone: "UTC", plainDate: { ...base, [prop]: inf } }), `${prop} property cannot be ${inf} in plainDate`); - - const calls = []; - const obj = TemporalHelpers.toPrimitiveObserver(calls, inf, prop); - assert.throws(RangeError, () => instance.toZonedDateTime({ timeZone: "UTC", plainDate: { ...base, [prop]: obj } })); - assert.compareArray(calls, [`get ${prop}.valueOf`, `call ${prop}.valueOf`], "it fails after fetching the primitive value"); - }); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/prop-desc.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/prop-desc.js deleted file mode 100644 index 0cd061a583..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/prop-desc.js +++ /dev/null @@ -1,21 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: The "toZonedDateTime" property of Temporal.PlainTime.prototype -includes: [propertyHelper.js] -features: [Temporal] ----*/ - -assert.sameValue( - typeof Temporal.PlainTime.prototype.toZonedDateTime, - "function", - "`typeof PlainTime.prototype.toZonedDateTime` is `function`" -); - -verifyProperty(Temporal.PlainTime.prototype, "toZonedDateTime", { - writable: true, - enumerable: false, - configurable: true, -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-case-insensitive.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-case-insensitive.js deleted file mode 100644 index 7b71990b4e..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-case-insensitive.js +++ /dev/null @@ -1,14 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Time zone names are case insensitive -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(); - -const timeZone = 'uTc'; -const result = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -assert.sameValue(result.timeZoneId, 'UTC', `Time zone created from string "${timeZone}"`); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-non-integer.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-non-integer.js deleted file mode 100644 index afc22e47f1..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-non-integer.js +++ /dev/null @@ -1,19 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: RangeError thrown if time zone reports an offset that is not an integer number of nanoseconds -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -[3600_000_000_000.5, NaN, -Infinity, Infinity].forEach((wrongOffset) => { - const timeZone = TemporalHelpers.specificOffsetTimeZone(wrongOffset); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const plainDate = new Temporal.PlainDate(2000, 5, 2); - timeZone.getPossibleInstantsFor = function () { - return []; - }; - assert.throws(RangeError, () => time.toZonedDateTime({ plainDate, timeZone })); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-not-callable.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-not-callable.js deleted file mode 100644 index e06ed3052d..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-not-callable.js +++ /dev/null @@ -1,23 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: TypeError thrown if timeZone.getOffsetNanosecondsFor is not callable -features: [BigInt, Symbol, Temporal, arrow-function] ----*/ - -[undefined, null, true, Math.PI, 'string', Symbol('sym'), 42n, {}].forEach((notCallable) => { - const timeZone = new Temporal.TimeZone("UTC"); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const plainDate = new Temporal.PlainDate(2000, 5, 2); - timeZone.getPossibleInstantsFor = function () { - return []; - }; - timeZone.getOffsetNanosecondsFor = notCallable; - assert.throws( - TypeError, - () => time.toZonedDateTime({ plainDate, timeZone }), - `Uncallable ${notCallable === null ? 'null' : typeof notCallable} getOffsetNanosecondsFor should throw TypeError` - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-out-of-range.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-out-of-range.js deleted file mode 100644 index 2e8f97e611..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-out-of-range.js +++ /dev/null @@ -1,19 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: RangeError thrown if time zone reports an offset that is out of range -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -[-86400_000_000_000, 86400_000_000_000].forEach((wrongOffset) => { - const timeZone = TemporalHelpers.specificOffsetTimeZone(wrongOffset); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const plainDate = new Temporal.PlainDate(2000, 5, 2); - timeZone.getPossibleInstantsFor = function () { - return []; - }; - assert.throws(RangeError, () => time.toZonedDateTime({ plainDate, timeZone })); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-wrong-type.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-wrong-type.js deleted file mode 100644 index ddb8233081..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getoffsetnanosecondsfor-wrong-type.js +++ /dev/null @@ -1,28 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: TypeError thrown if time zone reports an offset that is not a Number -features: [Temporal] -includes: [temporalHelpers.js] ----*/ - -[ - undefined, - null, - true, - "+01:00", - Symbol(), - 3600_000_000_000n, - {}, - { valueOf() { return 3600_000_000_000; } }, -].forEach((wrongOffset) => { - const timeZone = TemporalHelpers.specificOffsetTimeZone(wrongOffset); - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - const plainDate = new Temporal.PlainDate(2000, 5, 2); - timeZone.getPossibleInstantsFor = function () { - return []; - }; - assert.throws(TypeError, () => time.toZonedDateTime({ plainDate, timeZone })); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getpossibleinstantsfor-iterable.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getpossibleinstantsfor-iterable.js deleted file mode 100644 index 2fd76d4a05..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-getpossibleinstantsfor-iterable.js +++ /dev/null @@ -1,42 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: An iterable returned from timeZone.getPossibleInstantsFor is consumed after each call -info: | - sec-temporal.plaintime.prototype.tozoneddatetime step 10: - 10. Let _instant_ be ? BuiltinTimeZoneGetInstantFor(_timeZone_, _temporalDateTime_, *"compatible"*). - sec-temporal-builtintimezonegetinstantfor step 1: - 1. Let _possibleInstants_ be ? GetPossibleInstantsFor(_timeZone_, _dateTime_). - sec-temporal-builtintimezonegetinstantfor step 14: - 14. Assert: _disambiguation_ is *"compatible"* or *"later"*. - sec-temporal-builtintimezonegetinstantfor step 16: - 16. Set _possibleInstants_ to ? GetPossibleInstantsFor(_timeZone_, _later_). - sec-temporal-getpossibleinstantsfor step 2: - 2. Let _list_ be ? IterableToList(_possibleInstants_). -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -const expected1 = [ - "2000-05-02T12:34:56.987654321", -]; - -TemporalHelpers.checkTimeZonePossibleInstantsIterable((timeZone) => { - const time = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); - time.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -}, expected1); - -// Same, but test the other path where the time doesn't exist and -// GetPossibleInstantsFor is called again on a later time - -const expected2 = [ - "2030-01-01T00:30:00", - "2030-01-01T01:30:00", -]; - -TemporalHelpers.checkTimeZonePossibleInstantsIterable((timeZone) => { - const time = new Temporal.PlainTime(0, 30); - time.toZonedDateTime({ plainDate: new Temporal.PlainDate(2030, 1, 1), timeZone }); -}, expected2); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-datetime.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-datetime.js deleted file mode 100644 index 8eb3307c67..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-datetime.js +++ /dev/null @@ -1,62 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: Conversion of ISO date-time strings to Temporal.TimeZone instances -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(); - -let timeZone = "2021-08-19T17:30"; -assert.throws(RangeError, () => instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }), "bare date-time string is not a time zone"); - -[ - "2021-08-19T17:30-07:00:01", - "2021-08-19T17:30-07:00:00", - "2021-08-19T17:30-07:00:00.1", - "2021-08-19T17:30-07:00:00.0", - "2021-08-19T17:30-07:00:00.01", - "2021-08-19T17:30-07:00:00.00", - "2021-08-19T17:30-07:00:00.001", - "2021-08-19T17:30-07:00:00.000", - "2021-08-19T17:30-07:00:00.0001", - "2021-08-19T17:30-07:00:00.0000", - "2021-08-19T17:30-07:00:00.00001", - "2021-08-19T17:30-07:00:00.00000", - "2021-08-19T17:30-07:00:00.000001", - "2021-08-19T17:30-07:00:00.000000", - "2021-08-19T17:30-07:00:00.0000001", - "2021-08-19T17:30-07:00:00.0000000", - "2021-08-19T17:30-07:00:00.00000001", - "2021-08-19T17:30-07:00:00.00000000", - "2021-08-19T17:30-07:00:00.000000001", - "2021-08-19T17:30-07:00:00.000000000", -].forEach((timeZone) => { - assert.throws( - RangeError, - () => instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }), - `ISO string ${timeZone} with a sub-minute offset is not a valid time zone` - ); -}); - -timeZone = "2021-08-19T17:30Z"; -const result1 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -assert.sameValue(result1.timeZoneId, "UTC", "date-time + Z is UTC time zone"); - -timeZone = "2021-08-19T17:30-07:00"; -const result2 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -assert.sameValue(result2.timeZoneId, "-07:00", "date-time + offset is the offset time zone"); - -timeZone = "2021-08-19T17:30[UTC]"; -const result3 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -assert.sameValue(result3.timeZoneId, "UTC", "date-time + IANA annotation is the IANA time zone"); - -timeZone = "2021-08-19T17:30Z[UTC]"; -const result4 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -assert.sameValue(result4.timeZoneId, "UTC", "date-time + Z + IANA annotation is the IANA time zone"); - -timeZone = "2021-08-19T17:30-07:00[UTC]"; -const result5 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -assert.sameValue(result5.timeZoneId, "UTC", "date-time + offset + IANA annotation is the IANA time zone"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-leap-second.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-leap-second.js deleted file mode 100644 index bb994f9ef5..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-leap-second.js +++ /dev/null @@ -1,17 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Leap second is a valid ISO string for TimeZone -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(); -let timeZone = "2016-12-31T23:59:60+00:00[UTC]"; - -const result = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -assert.sameValue(result.timeZoneId, "UTC", "leap second is a valid ISO string for TimeZone"); - -timeZone = "2021-08-19T17:30:45.123456789+23:59[+23:59:60]"; -assert.throws(RangeError, () => instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }), "leap second in time zone name not valid"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-multiple-offsets.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-multiple-offsets.js deleted file mode 100644 index 8c8e37a488..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-multiple-offsets.js +++ /dev/null @@ -1,14 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -esid: sec-temporal.plaintime.prototype.tozoneddatetime -description: Time zone parsing from ISO strings uses the bracketed offset, not the ISO string offset -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(); -const timeZone = "2021-08-19T17:30:45.123456789-12:12[+01:46]"; - -const result = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -assert.sameValue(result.timeZoneId, "+01:46", "Time zone string determined from bracket name"); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-year-zero.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-year-zero.js deleted file mode 100644 index 50ca173af4..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-year-zero.js +++ /dev/null @@ -1,21 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Negative zero, as an extended year, is rejected -features: [Temporal, arrow-function] ----*/ - -const invalidStrings = [ - "-000000-10-31T17:45Z", - "-000000-10-31T17:45+00:00[UTC]", -]; -const instance = new Temporal.PlainTime(); -invalidStrings.forEach((timeZone) => { - assert.throws( - RangeError, - () => instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }), - "reject minus zero as extended year" - ); -}); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string.js deleted file mode 100644 index 6e3de214a8..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string.js +++ /dev/null @@ -1,36 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Time zone IDs are valid input for a time zone -includes: [temporalHelpers.js] -features: [Temporal] ----*/ - -const getPossibleInstantsForOriginal = Object.getOwnPropertyDescriptor(Temporal.TimeZone.prototype, "getPossibleInstantsFor"); -Object.defineProperty(Temporal.TimeZone.prototype, "getPossibleInstantsFor", { - configurable: true, - enumerable: false, - get() { - TemporalHelpers.assertUnreachable("getPossibleInstantsFor should not be looked up"); - }, -}); -const getOffsetNanosecondsForOriginal = Object.getOwnPropertyDescriptor(Temporal.TimeZone.prototype, "getOffsetNanosecondsFor"); -Object.defineProperty(Temporal.TimeZone.prototype, "getOffsetNanosecondsFor", { - configurable: true, - enumerable: false, - get() { - TemporalHelpers.assertUnreachable("getOffsetNanosecondsFor should not be looked up"); - }, -}); - -const instance = new Temporal.PlainTime(); - -["UTC", "+01:30"].forEach((timeZone) => { - const result = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); - assert.sameValue(result.getISOFields().timeZone, timeZone, `time zone slot should store string "${timeZone}"`); -}); - -Object.defineProperty(Temporal.TimeZone.prototype, "getPossibleInstantsFor", getPossibleInstantsForOriginal); -Object.defineProperty(Temporal.TimeZone.prototype, "getOffsetNanosecondsFor", getOffsetNanosecondsForOriginal); diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-wrong-type.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-wrong-type.js deleted file mode 100644 index b157559970..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-wrong-type.js +++ /dev/null @@ -1,39 +0,0 @@ -// 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.prototype.tozoneddatetime -description: > - Appropriate error thrown when argument cannot be converted to a valid string - or object for TimeZone -features: [BigInt, Symbol, Temporal] ----*/ - -const instance = new Temporal.PlainTime(); - -const primitiveTests = [ - [null, "null"], - [true, "boolean"], - ["", "empty string"], - [1, "number that doesn't convert to a valid ISO string"], - [19761118, "number that would convert to a valid ISO string in other contexts"], - [1n, "bigint"], -]; - -for (const [timeZone, description] of primitiveTests) { - assert.throws( - typeof timeZone === 'string' ? RangeError : TypeError, - () => instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }), - `${description} does not convert to a valid ISO string` - ); -} - -const typeErrorTests = [ - [Symbol(), "symbol"], - [{}, "object not implementing time zone protocol"], - [new Temporal.Calendar("iso8601"), "calendar instance"], -]; - -for (const [timeZone, description] of typeErrorTests) { - assert.throws(TypeError, () => instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }), `${description} is not a valid object and does not convert to a string`); -} diff --git a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/year-zero.js b/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/year-zero.js deleted file mode 100644 index 6fb496ea92..0000000000 --- a/test/built-ins/Temporal/PlainTime/prototype/toZonedDateTime/year-zero.js +++ /dev/null @@ -1,23 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Negative zero, as an extended year, is rejected -features: [Temporal, arrow-function] ----*/ - -const invalidStrings = [ - "-000000-10-31", - "-000000-10-31T00:45", - "-000000-10-31T00:45+01:00", - "-000000-10-31T00:45+00:00[UTC]", -]; -const instance = new Temporal.PlainTime(12, 34, 56, 987, 654, 321); -invalidStrings.forEach((arg) => { - assert.throws( - RangeError, - () => instance.toZonedDateTime({ plainDate: arg, timeZone: "UTC" }), - "reject minus zero as extended year" - ); -}); diff --git a/test/intl402/Temporal/PlainTime/prototype/toPlainDateTime/infinity-throws-rangeerror.js b/test/intl402/Temporal/PlainTime/prototype/toPlainDateTime/infinity-throws-rangeerror.js deleted file mode 100644 index 5b858b9da5..0000000000 --- a/test/intl402/Temporal/PlainTime/prototype/toPlainDateTime/infinity-throws-rangeerror.js +++ /dev/null @@ -1,21 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -description: Throws if eraYear in the property bag is Infinity or -Infinity -esid: sec-temporal.plaintime.prototype.toplaindatetime -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(15); -const base = { era: "ad", month: 5, day: 2, calendar: "gregory" }; - -[Infinity, -Infinity].forEach((inf) => { - assert.throws(RangeError, () => instance.toPlainDateTime({ ...base, eraYear: inf }), `eraYear property cannot be ${inf}`); - - const calls = []; - const obj = TemporalHelpers.toPrimitiveObserver(calls, inf, "eraYear"); - assert.throws(RangeError, () => instance.toPlainDateTime({ ...base, eraYear: obj })); - assert.compareArray(calls, ["get eraYear.valueOf", "call eraYear.valueOf"], "it fails after fetching the primitive value"); -}); diff --git a/test/intl402/Temporal/PlainTime/prototype/toZonedDateTime/plaindate-infinity-throws-rangeerror.js b/test/intl402/Temporal/PlainTime/prototype/toZonedDateTime/plaindate-infinity-throws-rangeerror.js deleted file mode 100644 index 81aa6d8f72..0000000000 --- a/test/intl402/Temporal/PlainTime/prototype/toZonedDateTime/plaindate-infinity-throws-rangeerror.js +++ /dev/null @@ -1,21 +0,0 @@ -// Copyright (C) 2021 Igalia, S.L. All rights reserved. -// This code is governed by the BSD license found in the LICENSE file. - -/*--- -description: Throws if eraYear in the property bag is Infinity or -Infinity -esid: sec-temporal.plaintime.prototype.tozoneddatetime -includes: [compareArray.js, temporalHelpers.js] -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(15); -const base = { era: "ad", month: 5, day: 2, calendar: "gregory" }; - -[Infinity, -Infinity].forEach((inf) => { - assert.throws(RangeError, () => instance.toZonedDateTime({ timeZone: "UTC", plainDate: { ...base, eraYear: inf } }), `eraYear property cannot be ${inf} in plainDate`); - - const calls = []; - const obj = TemporalHelpers.toPrimitiveObserver(calls, inf, "eraYear"); - assert.throws(RangeError, () => instance.toZonedDateTime({ timeZone: "UTC", plainDate: { ...base, eraYear: obj } })); - assert.compareArray(calls, ["get eraYear.valueOf", "call eraYear.valueOf"], "it fails after fetching the primitive value"); -}); diff --git a/test/intl402/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-datetime.js b/test/intl402/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-datetime.js deleted file mode 100644 index 6aa2ebf8ca..0000000000 --- a/test/intl402/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-datetime.js +++ /dev/null @@ -1,22 +0,0 @@ -// 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.prototype.tozoneddatetime -description: Conversion of ISO date-time strings to Temporal.TimeZone instances (with IANA time zones) -features: [Temporal] ----*/ - -const instance = new Temporal.PlainTime(); - -let timeZone = "2021-08-19T17:30[America/Vancouver]"; -const result1 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -assert.sameValue(result1.timeZoneId, "America/Vancouver", "date-time + IANA annotation is the IANA time zone"); - -timeZone = "2021-08-19T17:30Z[America/Vancouver]"; -const result2 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -assert.sameValue(result2.timeZoneId, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone"); - -timeZone = "2021-08-19T17:30-07:00[America/Vancouver]"; -const result3 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone }); -assert.sameValue(result3.timeZoneId, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone");