From 1eeacd02554a29779fb75b101ce0af81d2a91c36 Mon Sep 17 00:00:00 2001 From: Amir Jafarian Date: Thu, 7 Apr 2016 18:22:46 -0400 Subject: [PATCH] Fix `forceId` check for `replaceByIds` PR#896 --- lib/dao.js | 2 +- test/optional-validation.test.js | 40 ++++++++++++++++++++++++++++---- 2 files changed, 36 insertions(+), 6 deletions(-) diff --git a/lib/dao.js b/lib/dao.js index d4ecd134..ebe9f00d 100644 --- a/lib/dao.js +++ b/lib/dao.js @@ -2629,7 +2629,7 @@ DataAccessObject.replaceById = function(id, data, options, cb) { if (!data[pkName]) data[pkName] = id; var Model = this; - var inst = new Model(data); + var inst = new Model(data, { persisted: true }); var enforced = {}; this.applyProperties(enforced, inst); inst.setAttributes(enforced); diff --git a/test/optional-validation.test.js b/test/optional-validation.test.js index d27604be..e0d11d7a 100644 --- a/test/optional-validation.test.js +++ b/test/optional-validation.test.js @@ -4,8 +4,9 @@ // License text available at https://opensource.org/licenses/MIT // This test written in mocha+should.js +var async = require('async'); var should = require('./init.js'); -var db, User, options, whereCount = 0; +var db, User, options, ModelWithForceId, whereCount = 0; var j = require('../'); var ValidationError = j.ValidationError; @@ -18,6 +19,10 @@ describe('optional-validation', function () { before(function (done) { db = getSchema(); + ModelWithForceId = db.createModel( + 'ModelWithForceId', + { name: String }, + { forceId: true }); User = db.define('User', { seq: {type: Number, index: true}, name: {type: String, index: true, sort: true}, @@ -27,9 +32,7 @@ describe('optional-validation', function () { order: {type: Number, index: true, sort: true}, vip: {type: Boolean} }, { forceId: true, strict: true }); - - db.automigrate(['User'], done); - + db.automigrate(['ModelWithForceId', 'User'], done); }); beforeEach(function (done) { @@ -107,7 +110,34 @@ describe('optional-validation', function () { return {name: 'DoesNotExist' + (whereCount++)}; } - describe('no model setting', function () { + describe('forceId', function() { + context('replaceAttributes', function() { + it('should not fail if you do not pass the Primary key in data object', + function(done) { + ModelWithForceId.create({ name: 'foo' }, function(err, created) { + if (err) return done(err); + created.replaceAttributes({ name: 'bar' }, function(err, data) { + done(err); + }); + }); + }); + + it('should fail if you pass the Primary key in data object', + function(done) { + ModelWithForceId.create({ name: 'foo' }, function(err, created) { + if (err) return done(err); + created.replaceAttributes({ name: 'bar', id: 999 }, + function(err, data) { + should.exist(err); + done(); + }); + }); + }); + }); + }); + + + describe('no model setting', function() { describe('method create', function() { it('should throw on create with validate:true with invalid data', function (done) {