From 298ad6907b047a5ddb91816a4e61776eb05df009 Mon Sep 17 00:00:00 2001 From: Andy Wingo Date: Tue, 19 Feb 2019 19:23:41 +0100 Subject: [PATCH] Add new test for receiver of toJSON on bigint values (#2079) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Spec link: https://tc39.github.io/proposal-bigint/#sec-serializejsonproperty Thanks to André Bargull for the test: https://bugzilla.mozilla.org/show_bug.cgi?id=1528784 --- .../JSON/stringify/bigint-tojson-receiver.js | 25 +++++++++++++++++++ 1 file changed, 25 insertions(+) create mode 100644 test/built-ins/JSON/stringify/bigint-tojson-receiver.js diff --git a/test/built-ins/JSON/stringify/bigint-tojson-receiver.js b/test/built-ins/JSON/stringify/bigint-tojson-receiver.js new file mode 100644 index 0000000000..5e23f8198e --- /dev/null +++ b/test/built-ins/JSON/stringify/bigint-tojson-receiver.js @@ -0,0 +1,25 @@ +// Copyright 2019 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +// Test case written by André Bargull. + +/*--- +esid: sec-serializejsonproperty +description: toJSON method called with BigInt as receiver +features: [BigInt] +---*/ + +assert.throws(TypeError, () => JSON.stringify(1n), + "toString throws for BigInt object"); + +// The BigInt proposal changes the SerializeJSONProperty algorithm to +// specifically allow passing BigInt objects as receivers for the toJSON +// method. +Object.defineProperty(BigInt.prototype, "toJSON", { + get() { + "use strict"; + return () => typeof this; + } +}); + +assert.sameValue(JSON.stringify(1n), "\"bigint\"", + "BigInt toJSON method called with value as receiver");