mirror of
https://github.com/tc39/test262.git
synced 2025-09-30 13:38:48 +02:00
Normally, a plain object passed into an API that takes a Temporal.Calendar has its 'calendar' property checked (observably) with a Has operation followed by a Get operation if the property is present. In the normative change https://github.com/tc39/proposal-temporal/pull/2392 which reached consensus at the September 2022 TC39 meeting, this was changed so that this check is skipped for objects which have the Temporal.Calendar internal slots. This adds tests to all entry points that pass a user-supplied object to ToTemporalCalendar, with a "poisoned" calendar object which has the correct internal slots but a 'calendar' accessor property whose getter throws. A correct implementation should not cause this getter to throw.
21 lines
597 B
JavaScript
21 lines
597 B
JavaScript
// 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.plaindate
|
|
description: >
|
|
A Temporal.Calendar instance passed to new PlainDate() does not have
|
|
its 'calendar' property observably checked
|
|
features: [Temporal]
|
|
---*/
|
|
|
|
const arg = new Temporal.Calendar("iso8601");
|
|
Object.defineProperty(arg, "calendar", {
|
|
get() {
|
|
throw new Test262Error("calendar.calendar should not be accessed");
|
|
},
|
|
});
|
|
|
|
new Temporal.PlainDate(2000, 5, 2, arg);
|
|
new Temporal.PlainDate(2000, 5, 2, { calendar: arg });
|