2016-04-06 14:51:49 +00:00
|
|
|
// Copyright IBM Corp. 2014,2016. All Rights Reserved.
|
|
|
|
// Node module: loopback-datasource-juggler
|
|
|
|
// This file is licensed under the MIT License.
|
|
|
|
// License text available at https://opensource.org/licenses/MIT
|
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
// This test written in mocha+should.js
|
|
|
|
var should = require('./init.js');
|
|
|
|
var async = require('async');
|
|
|
|
|
2014-12-11 07:14:35 +00:00
|
|
|
var db, Category, Product, Tool, Widget, Thing, Person;
|
2014-09-06 12:38:57 +00:00
|
|
|
|
|
|
|
// This test requires a connector that can
|
|
|
|
// handle a custom collection or table name
|
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
// TODO [fabien] add table for pgsql/mysql
|
2014-09-06 17:44:58 +00:00
|
|
|
// TODO [fabien] change model definition - see #293
|
2014-09-06 17:24:30 +00:00
|
|
|
|
|
|
|
var setupProducts = function(ids, done) {
|
|
|
|
async.series([
|
|
|
|
function(next) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Tool.create({ name: 'Tool Z' }, function(err, inst) {
|
2014-09-06 17:24:30 +00:00
|
|
|
ids.toolZ = inst.id;
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
function(next) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Widget.create({ name: 'Widget Z' }, function(err, inst) {
|
2014-09-06 17:24:30 +00:00
|
|
|
ids.widgetZ = inst.id;
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
function(next) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Tool.create({ name: 'Tool A', active: false }, function(err, inst) {
|
2014-09-06 17:24:30 +00:00
|
|
|
ids.toolA = inst.id;
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
function(next) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Widget.create({ name: 'Widget A' }, function(err, inst) {
|
2014-09-06 17:24:30 +00:00
|
|
|
ids.widgetA = inst.id;
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
function(next) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Widget.create({ name: 'Widget B', active: false }, function(err, inst) {
|
2014-09-06 17:24:30 +00:00
|
|
|
ids.widgetB = inst.id;
|
|
|
|
next();
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
},
|
2014-09-06 17:24:30 +00:00
|
|
|
], done);
|
|
|
|
};
|
|
|
|
|
2016-04-14 14:41:19 +00:00
|
|
|
describe('default scope', function() {
|
|
|
|
before(function(done) {
|
2014-09-06 12:38:57 +00:00
|
|
|
db = getSchema();
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 18:19:20 +00:00
|
|
|
Category = db.define('Category', {
|
2016-04-14 14:41:19 +00:00
|
|
|
name: String,
|
2014-09-06 18:19:20 +00:00
|
|
|
});
|
2014-09-06 12:38:57 +00:00
|
|
|
|
|
|
|
Product = db.define('Product', {
|
|
|
|
name: String,
|
|
|
|
kind: String,
|
2014-09-06 17:24:30 +00:00
|
|
|
description: String,
|
2016-04-14 14:41:19 +00:00
|
|
|
active: { type: Boolean, default: true },
|
2014-09-06 12:38:57 +00:00
|
|
|
}, {
|
|
|
|
scope: { order: 'name' },
|
2016-04-14 14:41:19 +00:00
|
|
|
scopes: { active: { where: { active: true }}},
|
2014-09-06 12:38:57 +00:00
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-07 12:31:06 +00:00
|
|
|
Product.lookupModel = function(data) {
|
|
|
|
var m = this.dataSource.models[data.kind];
|
|
|
|
if (m.base === this) return m;
|
|
|
|
return this;
|
|
|
|
};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:44:58 +00:00
|
|
|
Tool = db.define('Tool', Product.definition.properties, {
|
2016-04-14 14:41:19 +00:00
|
|
|
base: 'Product',
|
|
|
|
scope: { where: { kind: 'Tool' }, order: 'name' },
|
|
|
|
scopes: { active: { where: { active: true }}},
|
|
|
|
mongodb: { collection: 'Product' },
|
|
|
|
memory: { collection: 'Product' },
|
2014-09-06 12:38:57 +00:00
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:44:58 +00:00
|
|
|
Widget = db.define('Widget', Product.definition.properties, {
|
2016-04-14 14:41:19 +00:00
|
|
|
base: 'Product',
|
|
|
|
properties: { kind: 'Widget' },
|
|
|
|
scope: { where: { kind: 'Widget' }, order: 'name' },
|
|
|
|
scopes: { active: { where: { active: true }}},
|
|
|
|
mongodb: { collection: 'Product' },
|
|
|
|
memory: { collection: 'Product' },
|
2014-09-06 12:38:57 +00:00
|
|
|
});
|
2014-12-11 07:14:35 +00:00
|
|
|
|
|
|
|
Person = db.define('Person', { name: String }, {
|
2016-04-14 14:41:19 +00:00
|
|
|
scope: { include: 'things' },
|
2014-12-11 07:14:35 +00:00
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-07 12:24:06 +00:00
|
|
|
// inst is only valid for instance methods
|
|
|
|
// like save, updateAttributes
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-07 12:24:06 +00:00
|
|
|
var scopeFn = function(target, inst) {
|
2016-04-14 14:41:19 +00:00
|
|
|
return { where: { kind: this.modelName }};
|
2014-09-06 17:44:58 +00:00
|
|
|
};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-07 12:24:06 +00:00
|
|
|
var propertiesFn = function(target, inst) {
|
|
|
|
return { kind: this.modelName };
|
|
|
|
};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:44:58 +00:00
|
|
|
Thing = db.define('Thing', Product.definition.properties, {
|
2016-04-14 14:41:19 +00:00
|
|
|
base: 'Product',
|
|
|
|
attributes: propertiesFn,
|
|
|
|
scope: scopeFn,
|
|
|
|
mongodb: { collection: 'Product' },
|
|
|
|
memory: { collection: 'Product' },
|
2014-09-06 17:44:58 +00:00
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 18:19:20 +00:00
|
|
|
Category.hasMany(Product);
|
2016-04-14 14:41:19 +00:00
|
|
|
Category.hasMany(Tool, { scope: { order: 'name DESC' }});
|
2014-09-06 18:19:20 +00:00
|
|
|
Category.hasMany(Widget);
|
|
|
|
Category.hasMany(Thing);
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 18:19:20 +00:00
|
|
|
Product.belongsTo(Category);
|
|
|
|
Tool.belongsTo(Category);
|
|
|
|
Widget.belongsTo(Category);
|
|
|
|
Thing.belongsTo(Category);
|
2014-12-11 07:14:35 +00:00
|
|
|
|
|
|
|
Person.hasMany(Thing);
|
|
|
|
Thing.belongsTo(Person);
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
db.automigrate(done);
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
describe('manipulation', function() {
|
|
|
|
var ids = {};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
before(function(done) {
|
|
|
|
db.automigrate(done);
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
it('should return a scoped instance', function() {
|
2016-05-10 21:25:33 +00:00
|
|
|
var p = new Tool({ name: 'Product A', kind: 'ignored' });
|
2014-09-06 12:38:57 +00:00
|
|
|
p.name.should.equal('Product A');
|
2014-09-06 17:44:58 +00:00
|
|
|
p.kind.should.equal('Tool');
|
2014-09-06 12:38:57 +00:00
|
|
|
p.setAttributes({ kind: 'ignored' });
|
2014-09-06 17:44:58 +00:00
|
|
|
p.kind.should.equal('Tool');
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
p.setAttribute('kind', 'other'); // currently not enforced
|
|
|
|
p.kind.should.equal('other');
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
it('should create a scoped instance - tool', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Tool.create({ name: 'Product A', kind: 'ignored' }, function(err, p) {
|
2014-09-06 12:38:57 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
p.name.should.equal('Product A');
|
2014-09-06 17:44:58 +00:00
|
|
|
p.kind.should.equal('Tool');
|
2014-09-06 12:38:57 +00:00
|
|
|
ids.productA = p.id;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
it('should create a scoped instance - widget', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Widget.create({ name: 'Product B', kind: 'ignored' }, function(err, p) {
|
2014-09-06 12:38:57 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
p.name.should.equal('Product B');
|
2014-09-06 17:44:58 +00:00
|
|
|
p.kind.should.equal('Widget');
|
2014-09-06 12:38:57 +00:00
|
|
|
ids.productB = p.id;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
it('should update a scoped instance - updateAttributes', function(done) {
|
|
|
|
Tool.findById(ids.productA, function(err, p) {
|
2016-04-14 14:41:19 +00:00
|
|
|
p.updateAttributes({ description: 'A thing...', kind: 'ingored' }, function(err, inst) {
|
2014-09-06 12:38:57 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
p.name.should.equal('Product A');
|
2014-09-06 17:44:58 +00:00
|
|
|
p.kind.should.equal('Tool');
|
2014-09-06 12:38:57 +00:00
|
|
|
p.description.should.equal('A thing...');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
it('should update a scoped instance - save', function(done) {
|
|
|
|
Tool.findById(ids.productA, function(err, p) {
|
|
|
|
p.description = 'Something...';
|
|
|
|
p.kind = 'ignored';
|
|
|
|
p.save(function(err, inst) {
|
|
|
|
should.not.exist(err);
|
|
|
|
p.name.should.equal('Product A');
|
2014-09-06 17:44:58 +00:00
|
|
|
p.kind.should.equal('Tool');
|
2014-09-06 12:38:57 +00:00
|
|
|
p.description.should.equal('Something...');
|
|
|
|
Tool.findById(ids.productA, function(err, p) {
|
2014-09-06 17:44:58 +00:00
|
|
|
p.kind.should.equal('Tool');
|
2014-09-06 12:38:57 +00:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
it('should update a scoped instance - updateOrCreate', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
var data = { id: ids.productA, description: 'Anything...', kind: 'ingored' };
|
2014-09-06 12:38:57 +00:00
|
|
|
Tool.updateOrCreate(data, function(err, p) {
|
2016-04-14 14:41:19 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
p.name.should.equal('Product A');
|
|
|
|
p.kind.should.equal('Tool');
|
|
|
|
p.description.should.equal('Anything...');
|
|
|
|
done();
|
2014-09-06 12:38:57 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
describe('findById', function() {
|
2014-09-06 12:38:57 +00:00
|
|
|
var ids = {};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
|
|
|
before(function(done) {
|
2014-09-06 17:24:30 +00:00
|
|
|
db.automigrate(setupProducts.bind(null, ids, done));
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope', function(done) {
|
|
|
|
Product.findById(ids.toolA, function(err, inst) {
|
|
|
|
should.not.exist(err);
|
|
|
|
inst.name.should.equal('Tool A');
|
2014-09-07 12:31:06 +00:00
|
|
|
inst.should.be.instanceof(Tool);
|
2014-09-06 17:24:30 +00:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - tool', function(done) {
|
|
|
|
Tool.findById(ids.toolA, function(err, inst) {
|
|
|
|
should.not.exist(err);
|
|
|
|
inst.name.should.equal('Tool A');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope (no match)', function(done) {
|
|
|
|
Widget.findById(ids.toolA, function(err, inst) {
|
|
|
|
should.not.exist(err);
|
|
|
|
should.not.exist(inst);
|
|
|
|
done();
|
2014-09-06 12:38:57 +00:00
|
|
|
});
|
|
|
|
});
|
2014-09-06 17:24:30 +00:00
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
describe('find', function() {
|
|
|
|
var ids = {};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
|
|
|
before(function(done) {
|
2014-09-06 17:24:30 +00:00
|
|
|
db.automigrate(setupProducts.bind(null, ids, done));
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
it('should apply default scope - order', function(done) {
|
|
|
|
Product.find(function(err, products) {
|
|
|
|
should.not.exist(err);
|
2014-09-06 17:24:30 +00:00
|
|
|
products.should.have.length(5);
|
2014-09-06 12:38:57 +00:00
|
|
|
products[0].name.should.equal('Tool A');
|
|
|
|
products[1].name.should.equal('Tool Z');
|
|
|
|
products[2].name.should.equal('Widget A');
|
2014-09-06 17:24:30 +00:00
|
|
|
products[3].name.should.equal('Widget B');
|
|
|
|
products[4].name.should.equal('Widget Z');
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-07 12:31:06 +00:00
|
|
|
products[0].should.be.instanceof(Product);
|
|
|
|
products[0].should.be.instanceof(Tool);
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-07 12:31:06 +00:00
|
|
|
products[2].should.be.instanceof(Product);
|
|
|
|
products[2].should.be.instanceof(Widget);
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 12:38:57 +00:00
|
|
|
it('should apply default scope - order override', function(done) {
|
|
|
|
Product.find({ order: 'name DESC' }, function(err, products) {
|
|
|
|
should.not.exist(err);
|
2014-09-06 17:24:30 +00:00
|
|
|
products.should.have.length(5);
|
2014-09-06 12:38:57 +00:00
|
|
|
products[0].name.should.equal('Widget Z');
|
2014-09-06 17:24:30 +00:00
|
|
|
products[1].name.should.equal('Widget B');
|
|
|
|
products[2].name.should.equal('Widget A');
|
|
|
|
products[3].name.should.equal('Tool Z');
|
|
|
|
products[4].name.should.equal('Tool A');
|
2014-09-06 12:38:57 +00:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - tool', function(done) {
|
2014-09-06 12:38:57 +00:00
|
|
|
Tool.find(function(err, products) {
|
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(2);
|
|
|
|
products[0].name.should.equal('Tool A');
|
|
|
|
products[1].name.should.equal('Tool Z');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - where (widget)', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Widget.find({ where: { active: true }}, function(err, products) {
|
2014-09-06 12:38:57 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(2);
|
2014-09-06 17:24:30 +00:00
|
|
|
products[0].name.should.equal('Widget A');
|
|
|
|
products[1].name.should.equal('Widget Z');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - order (widget)', function(done) {
|
|
|
|
Widget.find({ order: 'name DESC' }, function(err, products) {
|
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(3);
|
2014-09-06 12:38:57 +00:00
|
|
|
products[0].name.should.equal('Widget Z');
|
2014-09-06 17:24:30 +00:00
|
|
|
products[1].name.should.equal('Widget B');
|
|
|
|
products[2].name.should.equal('Widget A');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
describe('exists', function() {
|
|
|
|
var ids = {};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
|
|
|
before(function(done) {
|
2014-09-06 17:24:30 +00:00
|
|
|
db.automigrate(setupProducts.bind(null, ids, done));
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope', function(done) {
|
|
|
|
Product.exists(ids.widgetA, function(err, exists) {
|
|
|
|
should.not.exist(err);
|
|
|
|
exists.should.be.true;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - tool', function(done) {
|
|
|
|
Tool.exists(ids.toolZ, function(err, exists) {
|
|
|
|
should.not.exist(err);
|
|
|
|
exists.should.be.true;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - widget', function(done) {
|
|
|
|
Widget.exists(ids.widgetA, function(err, exists) {
|
|
|
|
should.not.exist(err);
|
|
|
|
exists.should.be.true;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - tool (no match)', function(done) {
|
|
|
|
Tool.exists(ids.widgetA, function(err, exists) {
|
|
|
|
should.not.exist(err);
|
|
|
|
exists.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - widget (no match)', function(done) {
|
|
|
|
Widget.exists(ids.toolZ, function(err, exists) {
|
|
|
|
should.not.exist(err);
|
|
|
|
exists.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
describe('count', function() {
|
|
|
|
var ids = {};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
|
|
|
before(function(done) {
|
2014-09-06 17:24:30 +00:00
|
|
|
db.automigrate(setupProducts.bind(null, ids, done));
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - order', function(done) {
|
|
|
|
Product.count(function(err, count) {
|
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(5);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - tool', function(done) {
|
|
|
|
Tool.count(function(err, count) {
|
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(2);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - widget', function(done) {
|
|
|
|
Widget.count(function(err, count) {
|
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(3);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - where', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Widget.count({ name: 'Widget Z' }, function(err, count) {
|
2014-09-06 17:24:30 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(1);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - no match', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Tool.count({ name: 'Widget Z' }, function(err, count) {
|
2014-09-06 17:24:30 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(0);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
describe('removeById', function() {
|
|
|
|
var ids = {};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
function isDeleted(id, done) {
|
|
|
|
Product.exists(id, function(err, exists) {
|
|
|
|
should.not.exist(err);
|
|
|
|
exists.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
|
|
|
before(function(done) {
|
2014-09-06 17:24:30 +00:00
|
|
|
db.automigrate(setupProducts.bind(null, ids, done));
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope', function(done) {
|
|
|
|
Product.removeById(ids.widgetZ, function(err) {
|
|
|
|
should.not.exist(err);
|
|
|
|
isDeleted(ids.widgetZ, done);
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - tool', function(done) {
|
|
|
|
Tool.removeById(ids.toolA, function(err) {
|
|
|
|
should.not.exist(err);
|
|
|
|
isDeleted(ids.toolA, done);
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - no match', function(done) {
|
|
|
|
Tool.removeById(ids.widgetA, function(err) {
|
|
|
|
should.not.exist(err);
|
|
|
|
Product.exists(ids.widgetA, function(err, exists) {
|
|
|
|
should.not.exist(err);
|
|
|
|
exists.should.be.true;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - widget', function(done) {
|
|
|
|
Widget.removeById(ids.widgetA, function(err) {
|
|
|
|
should.not.exist(err);
|
|
|
|
isDeleted(ids.widgetA, done);
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - verify', function(done) {
|
|
|
|
Product.find(function(err, products) {
|
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(2);
|
|
|
|
products[0].name.should.equal('Tool Z');
|
|
|
|
products[1].name.should.equal('Widget B');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
describe('update', function() {
|
|
|
|
var ids = {};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
|
|
|
before(function(done) {
|
2014-09-06 17:24:30 +00:00
|
|
|
db.automigrate(setupProducts.bind(null, ids, done));
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Widget.update({ active: false }, { active: true, kind: 'ignored' }, function(err) {
|
2014-09-06 17:24:30 +00:00
|
|
|
should.not.exist(err);
|
2016-04-14 14:41:19 +00:00
|
|
|
Widget.find({ where: { active: true }}, function(err, products) {
|
2014-09-06 17:24:30 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(3);
|
|
|
|
products[0].name.should.equal('Widget A');
|
|
|
|
products[1].name.should.equal('Widget B');
|
|
|
|
products[2].name.should.equal('Widget Z');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - no match', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Tool.update({ name: 'Widget A' }, { name: 'Ignored' }, function(err) {
|
2014-09-06 17:24:30 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
Product.findById(ids.widgetA, function(err, product) {
|
|
|
|
should.not.exist(err);
|
|
|
|
product.name.should.equal('Widget A');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should have updated within scope', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Product.find({ where: { active: true }}, function(err, products) {
|
2014-09-06 17:24:30 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(4);
|
|
|
|
products[0].name.should.equal('Tool Z');
|
2014-09-06 12:38:57 +00:00
|
|
|
products[1].name.should.equal('Widget A');
|
2014-09-06 17:24:30 +00:00
|
|
|
products[2].name.should.equal('Widget B');
|
|
|
|
products[3].name.should.equal('Widget Z');
|
2014-09-06 12:38:57 +00:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2014-09-06 17:24:30 +00:00
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
describe('remove', function() {
|
|
|
|
var ids = {};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
|
|
|
before(function(done) {
|
2014-09-06 17:24:30 +00:00
|
|
|
db.automigrate(setupProducts.bind(null, ids, done));
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - custom where', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Widget.remove({ name: 'Widget A' }, function(err) {
|
2014-09-06 17:24:30 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
Product.find(function(err, products) {
|
|
|
|
products.should.have.length(4);
|
|
|
|
products[0].name.should.equal('Tool A');
|
|
|
|
products[1].name.should.equal('Tool Z');
|
|
|
|
products[2].name.should.equal('Widget B');
|
|
|
|
products[3].name.should.equal('Widget Z');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - custom where (no match)', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Tool.remove({ name: 'Widget Z' }, function(err) {
|
2014-09-06 17:24:30 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
Product.find(function(err, products) {
|
|
|
|
products.should.have.length(4);
|
|
|
|
products[0].name.should.equal('Tool A');
|
|
|
|
products[1].name.should.equal('Tool Z');
|
|
|
|
products[2].name.should.equal('Widget B');
|
|
|
|
products[3].name.should.equal('Widget Z');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - deleteAll', function(done) {
|
|
|
|
Tool.deleteAll(function(err) {
|
|
|
|
should.not.exist(err);
|
|
|
|
Product.find(function(err, products) {
|
|
|
|
products.should.have.length(2);
|
|
|
|
products[0].name.should.equal('Widget B');
|
|
|
|
products[1].name.should.equal('Widget Z');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should create a scoped instance - tool', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Tool.create({ name: 'Tool B' }, function(err, p) {
|
2014-09-06 17:24:30 +00:00
|
|
|
should.not.exist(err);
|
|
|
|
Product.find(function(err, products) {
|
|
|
|
products.should.have.length(3);
|
|
|
|
products[0].name.should.equal('Tool B');
|
|
|
|
products[1].name.should.equal('Widget B');
|
|
|
|
products[2].name.should.equal('Widget Z');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should apply default scope - destroyAll', function(done) {
|
|
|
|
Widget.destroyAll(function(err) {
|
|
|
|
should.not.exist(err);
|
|
|
|
Product.find(function(err, products) {
|
|
|
|
products.should.have.length(1);
|
|
|
|
products[0].name.should.equal('Tool B');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
describe('scopes', function() {
|
|
|
|
var ids = {};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
|
|
|
before(function(done) {
|
2014-09-06 17:24:30 +00:00
|
|
|
db.automigrate(setupProducts.bind(null, ids, done));
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should merge with default scope', function(done) {
|
|
|
|
Product.active(function(err, products) {
|
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(3);
|
|
|
|
products[0].name.should.equal('Tool Z');
|
|
|
|
products[1].name.should.equal('Widget A');
|
|
|
|
products[2].name.should.equal('Widget Z');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should merge with default scope - tool', function(done) {
|
|
|
|
Tool.active(function(err, products) {
|
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(1);
|
|
|
|
products[0].name.should.equal('Tool Z');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:24:30 +00:00
|
|
|
it('should merge with default scope - widget', function(done) {
|
|
|
|
Widget.active(function(err, products) {
|
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(2);
|
|
|
|
products[0].name.should.equal('Widget A');
|
|
|
|
products[1].name.should.equal('Widget Z');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2014-09-06 12:38:57 +00:00
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:44:58 +00:00
|
|
|
describe('scope function', function() {
|
|
|
|
before(function(done) {
|
|
|
|
db.automigrate(done);
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:44:58 +00:00
|
|
|
it('should create a scoped instance - widget', function(done) {
|
2016-05-10 21:25:33 +00:00
|
|
|
Widget.create({ name: 'Product', kind: 'ignored' }, function(err, p) {
|
2014-09-06 17:44:58 +00:00
|
|
|
p.name.should.equal('Product');
|
|
|
|
p.kind.should.equal('Widget');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:44:58 +00:00
|
|
|
it('should create a scoped instance - thing', function(done) {
|
2016-05-10 21:25:33 +00:00
|
|
|
Thing.create({ name: 'Product', kind: 'ignored' }, function(err, p) {
|
2014-09-06 17:44:58 +00:00
|
|
|
p.name.should.equal('Product');
|
|
|
|
p.kind.should.equal('Thing');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:44:58 +00:00
|
|
|
it('should find a scoped instance - widget', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Widget.findOne({ where: { name: 'Product' }}, function(err, p) {
|
2014-09-06 17:44:58 +00:00
|
|
|
p.name.should.equal('Product');
|
|
|
|
p.kind.should.equal('Widget');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:44:58 +00:00
|
|
|
it('should find a scoped instance - thing', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Thing.findOne({ where: { name: 'Product' }}, function(err, p) {
|
2014-09-06 17:44:58 +00:00
|
|
|
p.name.should.equal('Product');
|
|
|
|
p.kind.should.equal('Thing');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 17:44:58 +00:00
|
|
|
it('should find a scoped instance - thing', function(done) {
|
2016-04-14 14:41:19 +00:00
|
|
|
Product.find({ where: { name: 'Product' }}, function(err, products) {
|
2014-09-06 17:44:58 +00:00
|
|
|
products.should.have.length(2);
|
|
|
|
products[0].name.should.equal('Product');
|
|
|
|
products[1].name.should.equal('Product');
|
2016-04-14 14:41:19 +00:00
|
|
|
var kinds = products.map(function(p) { return p.kind; });
|
2014-09-06 17:44:58 +00:00
|
|
|
kinds.sort();
|
|
|
|
kinds.should.eql(['Thing', 'Widget']);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 18:19:20 +00:00
|
|
|
describe('relations', function() {
|
|
|
|
var ids = {};
|
2016-04-14 14:41:19 +00:00
|
|
|
|
|
|
|
before(function(done) {
|
2014-09-06 18:19:20 +00:00
|
|
|
db.automigrate(done);
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
|
|
|
before(function(done) {
|
|
|
|
Category.create({ name: 'Category A' }, function(err, cat) {
|
2014-09-06 18:19:20 +00:00
|
|
|
ids.categoryA = cat.id;
|
|
|
|
async.series([
|
|
|
|
function(next) {
|
2016-04-14 14:41:19 +00:00
|
|
|
cat.widgets.create({ name: 'Widget B', kind: 'ignored' }, next);
|
2014-09-06 18:19:20 +00:00
|
|
|
},
|
|
|
|
function(next) {
|
2016-04-14 14:41:19 +00:00
|
|
|
cat.widgets.create({ name: 'Widget A' }, next);
|
2014-09-06 18:19:20 +00:00
|
|
|
},
|
|
|
|
function(next) {
|
2016-04-14 14:41:19 +00:00
|
|
|
cat.tools.create({ name: 'Tool A' }, next);
|
2014-09-06 18:19:20 +00:00
|
|
|
},
|
|
|
|
function(next) {
|
2016-04-14 14:41:19 +00:00
|
|
|
cat.things.create({ name: 'Thing A' }, next);
|
|
|
|
},
|
2014-09-06 18:19:20 +00:00
|
|
|
], done);
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 18:19:20 +00:00
|
|
|
it('should apply default scope - products', function(done) {
|
|
|
|
Category.findById(ids.categoryA, function(err, cat) {
|
|
|
|
should.not.exist(err);
|
|
|
|
cat.products(function(err, products) {
|
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(4);
|
|
|
|
products[0].name.should.equal('Thing A');
|
|
|
|
products[1].name.should.equal('Tool A');
|
|
|
|
products[2].name.should.equal('Widget A');
|
|
|
|
products[3].name.should.equal('Widget B');
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-07 12:31:06 +00:00
|
|
|
products[0].should.be.instanceof(Product);
|
|
|
|
products[0].should.be.instanceof(Thing);
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-07 12:31:06 +00:00
|
|
|
products[1].should.be.instanceof(Product);
|
|
|
|
products[1].should.be.instanceof(Tool);
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-07 12:31:06 +00:00
|
|
|
products[2].should.be.instanceof(Product);
|
|
|
|
products[2].should.be.instanceof(Widget);
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 18:19:20 +00:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 18:19:20 +00:00
|
|
|
it('should apply default scope - widgets', function(done) {
|
|
|
|
Category.findById(ids.categoryA, function(err, cat) {
|
|
|
|
should.not.exist(err);
|
|
|
|
cat.widgets(function(err, products) {
|
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(2);
|
|
|
|
products[0].should.be.instanceof(Widget);
|
|
|
|
products[0].name.should.equal('Widget A');
|
|
|
|
products[1].name.should.equal('Widget B');
|
|
|
|
products[0].category(function(err, inst) {
|
|
|
|
inst.name.should.equal('Category A');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 18:19:20 +00:00
|
|
|
it('should apply default scope - tools', function(done) {
|
|
|
|
Category.findById(ids.categoryA, function(err, cat) {
|
|
|
|
should.not.exist(err);
|
|
|
|
cat.tools(function(err, products) {
|
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(1);
|
|
|
|
products[0].should.be.instanceof(Tool);
|
|
|
|
products[0].name.should.equal('Tool A');
|
|
|
|
products[0].category(function(err, inst) {
|
|
|
|
inst.name.should.equal('Category A');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 18:19:20 +00:00
|
|
|
it('should apply default scope - things', function(done) {
|
|
|
|
Category.findById(ids.categoryA, function(err, cat) {
|
|
|
|
should.not.exist(err);
|
|
|
|
cat.things(function(err, products) {
|
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(1);
|
|
|
|
products[0].should.be.instanceof(Thing);
|
|
|
|
products[0].name.should.equal('Thing A');
|
|
|
|
products[0].category(function(err, inst) {
|
|
|
|
inst.name.should.equal('Category A');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 18:19:20 +00:00
|
|
|
it('should create related item with default scope', function(done) {
|
|
|
|
Category.findById(ids.categoryA, function(err, cat) {
|
2016-04-14 14:41:19 +00:00
|
|
|
cat.tools.create({ name: 'Tool B' }, done);
|
2014-09-06 18:19:20 +00:00
|
|
|
});
|
|
|
|
});
|
2016-04-14 14:41:19 +00:00
|
|
|
|
2014-09-06 18:19:20 +00:00
|
|
|
it('should use relation scope order', function(done) {
|
|
|
|
Category.findById(ids.categoryA, function(err, cat) {
|
|
|
|
should.not.exist(err);
|
|
|
|
cat.tools(function(err, products) {
|
|
|
|
should.not.exist(err);
|
|
|
|
products.should.have.length(2);
|
|
|
|
products[0].name.should.equal('Tool B');
|
|
|
|
products[1].name.should.equal('Tool A');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2014-12-11 07:14:35 +00:00
|
|
|
|
|
|
|
describe('with include option', function() {
|
2016-04-14 14:41:19 +00:00
|
|
|
before(function(done) {
|
2014-12-11 07:14:35 +00:00
|
|
|
db.automigrate(done);
|
|
|
|
});
|
|
|
|
|
2016-04-14 14:41:19 +00:00
|
|
|
before(function(done) {
|
2014-12-11 07:14:35 +00:00
|
|
|
Person.create({ id: 1, name: 'Person A' }, function(err, person) {
|
|
|
|
person.things.create({ name: 'Thing A' }, done);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should find a scoped instance with included relation - things', function(done) {
|
|
|
|
Person.findById(1, function(err, person) {
|
|
|
|
should.not.exist(err);
|
|
|
|
should.exist(person);
|
|
|
|
var things = person.things();
|
|
|
|
should.exist(things);
|
|
|
|
things.should.be.an.instanceOf(Array);
|
|
|
|
things.should.have.length(1);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2014-09-06 17:24:30 +00:00
|
|
|
});
|