From 7ec314aa926c2bd10e4004ad1c82d07065ab8280 Mon Sep 17 00:00:00 2001 From: Andrew Molchanov Date: Thu, 16 Mar 2023 21:34:53 +0300 Subject: [PATCH 1/4] fix: passing of ObjectId as a filter --- src/operations/find.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/operations/find.ts b/src/operations/find.ts index f1e98eb4d3..4a0f0a03ba 100644 --- a/src/operations/find.ts +++ b/src/operations/find.ts @@ -104,7 +104,7 @@ export class FindOperation extends CommandOperation { } // special case passing in an ObjectId as a filter - this.filter = filter != null && filter._bsontype === 'ObjectID' ? { _id: filter } : filter; + this.filter = filter != null && filter._bsontype === 'ObjectId' ? { _id: filter } : filter; } override execute( From 58da52cb45d874c163f61464047db617a6bacd38 Mon Sep 17 00:00:00 2001 From: Neal Beeken Date: Mon, 27 Mar 2023 15:04:33 -0400 Subject: [PATCH 2/4] test(NODE-5126): passing of ObjectId as a filter --- test/integration/crud/find.test.js | 38 +++++++++++++ test/integration/crud/find_and_modify.test.js | 55 +++++++++++++++++++ test/integration/gridfs/gridfs.test.ts | 33 ++++++++++- 3 files changed, 125 insertions(+), 1 deletion(-) diff --git a/test/integration/crud/find.test.js b/test/integration/crud/find.test.js index 16a9d7cdd5..5ccd9e9f44 100644 --- a/test/integration/crud/find.test.js +++ b/test/integration/crud/find.test.js @@ -2577,4 +2577,42 @@ describe('Find', function () { }); } }); + + context('when passed an ObjectId instance as the filter', () => { + let client; + let findsStarted; + + beforeEach(async function () { + client = this.configuration.newClient({ monitorCommands: true }); + findsStarted = []; + client.on('commandStarted', ev => { + if (ev.commandName === 'find') findsStarted.push(ev.command); + }); + }); + + afterEach(async function () { + findsStarted = undefined; + await client.close(); + }); + + context('find(oid)', () => { + it('wraps the objectId in a document with _id as the key', async () => { + const collection = client.db('test').collection('test'); + const oid = new ObjectId(); + await collection.find(oid).toArray(); + expect(findsStarted).to.have.lengthOf(1); + expect(findsStarted[0]).to.have.nested.property('filter._id', oid); + }); + }); + + context('findOne(oid)', () => { + it('wraps the objectId in a document with _id as the key', async () => { + const collection = client.db('test').collection('test'); + const oid = new ObjectId(); + await collection.findOne(oid); + expect(findsStarted).to.have.lengthOf(1); + expect(findsStarted[0]).to.have.nested.property('filter._id', oid); + }); + }); + }); }); diff --git a/test/integration/crud/find_and_modify.test.js b/test/integration/crud/find_and_modify.test.js index 2735d0a95e..6e2f0f2ff3 100644 --- a/test/integration/crud/find_and_modify.test.js +++ b/test/integration/crud/find_and_modify.test.js @@ -4,6 +4,8 @@ const { format: f } = require('util'); const { setupDatabase, assert: test } = require(`../shared`); const { expect } = require('chai'); +const { ObjectId, MongoServerError } = require('../../mongodb'); + describe('Find and Modify', function () { before(function () { return setupDatabase(this.configuration); @@ -318,4 +320,57 @@ describe('Find and Modify', function () { expect(error.message).to.match(/must not contain atomic operators/); await client.close(); }); + + context('when passed an ObjectId instance as the filter', () => { + let client; + let findAndModifyStarted; + + beforeEach(async function () { + client = this.configuration.newClient({ monitorCommands: true }); + findAndModifyStarted = []; + client.on('commandStarted', ev => { + if (ev.commandName === 'findAndModify') findAndModifyStarted.push(ev.command); + }); + }); + + afterEach(async function () { + findAndModifyStarted = undefined; + await client.close(); + }); + + context('findOneAndDelete(oid)', () => { + it('sets the query to be the ObjectId instance', async () => { + const collection = client.db('test').collection('test'); + const oid = new ObjectId(); + const error = await collection.findOneAndDelete(oid).catch(error => error); + expect(error).to.be.instanceOf(MongoServerError); + expect(findAndModifyStarted).to.have.lengthOf(1); + expect(findAndModifyStarted[0]).to.have.property('query', oid); + }); + }); + + context('findOneAndReplace(oid)', () => { + it('sets the query to be the ObjectId instance', async () => { + const collection = client.db('test').collection('test'); + const oid = new ObjectId(); + const error = await collection.findOneAndReplace(oid, {}).catch(error => error); + expect(error).to.be.instanceOf(MongoServerError); + expect(findAndModifyStarted).to.have.lengthOf(1); + expect(findAndModifyStarted[0]).to.have.property('query', oid); + }); + }); + + context('findOneAndUpdate(oid)', () => { + it('sets the query to be the ObjectId instance', async () => { + const collection = client.db('test').collection('test'); + const oid = new ObjectId(); + const error = await collection + .findOneAndUpdate(oid, { $set: { a: 1 } }) + .catch(error => error); + expect(error).to.be.instanceOf(MongoServerError); + expect(findAndModifyStarted).to.have.lengthOf(1); + expect(findAndModifyStarted[0]).to.have.property('query', oid); + }); + }); + }); }); diff --git a/test/integration/gridfs/gridfs.test.ts b/test/integration/gridfs/gridfs.test.ts index c21bd309c1..2e0a65362d 100644 --- a/test/integration/gridfs/gridfs.test.ts +++ b/test/integration/gridfs/gridfs.test.ts @@ -1,7 +1,13 @@ import { expect } from 'chai'; import { once } from 'events'; -import { CommandStartedEvent, type Db, GridFSBucket, type MongoClient } from '../../mongodb'; +import { + CommandStartedEvent, + type Db, + GridFSBucket, + type MongoClient, + ObjectId +} from '../../mongodb'; import { sleep } from '../../tools/utils'; describe('GridFS', () => { @@ -115,5 +121,30 @@ describe('GridFS', () => { const createIndexes = commandStartedEvents.filter(e => e.commandName === 'createIndexes'); expect(createIndexes).to.have.lengthOf(0); }); + + context('find(oid)', () => { + let findsStarted; + + beforeEach(async function () { + findsStarted = []; + client.on('commandStarted', ev => { + if (ev.commandName === 'find') findsStarted.push(ev.command); + }); + }); + + afterEach(async function () { + findsStarted = undefined; + await client.close(); + }); + + context('when passed an ObjectId instance as the filter', () => { + it('wraps the objectId in a document with _id as the key', async () => { + const oid = new ObjectId(); + await bucket.find(oid).toArray(); + expect(findsStarted).to.have.lengthOf(1); + expect(findsStarted[0]).to.have.nested.property('filter._id', oid); + }); + }); + }); }); }); From cca681d090eb4a77c1d48aa44100f05f3cc5010b Mon Sep 17 00:00:00 2001 From: Neal Beeken Date: Mon, 27 Mar 2023 15:54:32 -0400 Subject: [PATCH 3/4] test: assert no extra keys are added to the filter --- test/integration/crud/find.test.js | 4 +++- test/integration/crud/find_and_modify.test.js | 2 +- test/integration/gridfs/gridfs.test.ts | 3 ++- 3 files changed, 6 insertions(+), 3 deletions(-) diff --git a/test/integration/crud/find.test.js b/test/integration/crud/find.test.js index 5ccd9e9f44..6444a2cc6e 100644 --- a/test/integration/crud/find.test.js +++ b/test/integration/crud/find.test.js @@ -2582,7 +2582,7 @@ describe('Find', function () { let client; let findsStarted; - beforeEach(async function () { + beforeEach(function () { client = this.configuration.newClient({ monitorCommands: true }); findsStarted = []; client.on('commandStarted', ev => { @@ -2602,6 +2602,7 @@ describe('Find', function () { await collection.find(oid).toArray(); expect(findsStarted).to.have.lengthOf(1); expect(findsStarted[0]).to.have.nested.property('filter._id', oid); + expect(findsStarted[0].filter).to.have.all.keys(['_id']); }); }); @@ -2612,6 +2613,7 @@ describe('Find', function () { await collection.findOne(oid); expect(findsStarted).to.have.lengthOf(1); expect(findsStarted[0]).to.have.nested.property('filter._id', oid); + expect(findsStarted[0].filter).to.have.all.keys(['_id']); }); }); }); diff --git a/test/integration/crud/find_and_modify.test.js b/test/integration/crud/find_and_modify.test.js index 6e2f0f2ff3..8bf6a2cb77 100644 --- a/test/integration/crud/find_and_modify.test.js +++ b/test/integration/crud/find_and_modify.test.js @@ -325,7 +325,7 @@ describe('Find and Modify', function () { let client; let findAndModifyStarted; - beforeEach(async function () { + beforeEach(function () { client = this.configuration.newClient({ monitorCommands: true }); findAndModifyStarted = []; client.on('commandStarted', ev => { diff --git a/test/integration/gridfs/gridfs.test.ts b/test/integration/gridfs/gridfs.test.ts index 2e0a65362d..c7ad747c94 100644 --- a/test/integration/gridfs/gridfs.test.ts +++ b/test/integration/gridfs/gridfs.test.ts @@ -125,7 +125,7 @@ describe('GridFS', () => { context('find(oid)', () => { let findsStarted; - beforeEach(async function () { + beforeEach(function () { findsStarted = []; client.on('commandStarted', ev => { if (ev.commandName === 'find') findsStarted.push(ev.command); @@ -143,6 +143,7 @@ describe('GridFS', () => { await bucket.find(oid).toArray(); expect(findsStarted).to.have.lengthOf(1); expect(findsStarted[0]).to.have.nested.property('filter._id', oid); + expect(findsStarted[0].filter).to.have.all.keys(['_id']); }); }); }); From 578dfde22c496b1b9f1dd8634d81ffaf2c2c248d Mon Sep 17 00:00:00 2001 From: Neal Beeken Date: Mon, 27 Mar 2023 16:10:35 -0400 Subject: [PATCH 4/4] fix: nits --- test/integration/crud/find.test.js | 8 ++++---- test/integration/gridfs/gridfs.test.ts | 4 ++-- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/test/integration/crud/find.test.js b/test/integration/crud/find.test.js index 6444a2cc6e..e3281eb499 100644 --- a/test/integration/crud/find.test.js +++ b/test/integration/crud/find.test.js @@ -2596,24 +2596,24 @@ describe('Find', function () { }); context('find(oid)', () => { - it('wraps the objectId in a document with _id as the key', async () => { + it('wraps the objectId in a document with _id as the only key', async () => { const collection = client.db('test').collection('test'); const oid = new ObjectId(); await collection.find(oid).toArray(); expect(findsStarted).to.have.lengthOf(1); expect(findsStarted[0]).to.have.nested.property('filter._id', oid); - expect(findsStarted[0].filter).to.have.all.keys(['_id']); + expect(findsStarted[0].filter).to.have.all.keys('_id'); }); }); context('findOne(oid)', () => { - it('wraps the objectId in a document with _id as the key', async () => { + it('wraps the objectId in a document with _id as the only key', async () => { const collection = client.db('test').collection('test'); const oid = new ObjectId(); await collection.findOne(oid); expect(findsStarted).to.have.lengthOf(1); expect(findsStarted[0]).to.have.nested.property('filter._id', oid); - expect(findsStarted[0].filter).to.have.all.keys(['_id']); + expect(findsStarted[0].filter).to.have.all.keys('_id'); }); }); }); diff --git a/test/integration/gridfs/gridfs.test.ts b/test/integration/gridfs/gridfs.test.ts index c7ad747c94..7568198736 100644 --- a/test/integration/gridfs/gridfs.test.ts +++ b/test/integration/gridfs/gridfs.test.ts @@ -138,12 +138,12 @@ describe('GridFS', () => { }); context('when passed an ObjectId instance as the filter', () => { - it('wraps the objectId in a document with _id as the key', async () => { + it('wraps the objectId in a document with _id as the only key', async () => { const oid = new ObjectId(); await bucket.find(oid).toArray(); expect(findsStarted).to.have.lengthOf(1); expect(findsStarted[0]).to.have.nested.property('filter._id', oid); - expect(findsStarted[0].filter).to.have.all.keys(['_id']); + expect(findsStarted[0].filter).to.have.all.keys('_id'); }); }); });