From 45f5c4c6091a47bb0a2761ba0be7a7c18d11a084 Mon Sep 17 00:00:00 2001 From: Valeri Karpov Date: Sun, 25 Feb 2024 17:16:13 -0500 Subject: [PATCH 1/4] perf(model): make `insertMany()` `lean` option skip hydrating Mongoose docs Fix #14372 --- lib/model.js | 27 ++++++++++++++++----------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/lib/model.js b/lib/model.js index c5e54c46f67..d6a3026c7fd 100644 --- a/lib/model.js +++ b/lib/model.js @@ -3430,6 +3430,13 @@ Model.$__insertMany = function(arr, options, callback) { const results = ordered ? null : new Array(arr.length); const toExecute = arr.map((doc, index) => callback => { + // If option `lean` is set to true bypass validation and hydration + if (lean) { + // we have to execute callback at the nextTick to be compatible + // with parallelLimit, as `results` variable has TDZ issue if we + // execute the callback synchronously + return immediate(() => callback(null, doc)); + } if (!(doc instanceof _this)) { try { doc = new _this(doc); @@ -3440,13 +3447,6 @@ Model.$__insertMany = function(arr, options, callback) { if (options.session != null) { doc.$session(options.session); } - // If option `lean` is set to true bypass validation - if (lean) { - // we have to execute callback at the nextTick to be compatible - // with parallelLimit, as `results` variable has TDZ issue if we - // execute the callback synchronously - return immediate(() => callback(null, doc)); - } doc.$validate({ __noPromise: true }, function(error) { if (error) { // Option `ordered` signals that insert should be continued after reaching @@ -3510,7 +3510,7 @@ Model.$__insertMany = function(arr, options, callback) { callback(null, []); return; } - const docObjects = docAttributes.map(function(doc) { + const docObjects = lean ? docAttributes : docAttributes.map(function(doc) { if (doc.$__schema.options.versionKey) { doc[doc.$__schema.options.versionKey] = 0; } @@ -3572,6 +3572,9 @@ Model.$__insertMany = function(arr, options, callback) { return !isErrored; }). map(function setIsNewForInsertedDoc(doc) { + if (lean) { + return doc; + } doc.$__reset(); _setIsNew(doc, false); return doc; @@ -3588,9 +3591,11 @@ Model.$__insertMany = function(arr, options, callback) { return; } - for (const attribute of docAttributes) { - attribute.$__reset(); - _setIsNew(attribute, false); + if (!lean) { + for (const attribute of docAttributes) { + attribute.$__reset(); + _setIsNew(attribute, false); + } } if (rawResult) { From a9f661436d6f62bc6fc5ff282179efd7e4daefea Mon Sep 17 00:00:00 2001 From: Valeri Karpov Date: Tue, 27 Feb 2024 16:19:24 -0500 Subject: [PATCH 2/4] test: try fixing tests --- test/connection.test.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/connection.test.js b/test/connection.test.js index 36290280b47..111432160a6 100644 --- a/test/connection.test.js +++ b/test/connection.test.js @@ -1542,7 +1542,7 @@ describe('connections:', function() { it('should not throw an error when attempting to mutate unmutable options object gh-13335', async function() { const m = new mongoose.Mongoose(); const opts = Object.preventExtensions({}); - const conn = await m.connect('mongodb://127.0.0.1:27017/db?retryWrites=true&w=majority&readPreference=secondaryPreferred', opts); + const conn = await m.connect('mongodb://127.0.0.1:27017/db?retryWrites=true&w=majority&readPreference=primaryPreferred', opts); assert.ok(conn); }); }); From 867f7b75cb9b31731ab31d477d7ca67201303d32 Mon Sep 17 00:00:00 2001 From: Valeri Karpov Date: Tue, 27 Feb 2024 16:24:41 -0500 Subject: [PATCH 3/4] test: fix #13335 tests --- test/connection.test.js | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/test/connection.test.js b/test/connection.test.js index 111432160a6..3d65b001870 100644 --- a/test/connection.test.js +++ b/test/connection.test.js @@ -1542,7 +1542,12 @@ describe('connections:', function() { it('should not throw an error when attempting to mutate unmutable options object gh-13335', async function() { const m = new mongoose.Mongoose(); const opts = Object.preventExtensions({}); - const conn = await m.connect('mongodb://127.0.0.1:27017/db?retryWrites=true&w=majority&readPreference=primaryPreferred', opts); + + const uri = start.uri.lastIndexOf('?') === -1 ? + start.uri + '?retryWrites=true&w=majority&readPreference=primaryPreferred' : + start.uri.slice(0, start.uri.lastIndexOf('?')) + '?retryWrites=true&w=majority&readPreference=primaryPreferred'; + + const conn = await m.connect(uri, opts); assert.ok(conn); }); }); From 5096630bc236b1406d0f427c02aa1498f5850796 Mon Sep 17 00:00:00 2001 From: Valeri Karpov Date: Tue, 27 Feb 2024 16:27:30 -0500 Subject: [PATCH 4/4] style: fix lint --- test/connection.test.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/connection.test.js b/test/connection.test.js index 3d65b001870..446f4b0ccff 100644 --- a/test/connection.test.js +++ b/test/connection.test.js @@ -1546,7 +1546,7 @@ describe('connections:', function() { const uri = start.uri.lastIndexOf('?') === -1 ? start.uri + '?retryWrites=true&w=majority&readPreference=primaryPreferred' : start.uri.slice(0, start.uri.lastIndexOf('?')) + '?retryWrites=true&w=majority&readPreference=primaryPreferred'; - + const conn = await m.connect(uri, opts); assert.ok(conn); });