mirror of
https://github.com/tc39/test262.git
synced 2025-09-25 11:08:49 +02:00
Checking whether an object implements the TimeZone protocol is now done by means of HasProperty operations for each of the required methods unless the object already has the TimeZone brand. Discussion: https://github.com/tc39/proposal-temporal/issues/2104#issuecomment-1409549753 Corresponding normative PR: https://github.com/tc39/proposal-temporal/pull/2485
34 lines
1.1 KiB
JavaScript
34 lines
1.1 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.plaintimeiso
|
|
description: The value returned by TimeZone.getOffsetNanosecondsFor affects the result
|
|
includes: [compareArray.js, temporalHelpers.js]
|
|
features: [Temporal]
|
|
---*/
|
|
|
|
const actual = [];
|
|
const expected = [
|
|
"has timeZone.getOffsetNanosecondsFor",
|
|
"has timeZone.getPossibleInstantsFor",
|
|
"has timeZone.id",
|
|
"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 result = Temporal.Now.plainTimeISO(timeZone);
|
|
assert.sameValue(result instanceof Temporal.PlainTime, true);
|
|
for (const property of ["hour", "minute", "second", "millisecond", "microsecond", "nanosecond"]) {
|
|
assert.sameValue(result[property], 0, property);
|
|
}
|
|
|
|
assert.compareArray(actual, expected);
|