diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /js/src/tests/test262/built-ins/Temporal/Duration/prototype/total/relativeto-zoneddatetime-normalized-time-duration-to-days-range-errors.js | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/tests/test262/built-ins/Temporal/Duration/prototype/total/relativeto-zoneddatetime-normalized-time-duration-to-days-range-errors.js')
-rw-r--r-- | js/src/tests/test262/built-ins/Temporal/Duration/prototype/total/relativeto-zoneddatetime-normalized-time-duration-to-days-range-errors.js | 128 |
1 files changed, 128 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/Temporal/Duration/prototype/total/relativeto-zoneddatetime-normalized-time-duration-to-days-range-errors.js b/js/src/tests/test262/built-ins/Temporal/Duration/prototype/total/relativeto-zoneddatetime-normalized-time-duration-to-days-range-errors.js new file mode 100644 index 0000000000..d415117f89 --- /dev/null +++ b/js/src/tests/test262/built-ins/Temporal/Duration/prototype/total/relativeto-zoneddatetime-normalized-time-duration-to-days-range-errors.js @@ -0,0 +1,128 @@ +// |reftest| skip-if(!this.hasOwnProperty('Temporal')) -- Temporal is not enabled unconditionally +// Copyright (C) 2022 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-temporal.duration.prototype.total +description: > + Abstract operation NormalizedTimeDurationToDays can throw four different + RangeErrors. +info: | + NormalizedTimeDurationToDays ( norm, zonedRelativeTo, timeZoneRec [ , precalculatedPlainDateTime ] ) + 22. If days < 0 and sign = 1, throw a RangeError exception. + 23. If days > 0 and sign = -1, throw a RangeError exception. + ... + 25. If NormalizedTimeDurationSign(_norm_) = 1 and sign = -1, throw a RangeError exception. + ... + 28. If dayLength ≥ 2⁵³, throw a RangeError exception. +features: [Temporal, BigInt] +includes: [temporalHelpers.js] +---*/ + +const oneNsDuration = Temporal.Duration.from({ nanoseconds: 1 }); +const negOneNsDuration = Temporal.Duration.from({ nanoseconds: -1 }); +const dayNs = 86_400_000_000_000; +const epochInstant = new Temporal.Instant(0n); + +function timeZoneSubstituteValues( + getPossibleInstantsFor, + getOffsetNanosecondsFor +) { + const tz = new Temporal.TimeZone("UTC"); + TemporalHelpers.substituteMethod( + tz, + "getPossibleInstantsFor", + getPossibleInstantsFor + ); + TemporalHelpers.substituteMethod( + tz, + "getOffsetNanosecondsFor", + getOffsetNanosecondsFor + ); + return tz; +} + +// Step 22: days < 0 and sign = 1 +let zdt = new Temporal.ZonedDateTime( + 0n, // Sets _startNs_ to 0 + timeZoneSubstituteValues( + [[epochInstant]], // Returned in step 16, setting _relativeResult_ + [ + TemporalHelpers.SUBSTITUTE_SKIP, // Pre-conversion in Duration.p.total + dayNs - 1, // Returned in step 8, setting _startDateTime_ + -dayNs + 1, // Returned in step 9, setting _endDateTime_ + ] + ) +); +assert.throws(RangeError, () => + // Using 1ns duration _nanoseconds_ to 1 and _sign_ to 1 + oneNsDuration.total({ + relativeTo: zdt, + unit: "day", + }), + "RangeError when days < 0 and sign = 1" +); + +// Step 23: days > 0 and sign = -1 +zdt = new Temporal.ZonedDateTime( + 0n, // Sets _startNs_ to 0 + timeZoneSubstituteValues( + [[epochInstant]], // Returned in step 16, setting _relativeResult_ + [ + TemporalHelpers.SUBSTITUTE_SKIP, // Pre-conversion in Duration.p.total + -dayNs + 1, // Returned in step 8, setting _startDateTime_ + dayNs - 1, // Returned in step 9, setting _endDateTime_ + ] + ) +); +assert.throws(RangeError, () => + // Using -1ns duration sets _nanoseconds_ to -1 and _sign_ to -1 + negOneNsDuration.total({ + relativeTo: zdt, + unit: "day", + }), + "RangeError when days > 0 and sign = -1" +); + +// Step 25: nanoseconds > 0 and sign = -1 +zdt = new Temporal.ZonedDateTime( + 0n, // Sets _startNs_ to 0 + timeZoneSubstituteValues( + [ + [new Temporal.Instant(-2n)], // Returned in step 16, setting _relativeResult_ + [new Temporal.Instant(-4n)], // Returned in step 21.a, setting _oneDayFarther_ + ], + [ + TemporalHelpers.SUBSTITUTE_SKIP, // pre-conversion in Duration.p.total + dayNs - 1, // Returned in step 8, setting _startDateTime_ + -dayNs + 1, // Returned in step 9, setting _endDateTime_ + ] + ) +); +assert.throws(RangeError, () => + // Using -1ns duration sets _nanoseconds_ to -1 and _sign_ to -1 + negOneNsDuration.total({ + relativeTo: zdt, + unit: "day", + }), + "RangeError when nanoseconds > 0 and sign = -1" +); + +// Step 28: day length is an unsafe integer +zdt = new Temporal.ZonedDateTime( + 0n, + timeZoneSubstituteValues( + // Not called in step 16 because _days_ = 0 + // Returned in step 21.a, making _oneDayFarther_ 2^53 ns later than _relativeResult_ + [[new Temporal.Instant(2n ** 53n)]], + [] + ) +); +assert.throws(RangeError, () => + oneNsDuration.total({ + relativeTo: zdt, + unit: "days", + }), + "Should throw RangeError when time zone calculates an outrageous day length" +); + +reportCompare(0, 0); |