Temporal: Extend toJSON/toString tests.

This commit is contained in:
Ms2ger 2022-05-20 16:23:34 +02:00 committed by Philip Chimento
parent 2de2fe3084
commit 7fca6637e9
12 changed files with 95 additions and 51 deletions

View File

@ -1,16 +1,23 @@
// Copyright (C) 2020 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. // This code is governed by the BSD license found in the LICENSE file.
/*--- /*---
esid: sec-temporal.instant.prototype.tojson esid: sec-temporal.instant.prototype.tojson
description: Basic tests for toJSON() description: Basic behavior for toJSON
features: [Temporal] features: [BigInt, Temporal]
---*/ ---*/
const instantBeforeEpoch = Temporal.Instant.from("1963-02-13T10:36:29.123456789+01:00"); const tests = [
assert.sameValue(instantBeforeEpoch.toJSON(), "1963-02-13T09:36:29.123456789Z"); [new Temporal.Instant(192_258_181_000_000_000n), "1976-02-04T05:03:01Z"],
[new Temporal.Instant(0n), "1970-01-01T00:00:00Z"],
[new Temporal.Instant(30_000_000_000n), "1970-01-01T00:00:30Z"],
[new Temporal.Instant(30_123_400_000n), "1970-01-01T00:00:30.1234Z"],
];
const instantAfterEpoch = Temporal.Instant.from("1976-11-18T15:23:30.123456789+01:00"); const options = new Proxy({}, {
assert.sameValue(instantAfterEpoch.toJSON(), "1976-11-18T14:23:30.123456789Z"); get() { throw new Test262Error("should not get properties off argument") }
assert.sameValue(instantAfterEpoch.toJSON("+01:00"), "1976-11-18T14:23:30.123456789Z", });
"after epoch with ignored argument"); for (const [instant, expected] of tests) {
assert.sameValue(instant.toJSON(), expected, "toJSON without argument");
assert.sameValue(instant.toJSON(options), expected, "toJSON with argument");
}

View File

