mirror of https://github.com/tc39/test262.git
Temporal: Add test for Duration going out of range after rounding
After rounding relative to a ZonedDateTime, we have to potentially adjust for DST. With a time zone providing nonsensical values, the duration may go out of range. See: tc39/proposal-temporal#2801
This commit is contained in:
parent
f03883c7bb
commit
d7aec8e178
29
test/built-ins/Temporal/Duration/prototype/round/out-of-range-when-adjusting-rounded-days.js
vendored
Normal file
29
test/built-ins/Temporal/Duration/prototype/round/out-of-range-when-adjusting-rounded-days.js
vendored
Normal file
|
@ -0,0 +1,29 @@
|
|||
// 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.duration.prototype.round
|
||||
description: >
|
||||
When adjusting the rounded days after rounding relative to a ZonedDateTime,
|
||||
the duration may go out of range
|
||||
features: [Temporal]
|
||||
includes: [temporalHelpers.js]
|
||||
---*/
|
||||
|
||||
// Based on a test case by André Bargull
|
||||
|
||||
const d = new Temporal.Duration(0, 0, 0, /* days = */ 1, 0, 0, /* s = */ Number.MAX_SAFE_INTEGER - 86400, 0, 0, /* ns = */ 999_999_999);
|
||||
|
||||
const timeZone = new Temporal.TimeZone("UTC");
|
||||
TemporalHelpers.substituteMethod(timeZone, 'getPossibleInstantsFor', [
|
||||
TemporalHelpers.SUBSTITUTE_SKIP,
|
||||
[new Temporal.Instant(1n)],
|
||||
]);
|
||||
|
||||
const relativeTo = new Temporal.ZonedDateTime(0n, timeZone);
|
||||
|
||||
assert.throws(RangeError, () => d.round({
|
||||
largestUnit: 'nanoseconds',
|
||||
roundingIncrement: 2,
|
||||
relativeTo
|
||||
}));
|
Loading…
Reference in New Issue