mirror of
https://github.com/tc39/test262.git
synced 2025-09-30 13:38:48 +02:00
Similar to the previous commit with property bags, many existing tests use a Proxy to test the order of observable operations which involve user code passed in as part of a Temporal.TimeZone object. I am going to write several more tests that do this, as well. This seems like a good thing to put into TemporalHelpers, where it can be implemented consistently so that we don't get discrepancies in which operations are tracked. Updates existing tests to use this helper.
33 lines
1.0 KiB
JavaScript
33 lines
1.0 KiB
JavaScript
// Copyright (C) 2020 Igalia, S.L. All rights reserved.
|
|
// This code is governed by the BSD license found in the LICENSE file.
|
|
|
|
/*---
|
|
esid: sec-temporal.now.plaindatetime
|
|
description: The value returned by TimeZone.getOffsetNanosecondsFor affects the result
|
|
includes: [compareArray.js, temporalHelpers.js]
|
|
features: [Temporal]
|
|
---*/
|
|
|
|
const actual = [];
|
|
const expected = [
|
|
"has timeZone.timeZone",
|
|
"get timeZone.getOffsetNanosecondsFor",
|
|
"call timeZone.getOffsetNanosecondsFor",
|
|
];
|
|
|
|
const timeZone = TemporalHelpers.timeZoneObserver(actual, "timeZone", {
|
|
getOffsetNanosecondsFor(instant) {
|
|
assert.sameValue(instant instanceof Temporal.Instant, true, "Instant");
|
|
return -Number(instant.epochNanoseconds % 86400_000_000_000n);
|
|
},
|
|
});
|
|
|
|
const calendar = Temporal.Calendar.from("iso8601");
|
|
|
|
const result = Temporal.Now.plainDateTime(calendar, timeZone);
|
|
for (const property of ["hour", "minute", "second", "millisecond", "microsecond", "nanosecond"]) {
|
|
assert.sameValue(result[property], 0, property);
|
|
}
|
|
|
|
assert.compareArray(actual, expected);
|