From 44a62d01af2f884a7910f9d1b23c5726bc6bbd71 Mon Sep 17 00:00:00 2001 From: Raymond Feng Date: Mon, 24 Feb 2014 18:38:45 -0800 Subject: [PATCH] Allows unknown properties to be saved for non-strict models See https://github.com/strongloop/loopback/issues/199 --- lib/dao.js | 4 ++-- test/loopback-dl.test.js | 26 ++++++++++++++++++++++++++ 2 files changed, 28 insertions(+), 2 deletions(-) diff --git a/lib/dao.js b/lib/dao.js index f5edfe13..9025cbf7 100644 --- a/lib/dao.js +++ b/lib/dao.js @@ -876,8 +876,9 @@ DataAccessObject.prototype.updateAttributes = function updateAttributes(data, cb var typedData = {}; for (var key in data) { + // Convert the properties by type inst[key] = data[key]; - typedData[key] = inst.__data[key]; + typedData[key] = inst[key]; } inst._adapter().updateAttributes(model, getIdValue(inst.constructor, inst), inst.constructor._forDB(typedData), function (err) { @@ -886,7 +887,6 @@ DataAccessObject.prototype.updateAttributes = function updateAttributes(data, cb for (var key in data) { inst.__dataWas[key] = inst.__data[key]; } - ; } done.call(inst, function () { saveDone.call(inst, function () { diff --git a/test/loopback-dl.test.js b/test/loopback-dl.test.js index 8be22fac..e826e188 100644 --- a/test/loopback-dl.test.js +++ b/test/loopback-dl.test.js @@ -486,6 +486,32 @@ describe('DataSource define model', function () { }); + it('should update the instance with unknown properties', function (done) { + var ds = new DataSource('memory');// define models + Post = ds.define('Post', { + title: { type: String, length: 255, index: true }, + content: { type: String } + }); + + Post.create({title: 'a', content: 'AAA'}, function (err, post) { + post.updateAttributes({title: 'b', xyz: 'xyz'}, function (err, p) { + should.not.exist(err); + p.id.should.be.equal(post.id); + p.content.should.be.equal(post.content); + p.xyz.should.be.equal('xyz'); + + Post.findById(post.id, function (err, p) { + p.id.should.be.equal(post.id); + p.content.should.be.equal(post.content); + p.xyz.should.be.equal('xyz'); + p.title.should.be.equal('b'); + done(); + }); + }); + + }); + }); + it('injects id by default', function (done) { var ds = new ModelBuilder();