mirror of
https://github.com/tc39/test262.git
synced 2025-07-31 01:44:54 +02:00
This copies over the tests that previously existed in the tc39/proposal-temporal repository. For context, see thread starting at: https://github.com/tc39/test262/issues/3002#issuecomment-926234480 In service of https://github.com/tc39/test262/issues/3002
26 lines
1.1 KiB
JavaScript
26 lines
1.1 KiB
JavaScript
// 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.plaindatetime.compare
|
|
description: A pre-epoch value is handled correctly by the modulo operation in GetISOPartsFromEpoch
|
|
info: |
|
|
sec-temporal-getisopartsfromepoch step 1:
|
|
1. Let _remainderNs_ be the mathematical value whose sign is the sign of _epochNanoseconds_ and whose magnitude is abs(_epochNanoseconds_) modulo 10<sup>6</sup>.
|
|
sec-temporal-builtintimezonegetplaindatetimefor step 2:
|
|
2. Let _result_ be ! GetISOPartsFromEpoch(_instant_.[[Nanoseconds]]).
|
|
features: [Temporal]
|
|
---*/
|
|
|
|
const zoned = new Temporal.ZonedDateTime(-13849764_999_999_999n, "UTC");
|
|
const plain = new Temporal.PlainDateTime(1969, 7, 24, 16, 50, 35, 0, 0, 1);
|
|
|
|
// This code path shows up anywhere we convert an exact time, before the Unix
|
|
// epoch, with nonzero microseconds or nanoseconds, into a wall time.
|
|
|
|
const result1 = Temporal.PlainDateTime.compare(plain, zoned);
|
|
assert.sameValue(result1, 0);
|
|
|
|
const result2 = Temporal.PlainDateTime.compare(zoned, plain);
|
|
assert.sameValue(result2, 0);
|