manyToMany.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. var assert = require('assert');
  2. var _ = require('@sailshq/lodash');
  3. var Waterline = require('../../../../lib/waterline');
  4. describe('Collection Query ::', function() {
  5. describe('many to many association', function() {
  6. var User;
  7. var generatedQuery;
  8. before(function(done) {
  9. var waterline = new Waterline();
  10. var collections = {};
  11. collections.user = Waterline.Model.extend({
  12. identity: 'user',
  13. datastore: 'foo',
  14. primaryKey: 'id',
  15. attributes: {
  16. id: {
  17. type: 'number',
  18. columnName: 'user_id'
  19. },
  20. cars: {
  21. collection: 'car',
  22. via: 'drivers'
  23. }
  24. }
  25. });
  26. collections.car = Waterline.Model.extend({
  27. identity: 'car',
  28. datastore: 'foo',
  29. primaryKey: 'id',
  30. attributes: {
  31. id: {
  32. type: 'number',
  33. columnName: 'car_id'
  34. },
  35. name: {
  36. type: 'string',
  37. columnName: 'car_name'
  38. },
  39. drivers: {
  40. collection: 'user',
  41. via: 'cars',
  42. dominant: true
  43. }
  44. }
  45. });
  46. waterline.registerModel(collections.user);
  47. waterline.registerModel(collections.car);
  48. // Fixture Adapter Def
  49. var adapterDef = {
  50. identity: 'foo',
  51. join: function(con, query, cb) {
  52. generatedQuery = query;
  53. return cb();
  54. },
  55. find: function(con, query, cb) {
  56. return cb();
  57. }
  58. };
  59. var connections = {
  60. 'foo': {
  61. adapter: 'foobar'
  62. }
  63. };
  64. waterline.initialize({ adapters: { foobar: adapterDef }, datastores: connections }, function(err, orm) {
  65. if (err) {
  66. return done(err);
  67. }
  68. User = orm.collections.user;
  69. return done();
  70. });
  71. });
  72. it('should build a join query', function(done) {
  73. User.findOne(1)
  74. .populate('cars', { sort: [{'name': 'ASC'}]})
  75. .exec(function(err) {
  76. if (err) {
  77. return done(err);
  78. }
  79. assert.equal(generatedQuery.joins.length, 2);
  80. assert.equal(generatedQuery.joins[0].parent, 'user');
  81. assert.equal(generatedQuery.joins[0].parentKey, 'user_id');
  82. assert.equal(generatedQuery.joins[0].child, 'car_drivers__user_cars');
  83. assert.equal(generatedQuery.joins[0].childKey, 'user_cars');
  84. assert.equal(generatedQuery.joins[0].select, false);
  85. assert.equal(generatedQuery.joins[0].removeParentKey, false);
  86. assert.equal(generatedQuery.joins[1].parent, 'car_drivers__user_cars');
  87. assert.equal(generatedQuery.joins[1].parentKey, 'car_drivers');
  88. assert.equal(generatedQuery.joins[1].child, 'car');
  89. assert.equal(generatedQuery.joins[1].childKey, 'car_id');
  90. assert(_.isArray(generatedQuery.joins[1].criteria.select));
  91. assert.equal(generatedQuery.joins[1].criteria.select[0], 'car_id');
  92. assert.equal(generatedQuery.joins[1].criteria.select[1], 'car_name');
  93. assert(_.isArray(generatedQuery.joins[1].criteria.sort));
  94. assert(generatedQuery.joins[1].criteria.sort[0].car_name);
  95. assert.equal(generatedQuery.joins[1].removeParentKey, false);
  96. return done();
  97. });
  98. });
  99. });
  100. });