mirror of
https://github.com/tc39/test262.git
synced 2025-11-18 04:39:44 +01:00
Previously, "nested" calendar property bags were unwrapped up to one
level. That is, this object:
{
calendar: {
// ...Temporal.Calendar methods
}
}
would not be considered to implement the Calendar protocol, but would have
its calendar property used instead, if it were passed to an API that
required a Calendar protocol object.
These nested property bags are no longer supported. Discussion:
https://github.com/tc39/proposal-temporal/issues/2104#issuecomment-1409549753
Corresponding normative PR:
https://github.com/tc39/proposal-temporal/pull/2485
27 lines
708 B
JavaScript
27 lines
708 B
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: Observable interactions with the provided calendar-like object
|
|
includes: [compareArray.js, temporalHelpers.js]
|
|
features: [Proxy, Temporal]
|
|
---*/
|
|
|
|
const actual = [];
|
|
|
|
const calendar = TemporalHelpers.calendarObserver(actual, "calendar", {
|
|
toString: "iso8601",
|
|
});
|
|
|
|
Object.defineProperty(Temporal.Calendar, 'from', {
|
|
get() {
|
|
actual.push('get Temporal.Calendar.from');
|
|
return undefined;
|
|
},
|
|
});
|
|
|
|
Temporal.Now.plainDateTime(calendar);
|
|
|
|
assert.compareArray(actual, [], 'no observable operations should be invoked');
|