1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- 'use strict';
- var test = require('tape');
- var inspect = require('object-inspect');
- var hasBigInts = require('has-bigints')();
- var hasToStringTag = require('has-tostringtag/shams')();
- var forEach = require('for-each');
- var v = require('es-value-fixtures');
- var isBigInt = require('../');
- test('non-BigInt values', function (t) {
- /** @type {(typeof v.primitives[number] | object)[]} */
- var nonBigInts = v.nonBigInts.concat(
- Object(true),
- Object(false),
- // @ts-expect-error TS sucks with concat
- {},
- [],
- /a/g,
- new Date(),
- function () {},
- NaN,
- v.symbols
- );
- t.plan(nonBigInts.length);
- forEach(nonBigInts, function (nonBigInt) {
- t.equal(false, isBigInt(nonBigInt), inspect(nonBigInt) + ' is not a BigInt');
- });
- t.end();
- });
- test('faked BigInt values', function (t) {
- t.test('real BigInt valueOf', { skip: !hasBigInts }, function (st) {
- var fakeBigInt = { valueOf: function () { return BigInt(42); } };
- st.equal(false, isBigInt(fakeBigInt), 'object with valueOf returning a BigInt is not a BigInt');
- st.end();
- });
- t.test('faked @@toStringTag', { skip: !hasBigInts || !hasToStringTag }, function (st) {
- /** @type {{ valueOf(): unknown; [Symbol.toStringTag]?: unknown }} */
- var fakeBigInt = { valueOf: function () { return BigInt(42); } };
- fakeBigInt[Symbol.toStringTag] = 'BigInt';
- st.equal(false, isBigInt(fakeBigInt), 'object with fake BigInt @@toStringTag and valueOf returning a BigInt is not a BigInt');
- /** @type {{ valueOf(): unknown; [Symbol.toStringTag]?: unknown }} */
- var notSoFakeBigInt = { valueOf: function () { return 42; } };
- notSoFakeBigInt[Symbol.toStringTag] = 'BigInt';
- st.equal(false, isBigInt(notSoFakeBigInt), 'object with fake BigInt @@toStringTag and valueOf not returning a BigInt is not a BigInt');
- st.end();
- });
- var fakeBigIntString = { toString: function () { return '42n'; } };
- t.equal(false, isBigInt(fakeBigIntString), 'object with toString returning 42n is not a BigInt');
- t.end();
- });
- test('BigInt support', { skip: !hasBigInts }, function (t) {
- forEach(v.bigints.concat(Object(BigInt(42))), function (bigInt) {
- t.equal(true, isBigInt(bigInt), inspect(bigInt) + ' is a BigInt');
- });
- t.end();
- });
|