From 2473f0f4345d48567fd16918cc2aeb89b44cffa4 Mon Sep 17 00:00:00 2001 From: Paul Uithol Date: Tue, 21 Jan 2014 15:32:23 +0100 Subject: [PATCH] Submodels: accommodate multiple 'type' keys for the same submodel. Closes #429 --- backbone-relational.js | 2 +- test/tests.js | 7 +++++-- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/backbone-relational.js b/backbone-relational.js index 41a562a0..4508fcd4 100755 --- a/backbone-relational.js +++ b/backbone-relational.js @@ -230,7 +230,7 @@ */ setupSuperModel: function( modelType ) { _.find( this._subModels, function( subModelDef ) { - return _.find( subModelDef.subModels || [], function( subModelTypeName, typeValue ) { + return _.each( subModelDef.subModels || [], function( subModelTypeName, typeValue ) { var subModelType = this.getObjectByName( subModelTypeName ); if ( modelType === subModelType ) { diff --git a/test/tests.js b/test/tests.js index a360ff68..5c962c44 100644 --- a/test/tests.js +++ b/test/tests.js @@ -1435,7 +1435,8 @@ $(document).ready(function() { scope.Mammal = Animal.extend({ subModelTypes: { 'primate': 'Primate', - 'carnivore': 'Carnivore' + 'carnivore': 'Carnivore', + 'ape': 'Primate' // To check multiple keys for the same submodel; see GH-429 } }); scope.Primate = scope.Mammal.extend({ @@ -1453,12 +1454,14 @@ $(document).ready(function() { var mammals = new MammalCollection( [ { id: 5, species: 'chimp', type: 'primate' }, { id: 6, species: 'panther', type: 'carnivore' }, - { id: 7, species: 'person', type: 'human' } + { id: 7, species: 'person', type: 'human' }, + { id: 8, species: 'gorilla', type: 'ape' } ]); ok( mammals.at( 0 ) instanceof scope.Primate ); ok( mammals.at( 1 ) instanceof scope.Carnivore ); ok( mammals.at( 2 ) instanceof scope.Human ); + ok( mammals.at( 3 ) instanceof scope.Primate ); }); test( "Object building based on type, when used in relations" , function() {