From 450dfca8b6e4df66531df08b9e1360499eaa6475 Mon Sep 17 00:00:00 2001 From: Neal Beeken Date: Mon, 3 Apr 2023 09:45:58 -0400 Subject: [PATCH] fix: print createFromBase64 regardless of position --- src/binary.ts | 5 ---- test/node/binary.test.ts | 37 ++++++++++++++++++++--------- test/node/bson_type_classes.test.ts | 2 +- 3 files changed, 27 insertions(+), 17 deletions(-) diff --git a/src/binary.ts b/src/binary.ts index 9dd62db4..525093ae 100644 --- a/src/binary.ts +++ b/src/binary.ts @@ -302,11 +302,6 @@ export class Binary extends BSONValue { } inspect(): string { - if (this.position === 0) { - return this.sub_type !== Binary.BSON_BINARY_SUBTYPE_DEFAULT - ? `new Binary(undefined, ${this.sub_type})` - : 'new Binary()'; - } const base64 = ByteUtils.toBase64(this.buffer.subarray(0, this.position)); return `Binary.createFromBase64("${base64}", ${this.sub_type})`; } diff --git a/test/node/binary.test.ts b/test/node/binary.test.ts index af00dec0..5fdaa107 100644 --- a/test/node/binary.test.ts +++ b/test/node/binary.test.ts @@ -81,38 +81,53 @@ describe('class Binary', () => { }); context('inspect()', () => { - it('when value is default returns "new Binary()"', () => { - expect(new Binary().inspect()).to.equal('new Binary()'); + it('when value is default returns "Binary.createFromBase64("", 0)"', () => { + expect(new Binary().inspect()).to.equal('Binary.createFromBase64("", 0)'); }); - it('when value is empty returns "new Binary()"', () => { - expect(new Binary(new Uint8Array(0)).inspect()).to.equal('new Binary()'); + it('when value is empty returns "Binary.createFromBase64("", 0)"', () => { + expect(new Binary(new Uint8Array(0)).inspect()).to.equal('Binary.createFromBase64("", 0)'); }); - it('when value is default with a subtype returns "new Binary()"', () => { - expect(new Binary(null, 0x23).inspect()).to.equal('new Binary(undefined, 35)'); + it('when value is default with a subtype returns "Binary.createFromBase64("", 35)"', () => { + expect(new Binary(null, 0x23).inspect()).to.equal('Binary.createFromBase64("", 35)'); }); - it('when value is empty with a subtype returns "new Binary(undefined, 35)"', () => { - expect(new Binary(new Uint8Array(0), 0x23).inspect()).to.equal('new Binary(undefined, 35)'); + it('when value is empty with a subtype returns "Binary.createFromBase64("", 35)"', () => { + expect(new Binary(new Uint8Array(0), 0x23).inspect()).to.equal( + 'Binary.createFromBase64("", 35)' + ); }); - it('when value is empty returns "Binary.createFromBase64("", 0)"', () => { + it('when value has utf8 "abcdef" encoded returns "Binary.createFromBase64("YWJjZGVm", 0)"', () => { expect(new Binary(Buffer.from('abcdef', 'utf8')).inspect()).to.equal( 'Binary.createFromBase64("YWJjZGVm", 0)' ); }); context('when result is executed', () => { - it('is deep equal with a Binary that has no data', () => { + it('has a position of zero when constructed with default space', () => { const bsonValue = new Binary(); const ctx = { ...BSON, module: { exports: { result: null } } }; vm.runInNewContext(`module.exports.result = ${bsonValue.inspect()}`, ctx); + expect(ctx.module.exports.result).to.have.property('position', 0); + expect(ctx.module.exports.result).to.have.property('sub_type', 0); + + // While the default Binary has 256 bytes the newly constructed one will have 0 + // both will have a position of zero so when serialized to BSON they are the equivalent. + expect(ctx.module.exports.result).to.have.nested.property('buffer.byteLength', 0); + expect(bsonValue).to.have.nested.property('buffer.byteLength', 256); + }); + + it('is deep equal with a Binary that has no data', () => { + const bsonValue = new Binary(new Uint8Array(0)); + const ctx = { ...BSON, module: { exports: { result: null } } }; + vm.runInNewContext(`module.exports.result = ${bsonValue.inspect()}`, ctx); expect(ctx.module.exports.result).to.deep.equal(bsonValue); }); it('is deep equal with a Binary that has a subtype but no data', () => { - const bsonValue = new Binary(undefined, 0x23); + const bsonValue = new Binary(new Uint8Array(0), 0x23); const ctx = { ...BSON, module: { exports: { result: null } } }; vm.runInNewContext(`module.exports.result = ${bsonValue.inspect()}`, ctx); expect(ctx.module.exports.result).to.deep.equal(bsonValue); diff --git a/test/node/bson_type_classes.test.ts b/test/node/bson_type_classes.test.ts index f8f2aebc..3d7c3497 100644 --- a/test/node/bson_type_classes.test.ts +++ b/test/node/bson_type_classes.test.ts @@ -37,7 +37,7 @@ const BSONTypeClasses = [ ]; const BSONTypeClassCtors = new Map BSONValue>([ - ['Binary', () => new Binary()], + ['Binary', () => new Binary(new Uint8Array(0), 0)], ['Code', () => new Code('function () {}')], ['DBRef', () => new DBRef('name', new ObjectId('00'.repeat(12)))], ['Decimal128', () => new Decimal128('1.23')],