diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /js/src/tests/test262/harness/temporalHelpers-cross-date-line-time-zone.js | |
parent | Initial commit. (diff) | |
download | thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.zip |
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/tests/test262/harness/temporalHelpers-cross-date-line-time-zone.js')
-rw-r--r-- | js/src/tests/test262/harness/temporalHelpers-cross-date-line-time-zone.js | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/js/src/tests/test262/harness/temporalHelpers-cross-date-line-time-zone.js b/js/src/tests/test262/harness/temporalHelpers-cross-date-line-time-zone.js new file mode 100644 index 0000000000..b2c0abd294 --- /dev/null +++ b/js/src/tests/test262/harness/temporalHelpers-cross-date-line-time-zone.js @@ -0,0 +1,59 @@ +// |reftest| skip -- Temporal is not supported +// Copyright (C) 2022 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. + +/*--- +description: > + Verify the time zone arithmetic used in + TemporalHelpers.crossDateLineTimeZone() against the Pacific/Apia time zone in + the implementation's time zone database +includes: [compareArray.js, temporalHelpers.js] +features: [Temporal] +---*/ + +// No need to test this on hosts that don't provide an Intl object. It's +// sufficient that the logic is tested on at least one host. +if (typeof globalThis.Intl !== "undefined") { + const tz = TemporalHelpers.crossDateLineTimeZone(); + const realTz = new Temporal.TimeZone('Pacific/Apia'); + const shiftInstant = Temporal.Instant.from('2011-12-30T10:00:00Z'); + + assert.sameValue( + tz.getOffsetNanosecondsFor(shiftInstant), + realTz.getOffsetNanosecondsFor(shiftInstant), + 'offset at shift instant' + ); + const minus1 = shiftInstant.subtract({ hours: 1 }); + assert.sameValue( + tz.getOffsetNanosecondsFor(minus1), + realTz.getOffsetNanosecondsFor(minus1), + 'offset at 1 hour before shift' + ); + const plus1 = shiftInstant.add({ hours: 1 }); + assert.sameValue( + tz.getOffsetNanosecondsFor(plus1), + realTz.getOffsetNanosecondsFor(plus1), + 'offset at 1 hour after shift' + ); + + const middleOfSkippedDayWallTime = Temporal.PlainDateTime.from("2011-12-30T12:00"); + assert.compareArray( + tz.getPossibleInstantsFor(middleOfSkippedDayWallTime).map((i) => i.epochNanoseconds), + realTz.getPossibleInstantsFor(middleOfSkippedDayWallTime).map((i) => i.epochNanoseconds), + 'possible instants for middle of skipped day wall time' + ); + const before1 = middleOfSkippedDayWallTime.subtract({ days: 1 }); + assert.compareArray( + tz.getPossibleInstantsFor(before1).map((i) => i.epochNanoseconds), + realTz.getPossibleInstantsFor(before1).map((i) => i.epochNanoseconds), + 'possible instants for 1 day before skipped day' + ); + const after1 = middleOfSkippedDayWallTime.add({ days: 1 }); + assert.compareArray( + tz.getPossibleInstantsFor(after1).map((i) => i.epochNanoseconds), + realTz.getPossibleInstantsFor(after1).map((i) => i.epochNanoseconds), + 'possible instants for 1 day after skipped day' + ); +} + +reportCompare(0, 0); |