From 616665f5e6f7dd06a88de450aaccaa203fa6c652 Mon Sep 17 00:00:00 2001 From: Anna Henningsen Date: Fri, 4 Dec 2020 21:35:22 +0100 Subject: [PATCH] fix: make inspection result of BSON types evaluable (#416) Make sure that evaluating the inspection result of a BSON type returns a result that can be evaluated to give an object equivalent to the original. NODE-2947 --- src/binary.ts | 2 +- src/code.ts | 4 +++- src/db_ref.ts | 4 +++- src/decimal128.ts | 2 +- src/double.ts | 2 +- src/int_32.ts | 2 +- src/long.ts | 2 +- src/max_key.ts | 2 +- src/min_key.ts | 2 +- src/objectid.ts | 2 +- src/symbol.ts | 2 +- src/timestamp.ts | 2 +- test/node/bson_test.js | 24 +++++++++++++----------- test/node/object_id_tests.js | 2 +- 14 files changed, 30 insertions(+), 24 deletions(-) diff --git a/src/binary.ts b/src/binary.ts index baabcef7..6fd898b8 100644 --- a/src/binary.ts +++ b/src/binary.ts @@ -263,7 +263,7 @@ export class Binary { inspect(): string { const asBuffer = this.value(true); - return `Binary("${asBuffer.toString('hex')}", ${this.sub_type})`; + return `new Binary(Buffer.from("${asBuffer.toString('hex')}", "hex"), ${this.sub_type})`; } } diff --git a/src/code.ts b/src/code.ts index e2bd2a65..603722c8 100644 --- a/src/code.ts +++ b/src/code.ts @@ -50,7 +50,9 @@ export class Code { inspect(): string { const codeJson = this.toJSON(); - return `Code("${codeJson.code}"${codeJson.scope ? `, ${JSON.stringify(codeJson.scope)}` : ''})`; + return `new Code("${codeJson.code}"${ + codeJson.scope ? `, ${JSON.stringify(codeJson.scope)}` : '' + })`; } } diff --git a/src/db_ref.ts b/src/db_ref.ts index cfc69d20..7556c9d2 100644 --- a/src/db_ref.ts +++ b/src/db_ref.ts @@ -108,7 +108,9 @@ export class DBRef { // NOTE: if OID is an ObjectId class it will just print the oid string. const oid = this.oid === undefined || this.oid.toString === undefined ? this.oid : this.oid.toString(); - return `DBRef("${this.namespace}", "${oid}"${this.db ? `, "${this.db}"` : ''})`; + return `new DBRef("${this.namespace}", new ObjectId("${oid}")${ + this.db ? `, "${this.db}"` : '' + })`; } } diff --git a/src/decimal128.ts b/src/decimal128.ts index 4ed3605e..8ba4c30d 100644 --- a/src/decimal128.ts +++ b/src/decimal128.ts @@ -794,7 +794,7 @@ export class Decimal128 { } inspect(): string { - return `Decimal128("${this.toString()}")`; + return `Decimal128.fromString("${this.toString()}")`; } } diff --git a/src/double.ts b/src/double.ts index 862778f7..becdc9df 100644 --- a/src/double.ts +++ b/src/double.ts @@ -78,7 +78,7 @@ export class Double { inspect(): string { const eJSON = this.toExtendedJSON() as DoubleExtended; - return `Double(${eJSON.$numberDouble})`; + return `new Double(${eJSON.$numberDouble})`; } } diff --git a/src/int_32.ts b/src/int_32.ts index b8c1f86c..b3041530 100644 --- a/src/int_32.ts +++ b/src/int_32.ts @@ -57,7 +57,7 @@ export class Int32 { } inspect(): string { - return `Int32(${this.valueOf()})`; + return `new Int32(${this.valueOf()})`; } } diff --git a/src/long.ts b/src/long.ts index f7e6aa80..3887c3c4 100644 --- a/src/long.ts +++ b/src/long.ts @@ -992,7 +992,7 @@ export class Long { } inspect(): string { - return `Long("${this.toString()}")`; + return `new Long("${this.toString()}")`; } } diff --git a/src/max_key.ts b/src/max_key.ts index 5f8379a5..49f8288c 100644 --- a/src/max_key.ts +++ b/src/max_key.ts @@ -26,7 +26,7 @@ export class MaxKey { } inspect(): string { - return 'MaxKey()'; + return 'new MaxKey()'; } } diff --git a/src/min_key.ts b/src/min_key.ts index ce2012a8..79ee2091 100644 --- a/src/min_key.ts +++ b/src/min_key.ts @@ -26,7 +26,7 @@ export class MinKey { } inspect(): string { - return 'MinKey()'; + return 'new MinKey()'; } } diff --git a/src/objectid.ts b/src/objectid.ts index 9dbb65cd..9495bf1e 100644 --- a/src/objectid.ts +++ b/src/objectid.ts @@ -350,7 +350,7 @@ export class ObjectId { } inspect(): string { - return `ObjectId("${this.toHexString()}")`; + return `new ObjectId("${this.toHexString()}")`; } } diff --git a/src/symbol.ts b/src/symbol.ts index 6f82f0b3..15d3da8f 100644 --- a/src/symbol.ts +++ b/src/symbol.ts @@ -30,7 +30,7 @@ export class BSONSymbol { /** @internal */ inspect(): string { - return `BSONSymbol("${this.value}")`; + return `new BSONSymbol("${this.value}")`; } /** @internal */ diff --git a/src/timestamp.ts b/src/timestamp.ts index a0e9cf51..a280f78c 100644 --- a/src/timestamp.ts +++ b/src/timestamp.ts @@ -98,6 +98,6 @@ export class Timestamp extends LongWithoutOverridesClass { } inspect(): string { - return `Timestamp(${this.getLowBits().toString()}, ${this.getHighBits().toString()})`; + return `new Timestamp(${this.getLowBits().toString()}, ${this.getHighBits().toString()})`; } } diff --git a/test/node/bson_test.js b/test/node/bson_test.js index fb5c95ca..406d219d 100644 --- a/test/node/bson_test.js +++ b/test/node/bson_test.js @@ -2276,7 +2276,9 @@ describe('BSON', function () { */ it('Binary', function () { const binary = new Binary(Buffer.from('0123456789abcdef0123456789abcdef', 'hex'), 4); - expect(inspect(binary)).to.equal('Binary("0123456789abcdef0123456789abcdef", 4)'); + expect(inspect(binary)).to.equal( + 'new Binary(Buffer.from("0123456789abcdef0123456789abcdef", "hex"), 4)' + ); }); /** @@ -2284,7 +2286,7 @@ describe('BSON', function () { */ it('BSONSymbol', function () { const symbol = new BSONSymbol('sym'); - expect(inspect(symbol)).to.equal('BSONSymbol("sym")'); + expect(inspect(symbol)).to.equal('new BSONSymbol("sym")'); }); /** @@ -2292,7 +2294,7 @@ describe('BSON', function () { */ it('Code', function () { const code = new Code('this.a > i', { i: 1 }); - expect(inspect(code)).to.equal('Code("this.a > i", {"i":1})'); + expect(inspect(code)).to.equal('new Code("this.a > i", {"i":1})'); }); /** @@ -2302,7 +2304,7 @@ describe('BSON', function () { const oid = new ObjectId('deadbeefdeadbeefdeadbeef'); const dbref = new DBRef('namespace', oid, 'integration_tests_'); expect(inspect(dbref)).to.equal( - 'DBRef("namespace", "deadbeefdeadbeefdeadbeef", "integration_tests_")' + 'new DBRef("namespace", new ObjectId("deadbeefdeadbeefdeadbeef"), "integration_tests_")' ); }); @@ -2311,7 +2313,7 @@ describe('BSON', function () { */ it('Decimal128', function () { const dec = Decimal128.fromString('1.42'); - expect(inspect(dec)).to.equal('Decimal128("1.42")'); + expect(inspect(dec)).to.equal('Decimal128.fromString("1.42")'); }); /** @@ -2319,7 +2321,7 @@ describe('BSON', function () { */ it('Double', function () { const double = new Double(-42.42); - expect(inspect(double)).to.equal('Double(-42.42)'); + expect(inspect(double)).to.equal('new Double(-42.42)'); }); /** @@ -2327,7 +2329,7 @@ describe('BSON', function () { */ it('Int32', function () { const int = new Int32(42); - expect(inspect(int)).to.equal('Int32(42)'); + expect(inspect(int)).to.equal('new Int32(42)'); }); /** @@ -2335,7 +2337,7 @@ describe('BSON', function () { */ it('Long', function () { const long = Long.fromString('42'); - expect(inspect(long)).to.equal('Long("42")'); + expect(inspect(long)).to.equal('new Long("42")'); }); /** @@ -2343,7 +2345,7 @@ describe('BSON', function () { */ it('MaxKey', function () { const maxKey = new MaxKey(); - expect(inspect(maxKey)).to.equal('MaxKey()'); + expect(inspect(maxKey)).to.equal('new MaxKey()'); }); /** @@ -2351,7 +2353,7 @@ describe('BSON', function () { */ it('MinKey', function () { const minKey = new MinKey(); - expect(inspect(minKey)).to.equal('MinKey()'); + expect(inspect(minKey)).to.equal('new MinKey()'); }); /** @@ -2359,7 +2361,7 @@ describe('BSON', function () { */ it('Timestamp', function () { const timestamp = new Timestamp(1, 100); - expect(inspect(timestamp)).to.equal('Timestamp(1, 100)'); + expect(inspect(timestamp)).to.equal('new Timestamp(1, 100)'); }); }); }); diff --git a/test/node/object_id_tests.js b/test/node/object_id_tests.js index 6dff5afd..601768c0 100644 --- a/test/node/object_id_tests.js +++ b/test/node/object_id_tests.js @@ -66,7 +66,7 @@ describe('ObjectId', function () { it('should correctly allow for node.js inspect to work with ObjectId', function (done) { var a = 'AAAAAAAAAAAAAAAAAAAAAAAA'; var b = new ObjectId(a); - expect(util.inspect(b)).to.equal('ObjectId("aaaaaaaaaaaaaaaaaaaaaaaa")'); + expect(util.inspect(b)).to.equal('new ObjectId("aaaaaaaaaaaaaaaaaaaaaaaa")'); done(); });