diff --git a/ampersand-state.js b/ampersand-state.js index 695bb6d..57bb7d9 100644 --- a/ampersand-state.js +++ b/ampersand-state.js @@ -114,6 +114,10 @@ _.extend(Base.prototype, BBEvents, { options = options || {}; + if (options.parse) { + attrs = this.parse(attrs, options); + } + if (!this._validate(attrs, options)) return false; // Extract attributes and options. diff --git a/test/full.js b/test/full.js index 702d50f..4e6ed97 100644 --- a/test/full.js +++ b/test/full.js @@ -1509,3 +1509,32 @@ test('#68, #110 mixin props should not be deleted', function (t) { t.ok(sprocket.selected); t.end(); }); + +test('#106 #84 - set accepts options.parse', function (t) { + var me; + var Person = State.extend({ + props: { + id: 'number', + name: 'string' + }, + parse: function (attrs) { + attrs.id = attrs.personID; + delete attrs.personID; + return attrs; + } + }); + + me = new Person(); + me.set({ personID: 123, name: 'Phil' }); + t.equal(me.id, undefined, 'does not parse attributes if not passed'); + + me = new Person(); + me.set({ personID: 123, name: 'Phil' },{ parse: false }); + t.equal(me.id, undefined, 'does not parse attributes if options.parse is false'); + + me = new Person(); + me.set({ personID: 123, name: 'Phil' },{ parse: true }); + t.equal(me.id, 123, 'parses attributes if options.parse is true'); + + t.end(); +});