From 7861c08e5a0614b254257a1600867cc598fa7a33 Mon Sep 17 00:00:00 2001 From: ningsuhen Date: Sat, 25 Apr 2015 01:32:33 +0530 Subject: [PATCH] add test case for hasmanythrough bi-drectional relations --- lib/relation-definition.js | 4 +-- test/relations.test.js | 52 +++++++++++++++++++++++++++++++++++++- 2 files changed, 53 insertions(+), 3 deletions(-) diff --git a/lib/relation-definition.js b/lib/relation-definition.js index a4b4e506..1a727f39 100644 --- a/lib/relation-definition.js +++ b/lib/relation-definition.js @@ -870,8 +870,8 @@ var throughKeys = function(definition) { //Fix for bug - https://github.com/strongloop/loopback-datasource-juggler/issues/571 //Make sure that first key is mapped to modelFrom //& second key to modelTo. Order matters - return (definition.keyTo === fk1) ? -1 : 1; - }); + return (definition.keyTo === fk1) ? -1 : 1; + }); } else { var fk1 = findBelongsTo(modelThrough, definition.modelFrom, definition.keyFrom)[0]; diff --git a/test/relations.test.js b/test/relations.test.js index d1038838..ba25a2e0 100644 --- a/test/relations.test.js +++ b/test/relations.test.js @@ -1214,7 +1214,57 @@ describe('relations', function () { }); }); - describe('hasMany through - between same model', function () { + describe('hasMany through bi-directional relations on the same model', function () { + var User, Follow, Address; + + before(function (done) { + db = getSchema(); + User = db.define('User', {name: String}); + Follow = db.define('Follow', {date: {type: Date, + default: function () { + return new Date(); + }}}); + Address = db.define('Address', {name: String}); + + User.hasMany(User, {as: 'followers', foreignKey: 'followeeId', keyThrough: 'followerId', through: Follow}); + User.hasMany(User, {as: 'following', foreignKey: 'followerId', keyThrough: 'followeeId', through: Follow}); + User.belongsTo(Address); + Follow.belongsTo(User, {as: 'follower'}); + Follow.belongsTo(User, {as: 'followee'}); + db.automigrate(['User', 'Follow'], function (err) { + done(err); + }); + }); + + + it('should set foreignKeys of through model correctly in first relation', + function (done) { + var follower = new User({id: 1}); + var followee = new User({id: 2}); + followee.followers.add(follower, function (err, throughInst) { + should.not.exist(err); + should.exist(throughInst); + throughInst.followerId.should.equal(follower.id); + throughInst.followeeId.should.equal(followee.id); + done(); + }); + }); + + it('should set foreignKeys of through model correctly in second relation', + function (done) { + var follower = new User({id: 3}); + var followee = new User({id: 4}); + follower.following.add(followee, function (err, throughInst) { + should.not.exist(err); + should.exist(throughInst); + throughInst.followeeId.should.equal(followee.id); + throughInst.followerId.should.equal(follower.id); + done(); + }); + }); + }); + + describe('hasMany through - between same models', function () { var User, Follow, Address; before(function (done) {