mirror of https://github.com/tc39/test262.git
Add tests using Intl time zones to intl402/
For cases in the previous commit that actually removed some functionality from tests in built-ins/, add corresponding tests in intl402/ to preserve test coverage of that functionality for hosts that do support Intl.
This commit is contained in:
parent
17b3c567ff
commit
a6faa8c000
|
@ -0,0 +1,28 @@
|
|||
// 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.duration.prototype.add
|
||||
description: >
|
||||
Conversion of ISO date-time strings as relativeTo option to
|
||||
Temporal.ZonedDateTime or Temporal.PlainDateTime instances
|
||||
includes: [temporalHelpers.js]
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const instance = new Temporal.Duration(1, 0, 0, 1);
|
||||
|
||||
let relativeTo = "2019-11-01T00:00[America/Vancouver]";
|
||||
const result4 = instance.add(new Temporal.Duration(0, 0, 0, 0, -24), { relativeTo });
|
||||
TemporalHelpers.assertDuration(result4, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, "date-time + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00Z[America/Vancouver]";
|
||||
const result5 = instance.add(new Temporal.Duration(0, 0, 0, 0, -24), { relativeTo });
|
||||
TemporalHelpers.assertDuration(result5, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, "date-time + Z + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00-07:00[America/Vancouver]";
|
||||
const result6 = instance.add(new Temporal.Duration(0, 0, 0, 0, -24), { relativeTo });
|
||||
TemporalHelpers.assertDuration(result6, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, "date-time + offset + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00+04:15[America/Vancouver]";
|
||||
assert.throws(RangeError, () => instance.add(new Temporal.Duration(0, 0, 0, 0, -24), { relativeTo }), "date-time + offset + IANA annotation throws if wall time and exact time mismatch");
|
28
test/intl402/Temporal/Duration/prototype/round/relativeto-string-datetime.js
vendored
Normal file
28
test/intl402/Temporal/Duration/prototype/round/relativeto-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,28 @@
|
|||
// 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.duration.prototype.round
|
||||
description: >
|
||||
Conversion of ISO date-time strings as relativeTo option to
|
||||
Temporal.ZonedDateTime or Temporal.PlainDateTime instances
|
||||
includes: [temporalHelpers.js]
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const instance = new Temporal.Duration(1, 0, 0, 0, 24);
|
||||
|
||||
let relativeTo = "2019-11-01T00:00[America/Vancouver]";
|
||||
const result4 = instance.round({ largestUnit: "years", relativeTo });
|
||||
TemporalHelpers.assertDuration(result4, 1, 0, 0, 0, 24, 0, 0, 0, 0, 0, "date-time + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00Z[America/Vancouver]";
|
||||
const result5 = instance.round({ largestUnit: "years", relativeTo });
|
||||
TemporalHelpers.assertDuration(result5, 1, 0, 0, 0, 24, 0, 0, 0, 0, 0, "date-time + Z + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00-07:00[America/Vancouver]";
|
||||
const result6 = instance.round({ largestUnit: "years", relativeTo });
|
||||
TemporalHelpers.assertDuration(result6, 1, 0, 0, 0, 24, 0, 0, 0, 0, 0, "date-time + offset + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00+04:15[America/Vancouver]";
|
||||
assert.throws(RangeError, () => instance.round({ largestUnit: "years", relativeTo }), "date-time + offset + IANA annotation throws if wall time and exact time mismatch");
|
28
test/intl402/Temporal/Duration/prototype/subtract/relativeto-string-datetime.js
vendored
Normal file
28
test/intl402/Temporal/Duration/prototype/subtract/relativeto-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,28 @@
|
|||
// 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.duration.prototype.subtract
|
||||
description: >
|
||||
Conversion of ISO date-time strings as relativeTo option to
|
||||
Temporal.ZonedDateTime or Temporal.PlainDateTime instances
|
||||
includes: [temporalHelpers.js]
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const instance = new Temporal.Duration(1, 0, 0, 1);
|
||||
|
||||
let relativeTo = "2019-11-01T00:00[America/Vancouver]";
|
||||
const result4 = instance.subtract(new Temporal.Duration(0, 0, 0, 0, 24), { relativeTo });
|
||||
TemporalHelpers.assertDuration(result4, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, "date-time + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00Z[America/Vancouver]";
|
||||
const result5 = instance.subtract(new Temporal.Duration(0, 0, 0, 0, 24), { relativeTo });
|
||||
TemporalHelpers.assertDuration(result5, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, "date-time + Z + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00-07:00[America/Vancouver]";
|
||||
const result6 = instance.subtract(new Temporal.Duration(0, 0, 0, 0, 24), { relativeTo });
|
||||
TemporalHelpers.assertDuration(result6, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, "date-time + offset + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00+04:15[America/Vancouver]";
|
||||
assert.throws(RangeError, () => instance.subtract(new Temporal.Duration(0, 0, 0, 0, 24), { relativeTo }), "date-time + offset + IANA annotation throws if wall time and exact time mismatch");
|
27
test/intl402/Temporal/Duration/prototype/total/relativeto-string-datetime.js
vendored
Normal file
27
test/intl402/Temporal/Duration/prototype/total/relativeto-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,27 @@
|
|||
// 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.duration.prototype.total
|
||||
description: >
|
||||
Conversion of ISO date-time strings as relativeTo option to
|
||||
Temporal.ZonedDateTime or Temporal.PlainDateTime instances
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const instance = new Temporal.Duration(1, 0, 0, 0, 24);
|
||||
|
||||
let relativeTo = "2019-11-01T00:00[America/Vancouver]";
|
||||
const result4 = instance.total({ unit: "days", relativeTo });
|
||||
assert.sameValue(result4, 366.96, "date-time + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00Z[America/Vancouver]";
|
||||
const result5 = instance.total({ unit: "days", relativeTo });
|
||||
assert.sameValue(result5, 366.96, "date-time + Z + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00-07:00[America/Vancouver]";
|
||||
const result6 = instance.total({ unit: "days", relativeTo });
|
||||
assert.sameValue(result6, 366.96, "date-time + offset + IANA annotation is a zoned relativeTo");
|
||||
|
||||
relativeTo = "2019-11-01T00:00+04:15[America/Vancouver]";
|
||||
assert.throws(RangeError, () => instance.total({ unit: "days", relativeTo }), "date-time + offset + IANA annotation throws if wall time and exact time mismatch");
|
28
test/intl402/Temporal/Instant/prototype/toString/timezone-string-datetime.js
vendored
Normal file
28
test/intl402/Temporal/Instant/prototype/toString/timezone-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,28 @@
|
|||
// 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.instant.prototype.tostring
|
||||
description: Conversion of ISO date-time strings to Temporal.TimeZone instances (with Intl time zones)
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const instance = new Temporal.Instant(0n);
|
||||
|
||||
let timeZone = "2021-08-19T17:30[America/Vancouver]";
|
||||
const result1 = instance.toString({ timeZone });
|
||||
assert.sameValue(result1.substr(-6), "-08:00", "date-time + IANA annotation is the IANA time zone");
|
||||
const result2 = instance.toString({ timeZone: { timeZone } });
|
||||
assert.sameValue(result2.substr(-6), "-08:00", "date-time + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30Z[America/Vancouver]";
|
||||
const result3 = instance.toString({ timeZone });
|
||||
assert.sameValue(result3.substr(-6), "-08:00", "date-time + Z + IANA annotation is the IANA time zone");
|
||||
const result4 = instance.toString({ timeZone: { timeZone } });
|
||||
assert.sameValue(result4.substr(-6), "-08:00", "date-time + Z + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30-07:00[America/Vancouver]";
|
||||
const result5 = instance.toString({ timeZone });
|
||||
assert.sameValue(result5.substr(-6), "-08:00", "date-time + offset + IANA annotation is the IANA time zone");
|
||||
const result6 = instance.toString({ timeZone: { timeZone } });
|
||||
assert.sameValue(result6.substr(-6), "-08:00", "date-time + offset + IANA annotation is the IANA time zone (string in property bag)");
|
28
test/intl402/Temporal/Instant/prototype/toZonedDateTime/timezone-string-datetime.js
vendored
Normal file
28
test/intl402/Temporal/Instant/prototype/toZonedDateTime/timezone-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,28 @@
|
|||
// 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.instant.prototype.tozoneddatetime
|
||||
description: Conversion of ISO date-time strings to Temporal.TimeZone instances (with Intl time zones)
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const instance = new Temporal.Instant(0n);
|
||||
|
||||
let timeZone = "2021-08-19T17:30[America/Vancouver]";
|
||||
const result1 = instance.toZonedDateTime({ timeZone, calendar: "iso8601" });
|
||||
assert.sameValue(result1.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone");
|
||||
const result2 = instance.toZonedDateTime({ timeZone: { timeZone }, calendar: "iso8601" });
|
||||
assert.sameValue(result2.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30Z[America/Vancouver]";
|
||||
const result3 = instance.toZonedDateTime({ timeZone, calendar: "iso8601" });
|
||||
assert.sameValue(result3.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone");
|
||||
const result4 = instance.toZonedDateTime({ timeZone: { timeZone }, calendar: "iso8601" });
|
||||
assert.sameValue(result4.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30-07:00[America/Vancouver]";
|
||||
const result5 = instance.toZonedDateTime({ timeZone, calendar: "iso8601" });
|
||||
assert.sameValue(result5.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone");
|
||||
const result6 = instance.toZonedDateTime({ timeZone: { timeZone }, calendar: "iso8601" });
|
||||
assert.sameValue(result6.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone (string in property bag)");
|
28
test/intl402/Temporal/Instant/prototype/toZonedDateTimeISO/timezone-string-datetime.js
vendored
Normal file
28
test/intl402/Temporal/Instant/prototype/toZonedDateTimeISO/timezone-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,28 @@
|
|||
// 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.instant.prototype.tozoneddatetimeiso
|
||||
description: Conversion of ISO date-time strings to Temporal.TimeZone instances (with Intl time zones)
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const instance = new Temporal.Instant(0n);
|
||||
|
||||
let timeZone = "2021-08-19T17:30[America/Vancouver]";
|
||||
const result1 = instance.toZonedDateTimeISO(timeZone);
|
||||
assert.sameValue(result1.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone");
|
||||
const result2 = instance.toZonedDateTimeISO({ timeZone });
|
||||
assert.sameValue(result2.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30Z[America/Vancouver]";
|
||||
const result3 = instance.toZonedDateTimeISO(timeZone);
|
||||
assert.sameValue(result3.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone");
|
||||
const result4 = instance.toZonedDateTimeISO({ timeZone });
|
||||
assert.sameValue(result4.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30-07:00[America/Vancouver]";
|
||||
const result5 = instance.toZonedDateTimeISO(timeZone);
|
||||
assert.sameValue(result5.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone");
|
||||
const result6 = instance.toZonedDateTimeISO({ timeZone });
|
||||
assert.sameValue(result6.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone (string in property bag)");
|
|
@ -1,4 +1,4 @@
|
|||
// Copyright (C) 2021 Igalia, S.L. All rights reserved.
|
||||
// Copyright (C) 2022 Igalia, S.L. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
|
||||
/*---
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
// Copyright (C) 2021 Igalia, S.L. All rights reserved.
|
||||
// Copyright (C) 2022 Igalia, S.L. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
|
||||
/*---
|
||||
|
|
28
test/intl402/Temporal/PlainDate/prototype/toZonedDateTime/timezone-string-datetime.js
vendored
Normal file
28
test/intl402/Temporal/PlainDate/prototype/toZonedDateTime/timezone-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,28 @@
|
|||
// 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.plaindate.prototype.tozoneddatetime
|
||||
description: Conversion of ISO date-time strings to Temporal.TimeZone instances (with Intl time zones)
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const instance = new Temporal.PlainDate(2000, 5, 2);
|
||||
|
||||
let timeZone = "2021-08-19T17:30[America/Vancouver]";
|
||||
const result1 = instance.toZonedDateTime(timeZone);
|
||||
assert.sameValue(result1.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone");
|
||||
const result2 = instance.toZonedDateTime({ timeZone });
|
||||
assert.sameValue(result2.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30Z[America/Vancouver]";
|
||||
const result3 = instance.toZonedDateTime(timeZone);
|
||||
assert.sameValue(result3.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone");
|
||||
const result4 = instance.toZonedDateTime({ timeZone });
|
||||
assert.sameValue(result4.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30-07:00[America/Vancouver]";
|
||||
const result5 = instance.toZonedDateTime(timeZone);
|
||||
assert.sameValue(result5.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone");
|
||||
const result6 = instance.toZonedDateTime({ timeZone });
|
||||
assert.sameValue(result6.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone (string in property bag)");
|
28
test/intl402/Temporal/PlainDateTime/prototype/toZonedDateTime/timezone-string-datetime.js
vendored
Normal file
28
test/intl402/Temporal/PlainDateTime/prototype/toZonedDateTime/timezone-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,28 @@
|
|||
// 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.plaindatetime.prototype.tozoneddatetime
|
||||
description: Conversion of ISO date-time strings to Temporal.TimeZone instances (with Intl time zones)
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const instance = new Temporal.PlainDateTime(2000, 5, 2);
|
||||
|
||||
let timeZone = "2021-08-19T17:30[America/Vancouver]";
|
||||
const result1 = instance.toZonedDateTime(timeZone);
|
||||
assert.sameValue(result1.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone");
|
||||
const result2 = instance.toZonedDateTime({ timeZone });
|
||||
assert.sameValue(result2.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30Z[America/Vancouver]";
|
||||
const result3 = instance.toZonedDateTime(timeZone);
|
||||
assert.sameValue(result3.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone");
|
||||
const result4 = instance.toZonedDateTime({ timeZone });
|
||||
assert.sameValue(result4.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30-07:00[America/Vancouver]";
|
||||
const result5 = instance.toZonedDateTime(timeZone);
|
||||
assert.sameValue(result5.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone");
|
||||
const result6 = instance.toZonedDateTime({ timeZone });
|
||||
assert.sameValue(result6.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone (string in property bag)");
|
28
test/intl402/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-datetime.js
vendored
Normal file
28
test/intl402/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,28 @@
|
|||
// 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 Intl 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.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone");
|
||||
const result2 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone: { timeZone } });
|
||||
assert.sameValue(result2.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30Z[America/Vancouver]";
|
||||
const result3 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone });
|
||||
assert.sameValue(result3.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone");
|
||||
const result4 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone: { timeZone } });
|
||||
assert.sameValue(result4.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30-07:00[America/Vancouver]";
|
||||
const result5 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone });
|
||||
assert.sameValue(result5.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone");
|
||||
const result6 = instance.toZonedDateTime({ plainDate: new Temporal.PlainDate(2000, 5, 2), timeZone: { timeZone } });
|
||||
assert.sameValue(result6.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone (string in property bag)");
|
|
@ -0,0 +1,26 @@
|
|||
// 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.timezone.from
|
||||
description: Conversion of ISO date-time strings to Temporal.TimeZone instances (with Intl time zones)
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
let timeZone = "2021-08-19T17:30[America/Vancouver]";
|
||||
const result1 = Temporal.TimeZone.from(timeZone);
|
||||
assert.sameValue(result1.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone");
|
||||
const result2 = Temporal.TimeZone.from({ timeZone });
|
||||
assert.sameValue(result2.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30Z[America/Vancouver]";
|
||||
const result3 = Temporal.TimeZone.from(timeZone);
|
||||
assert.sameValue(result3.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone");
|
||||
const result4 = Temporal.TimeZone.from({ timeZone });
|
||||
assert.sameValue(result4.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30-07:00[America/Vancouver]";
|
||||
const result5 = Temporal.TimeZone.from(timeZone);
|
||||
assert.sameValue(result5.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone");
|
||||
const result6 = Temporal.TimeZone.from({ timeZone });
|
||||
assert.sameValue(result6.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone (string in property bag)");
|
|
@ -0,0 +1,26 @@
|
|||
// 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.zoneddatetime.from
|
||||
description: Conversion of ISO date-time strings to Temporal.TimeZone instances (with Intl time zones)
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
let timeZone = "2021-08-19T17:30[America/Vancouver]";
|
||||
const result1 = Temporal.ZonedDateTime.from({ year: 2000, month: 5, day: 2, timeZone });
|
||||
assert.sameValue(result1.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone");
|
||||
const result2 = Temporal.ZonedDateTime.from({ year: 2000, month: 5, day: 2, timeZone: { timeZone } });
|
||||
assert.sameValue(result2.timeZone.id, "America/Vancouver", "date-time + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30Z[America/Vancouver]";
|
||||
const result3 = Temporal.ZonedDateTime.from({ year: 2000, month: 5, day: 2, timeZone });
|
||||
assert.sameValue(result3.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone");
|
||||
const result4 = Temporal.ZonedDateTime.from({ year: 2000, month: 5, day: 2, timeZone: { timeZone } });
|
||||
assert.sameValue(result4.timeZone.id, "America/Vancouver", "date-time + Z + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30-07:00[America/Vancouver]";
|
||||
const result5 = Temporal.ZonedDateTime.from({ year: 2000, month: 5, day: 2, timeZone });
|
||||
assert.sameValue(result5.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone");
|
||||
const result6 = Temporal.ZonedDateTime.from({ year: 2000, month: 5, day: 2, timeZone: { timeZone } });
|
||||
assert.sameValue(result6.timeZone.id, "America/Vancouver", "date-time + offset + IANA annotation is the IANA time zone (string in property bag)");
|
22
test/intl402/Temporal/ZonedDateTime/prototype/equals/timezone-string-datetime.js
vendored
Normal file
22
test/intl402/Temporal/ZonedDateTime/prototype/equals/timezone-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,22 @@
|
|||
// 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.zoneddatetime.prototype.equals
|
||||
description: Conversion of ISO date-time strings to Temporal.TimeZone instances (with Intl time zones)
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const expectedTimeZone = "America/Vancouver";
|
||||
const instance = new Temporal.ZonedDateTime(0n, expectedTimeZone);
|
||||
let timeZone = "2021-08-19T17:30[America/Vancouver]";
|
||||
assert(instance.equals({ year: 1969, month: 12, day: 31, hour: 16, timeZone }), "date-time + IANA annotation is the IANA time zone");
|
||||
assert(instance.equals({ year: 1969, month: 12, day: 31, hour: 16, timeZone: { timeZone } }), "date-time + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30Z[America/Vancouver]";
|
||||
assert(instance.equals({ year: 1969, month: 12, day: 31, hour: 16, timeZone }), "date-time + Z + IANA annotation is the IANA time zone");
|
||||
assert(instance.equals({ year: 1969, month: 12, day: 31, hour: 16, timeZone: { timeZone } }), "date-time + Z + IANA annotation is the IANA time zone (string in property bag)");
|
||||
|
||||
timeZone = "2021-08-19T17:30-07:00[America/Vancouver]";
|
||||
assert(instance.equals({ year: 1969, month: 12, day: 31, hour: 16, timeZone }), "date-time + offset + IANA annotation is the IANA time zone");
|
||||
assert(instance.equals({ year: 1969, month: 12, day: 31, hour: 16, timeZone: { timeZone } }), "date-time + offset + IANA annotation is the IANA time zone (string in property bag)");
|
22
test/intl402/Temporal/ZonedDateTime/prototype/since/timezone-string-datetime.js
vendored
Normal file
22
test/intl402/Temporal/ZonedDateTime/prototype/since/timezone-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,22 @@
|
|||
// 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.zoneddatetime.prototype.since
|
||||
description: Conversion of ISO date-time strings to Temporal.TimeZone instances (with Intl time zones)
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const expectedTimeZone = "America/Vancouver";
|
||||
const instance = new Temporal.ZonedDateTime(0n, expectedTimeZone);
|
||||
let timeZone = "2021-08-19T17:30[America/Vancouver]";
|
||||
instance.since({ year: 2020, month: 5, day: 2, timeZone });
|
||||
instance.since({ year: 2020, month: 5, day: 2, timeZone: { timeZone } });
|
||||
|
||||
timeZone = "2021-08-19T17:30Z[America/Vancouver]";
|
||||
instance.since({ year: 2020, month: 5, day: 2, timeZone });
|
||||
instance.since({ year: 2020, month: 5, day: 2, timeZone: { timeZone } });
|
||||
|
||||
timeZone = "2021-08-19T17:30-07:00[America/Vancouver]";
|
||||
instance.since({ year: 2020, month: 5, day: 2, timeZone });
|
||||
instance.since({ year: 2020, month: 5, day: 2, timeZone: { timeZone } });
|
22
test/intl402/Temporal/ZonedDateTime/prototype/until/timezone-string-datetime.js
vendored
Normal file
22
test/intl402/Temporal/ZonedDateTime/prototype/until/timezone-string-datetime.js
vendored
Normal file
|
@ -0,0 +1,22 @@
|
|||
// 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.zoneddatetime.prototype.until
|
||||
description: Conversion of ISO date-time strings to Temporal.TimeZone instances (with Intl time zones)
|
||||
features: [Temporal]
|
||||
---*/
|
||||
|
||||
const expectedTimeZone = "America/Vancouver";
|
||||
const instance = new Temporal.ZonedDateTime(0n, expectedTimeZone);
|
||||
let timeZone = "2021-08-19T17:30[America/Vancouver]";
|
||||
instance.until({ year: 2020, month: 5, day: 2, timeZone });
|
||||
instance.until({ year: 2020, month: 5, day: 2, timeZone: { timeZone } });
|
||||
|
||||
timeZone = "2021-08-19T17:30Z[America/Vancouver]";
|
||||
instance.until({ year: 2020, month: 5, day: 2, timeZone });
|
||||
instance.until({ year: 2020, month: 5, day: 2, timeZone: { timeZone } });
|
||||
|
||||
timeZone = "2021-08-19T17:30-07:00[America/Vancouver]";
|
||||
instance.until({ year: 2020, month: 5, day: 2, timeZone });
|
||||
instance.until({ year: 2020, month: 5, day: 2, timeZone: { timeZone } });
|
Loading…
Reference in New Issue