@ -7,14 +7,11 @@ description: auto value for fractionalSecondDigits option
features: [BigInt, Temporal] features: [BigInt, Temporal]
---*/ ---*/
const zeroSeconds = new Temporal.Instant(0n);
const wholeSeconds = new Temporal.Instant(30_000_000_000n);
const subSeconds = new Temporal.Instant(30_123_400_000n);
const tests = [ const tests = [
[zeroSeconds, "1970-01-01T00:00:00Z"], [new Temporal.Instant(192_258_181_000_000_000n), "1976-02-04T05:03:01Z"],
[wholeSeconds, "1970-01-01T00:00:30Z"], [new Temporal.Instant(0n), "1970-01-01T00:00:00Z"],
[subSeconds, "1970-01-01T00:00:30.1234Z"], [new Temporal.Instant(30_000_000_000n), "1970-01-01T00:00:30Z"],
[new Temporal.Instant(30_123_400_000n), "1970-01-01T00:00:30.1234Z"],
]; ];
for (const [instant, expected] of tests) { for (const [instant, expected] of tests) {

View File

@ -7,10 +7,13 @@ description: Number for fractionalSecondDigits option
features: [BigInt, Temporal] features: [BigInt, Temporal]
---*/ ---*/
const fewSeconds = new Temporal.Instant(192_258_181_000_000_000n);
const zeroSeconds = new Temporal.Instant(0n); const zeroSeconds = new Temporal.Instant(0n);
const wholeSeconds = new Temporal.Instant(30_000_000_000n); const wholeSeconds = new Temporal.Instant(30_000_000_000n);
const subSeconds = new Temporal.Instant(30_123_400_000n); const subSeconds = new Temporal.Instant(30_123_400_000n);
assert.sameValue(fewSeconds.toString({ fractionalSecondDigits: 0 }), "1976-02-04T05:03:01Z",
"pads parts with 0");
assert.sameValue(subSeconds.toString({ fractionalSecondDigits: 0 }), "1970-01-01T00:00:30Z", assert.sameValue(subSeconds.toString({ fractionalSecondDigits: 0 }), "1970-01-01T00:00:30Z",
"truncates 4 decimal places to 0"); "truncates 4 decimal places to 0");
assert.sameValue(zeroSeconds.toString({ fractionalSecondDigits: 2 }), "1970-01-01T00:00:00.00Z", assert.sameValue(zeroSeconds.toString({ fractionalSecondDigits: 2 }), "1970-01-01T00:00:00.00Z",

View File

@ -16,14 +16,11 @@ info: |
features: [Temporal] features: [Temporal]
---*/ ---*/
const zeroSeconds = new Temporal.Instant(0n);
const wholeSeconds = new Temporal.Instant(30_000_000_000n);
const subSeconds = new Temporal.Instant(30_123_400_000n);
const tests = [ const tests = [
[zeroSeconds, "1970-01-01T00:00:00Z"], [new Temporal.Instant(192_258_181_000_000_000n), "1976-02-04T05:03:01Z"],
[wholeSeconds, "1970-01-01T00:00:30Z"], [new Temporal.Instant(0n), "1970-01-01T00:00:00Z"],
[subSeconds, "1970-01-01T00:00:30.1234Z"], [new Temporal.Instant(30_000_000_000n), "1970-01-01T00:00:30Z"],
[new Temporal.Instant(30_123_400_000n), "1970-01-01T00:00:30.1234Z"],
]; ];
for (const [instant, expected] of tests) { for (const [instant, expected] of tests) {

View File

@ -0,0 +1,23 @@
// 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.tojson
description: Basic behavior for toJSON
features: [Temporal]
---*/
const tests = [
[new Temporal.PlainDateTime(1976, 2, 4, 5, 3, 1), "1976-02-04T05:03:01"],
[new Temporal.PlainDateTime(1976, 11, 18, 15, 23), "1976-11-18T15:23:00"],
[new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30), "1976-11-18T15:23:30"],
[new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30, 123, 400), "1976-11-18T15:23:30.1234"],
];
const options = new Proxy({}, {
get() { throw new Test262Error("should not get properties off argument") }
});
for (const [datetime, expected] of tests) {
assert.sameValue(datetime.toJSON(), expected, "toJSON without argument");
assert.sameValue(datetime.toJSON(options), expected, "toJSON with argument");
}

View File

@ -7,14 +7,11 @@ description: auto value for fractionalSecondDigits option
features: [Temporal] features: [Temporal]
---*/ ---*/
const zeroSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23);
const wholeSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30);
const subSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30, 123, 400);
const tests = [ const tests = [
[zeroSeconds, "1976-11-18T15:23:00"], [new Temporal.PlainDateTime(1976, 2, 4, 5, 3, 1), "1976-02-04T05:03:01"],
[wholeSeconds, "1976-11-18T15:23:30"], [new Temporal.PlainDateTime(1976, 11, 18, 15, 23), "1976-11-18T15:23:00"],
[subSeconds, "1976-11-18T15:23:30.1234"], [new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30), "1976-11-18T15:23:30"],
[new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30, 123, 400), "1976-11-18T15:23:30.1234"],
]; ];
for (const [datetime, expected] of tests) { for (const [datetime, expected] of tests) {

View File

@ -7,10 +7,13 @@ description: Number for fractionalSecondDigits option
features: [Temporal] features: [Temporal]
---*/ ---*/
const fewSeconds = new Temporal.PlainDateTime(1976, 2, 4, 5, 3, 1);
const zeroSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23); const zeroSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23);
const wholeSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30); const wholeSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30);
const subSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30, 123, 400); const subSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30, 123, 400);
assert.sameValue(fewSeconds.toString({ fractionalSecondDigits: 0 }), "1976-02-04T05:03:01",
"pads parts with 0");
assert.sameValue(subSeconds.toString({ fractionalSecondDigits: 0 }), "1976-11-18T15:23:30", assert.sameValue(subSeconds.toString({ fractionalSecondDigits: 0 }), "1976-11-18T15:23:30",
"truncates 4 decimal places to 0"); "truncates 4 decimal places to 0");
assert.sameValue(zeroSeconds.toString({ fractionalSecondDigits: 2 }), "1976-11-18T15:23:00.00", assert.sameValue(zeroSeconds.toString({ fractionalSecondDigits: 2 }), "1976-11-18T15:23:00.00",

View File

@ -16,14 +16,11 @@ info: |
features: [Temporal] features: [Temporal]
---*/ ---*/
const zeroSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23);
const wholeSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30);
const subSeconds = new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30, 123, 400);
const tests = [ const tests = [
[zeroSeconds, "1976-11-18T15:23:00"], [new Temporal.PlainDateTime(1976, 2, 4, 5, 3, 1), "1976-02-04T05:03:01"],
[wholeSeconds, "1976-11-18T15:23:30"], [new Temporal.PlainDateTime(1976, 11, 18, 15, 23), "1976-11-18T15:23:00"],
[subSeconds, "1976-11-18T15:23:30.1234"], [new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30), "1976-11-18T15:23:30"],
[new Temporal.PlainDateTime(1976, 11, 18, 15, 23, 30, 123, 400), "1976-11-18T15:23:30.1234"],
]; ];
for (const [datetime, expected] of tests) { for (const [datetime, expected] of tests) {

View File

@ -0,0 +1,23 @@
// 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.tojson
description: Basic behavior for toJSON
features: [BigInt, Temporal]
---*/
const tests = [
[new Temporal.ZonedDateTime(192_258_181_000_000_000n, "UTC"), "1976-02-04T05:03:01+00:00[UTC]"],
[new Temporal.ZonedDateTime(0n, "UTC"), "1970-01-01T00:00:00+00:00[UTC]"],
[new Temporal.ZonedDateTime(30_000_000_000n, "UTC"), "1970-01-01T00:00:30+00:00[UTC]"],
[new Temporal.ZonedDateTime(30_123_400_000n, "UTC"), "1970-01-01T00:00:30.1234+00:00[UTC]"],
];
const options = new Proxy({}, {
get() { throw new Test262Error("should not get properties off argument") }
});
for (const [datetime, expected] of tests) {
assert.sameValue(datetime.toJSON(), expected, "toJSON without argument");
assert.sameValue(datetime.toJSON(options), expected, "toJSON with argument");
}

View File

@ -7,14 +7,11 @@ description: auto value for fractionalSecondDigits option
features: [BigInt, Temporal] features: [BigInt, Temporal]
---*/ ---*/
const zeroSeconds = new Temporal.ZonedDateTime(0n, "UTC");
const wholeSeconds = new Temporal.ZonedDateTime(30_000_000_000n, "UTC");
const subSeconds = new Temporal.ZonedDateTime(30_123_400_000n, "UTC");
const tests = [ const tests = [
[zeroSeconds, "1970-01-01T00:00:00+00:00[UTC]"], [new Temporal.ZonedDateTime(192_258_181_000_000_000n, "UTC"), "1976-02-04T05:03:01+00:00[UTC]"],
[wholeSeconds, "1970-01-01T00:00:30+00:00[UTC]"], [new Temporal.ZonedDateTime(0n, "UTC"), "1970-01-01T00:00:00+00:00[UTC]"],
[subSeconds, "1970-01-01T00:00:30.1234+00:00[UTC]"], [new Temporal.ZonedDateTime(30_000_000_000n, "UTC"), "1970-01-01T00:00:30+00:00[UTC]"],
[new Temporal.ZonedDateTime(30_123_400_000n, "UTC"), "1970-01-01T00:00:30.1234+00:00[UTC]"],
]; ];
for (const [datetime, expected] of tests) { for (const [datetime, expected] of tests) {

View File

@ -7,10 +7,13 @@ description: Number for fractionalSecondDigits option
features: [BigInt, Temporal] features: [BigInt, Temporal]
---*/ ---*/
const fewSeconds = new Temporal.ZonedDateTime(192_258_181_000_000_000n, "UTC");
const zeroSeconds = new Temporal.ZonedDateTime(0n, "UTC"); const zeroSeconds = new Temporal.ZonedDateTime(0n, "UTC");
const wholeSeconds = new Temporal.ZonedDateTime(30_000_000_000n, "UTC"); const wholeSeconds = new Temporal.ZonedDateTime(30_000_000_000n, "UTC");
const subSeconds = new Temporal.ZonedDateTime(30_123_400_000n, "UTC"); const subSeconds = new Temporal.ZonedDateTime(30_123_400_000n, "UTC");
assert.sameValue(fewSeconds.toString({ fractionalSecondDigits: 0 }), "1976-02-04T05:03:01+00:00[UTC]",
"pads parts with 0");
assert.sameValue(subSeconds.toString({ fractionalSecondDigits: 0 }), "1970-01-01T00:00:30+00:00[UTC]", assert.sameValue(subSeconds.toString({ fractionalSecondDigits: 0 }), "1970-01-01T00:00:30+00:00[UTC]",
"truncates 4 decimal places to 0"); "truncates 4 decimal places to 0");
assert.sameValue(zeroSeconds.toString({ fractionalSecondDigits: 2 }), "1970-01-01T00:00:00.00+00:00[UTC]", assert.sameValue(zeroSeconds.toString({ fractionalSecondDigits: 2 }), "1970-01-01T00:00:00.00+00:00[UTC]",

View File

@ -16,14 +16,11 @@ info: |
features: [Temporal] features: [Temporal]
---*/ ---*/
const zeroSeconds = new Temporal.ZonedDateTime(0n, "UTC");
const wholeSeconds = new Temporal.ZonedDateTime(30_000_000_000n, "UTC");
const subSeconds = new Temporal.ZonedDateTime(30_123_400_000n, "UTC");
const tests = [ const tests = [
[zeroSeconds, "1970-01-01T00:00:00+00:00[UTC]"], [new Temporal.ZonedDateTime(192_258_181_000_000_000n, "UTC"), "1976-02-04T05:03:01+00:00[UTC]"],
[wholeSeconds, "1970-01-01T00:00:30+00:00[UTC]"], [new Temporal.ZonedDateTime(0n, "UTC"), "1970-01-01T00:00:00+00:00[UTC]"],
[subSeconds, "1970-01-01T00:00:30.1234+00:00[UTC]"], [new Temporal.ZonedDateTime(30_000_000_000n, "UTC"), "1970-01-01T00:00:30+00:00[UTC]"],
[new Temporal.ZonedDateTime(30_123_400_000n, "UTC"), "1970-01-01T00:00:30.1234+00:00[UTC]"],
]; ];
for (const [datetime, expected] of tests) { for (const [datetime, expected] of tests) {