From 67e69cdb0e9d3dc16f61449cf0cf4f609c724719 Mon Sep 17 00:00:00 2001 From: Luiz Victor Linhares Rocha Date: Mon, 7 Nov 2022 18:32:54 -0300 Subject: [PATCH] fix: remove options.model overwrite on bulkUpdate (#15252) * fix: remove options.model overwrite on bulkUpdate (#15231) * fix: remove options.model overwrite on bulkUpdate * fix: fix typo in test * fix: make test simpler Co-authored-by: Rik Smale <13023439+WikiRik@users.noreply.github.com> Co-authored-by: Rik Smale <13023439+WikiRik@users.noreply.github.com> (cherry picked from commit c62046930088344695c29ca4172cf0759916dbe2) * fix: adapt test to v6 --- src/dialects/abstract/query-interface.js | 2 +- test/unit/model/update.test.js | 47 ++++++++++++++++++++++++ 2 files changed, 48 insertions(+), 1 deletion(-) diff --git a/src/dialects/abstract/query-interface.js b/src/dialects/abstract/query-interface.js index 8a337f6a897c..ac5926bc8b22 100644 --- a/src/dialects/abstract/query-interface.js +++ b/src/dialects/abstract/query-interface.js @@ -923,7 +923,7 @@ class QueryInterface { const sql = this.queryGenerator.updateQuery(tableName, values, identifier, options, attributes); const table = _.isObject(tableName) ? tableName : { tableName }; - const model = _.find(this.sequelize.modelManager.models, { tableName: table.tableName }); + const model = options.model ? options.model : _.find(this.sequelize.modelManager.models, { tableName: table.tableName }); options.type = QueryTypes.BULKUPDATE; options.model = model; diff --git a/test/unit/model/update.test.js b/test/unit/model/update.test.js index f11c554cf057..3cdd9b8c015b 100644 --- a/test/unit/model/update.test.js +++ b/test/unit/model/update.test.js @@ -49,4 +49,51 @@ describe(Support.getTestDialectTeaser('Model'), () => { await expect(this.User.update(this.updates, { where: new Where() })).to.be.rejected; }); }); + + describe('Update with multiple models to the same table', () => { + before(function () { + this.Model1 = current.define('Model1', { + value: DataTypes.INTEGER, + name: DataTypes.STRING, + isModel2: DataTypes.BOOLEAN, + model1ExclusiveData: DataTypes.STRING, + }, { + tableName: 'model_table', + }); + + this.Model2 = current.define('Model2', { + value: DataTypes.INTEGER, + name: DataTypes.STRING, + }, { + tableName: 'model_table', + }); + }); + + beforeEach(function () { + this.stubQuery = sinon.stub(current, 'query').resolves([]); + }); + + afterEach(function () { + this.stubQuery.restore(); + }); + + it('updates model1 using model1 model', async function () { + await this.Model1.update({ + name: 'other name', + model1ExclusiveData: 'only I can update this field', + }, { + where: { value: 1 }, + }); + expect(this.stubQuery.lastCall.lastArg.model).to.eq(this.Model1); + }); + + it('updates model2 using model2 model', async function () { + await this.Model2.update({ + name: 'other name', + }, { + where: { value: 2 }, + }); + expect(this.stubQuery.lastCall.lastArg.model).to.eq(this.Model2); + }); + }); });