2013-04-11 23:56:51 +00:00
|
|
|
// This test written in mocha+should.js
|
|
|
|
var should = require('./init.js');
|
|
|
|
|
|
|
|
var db, Railway, Station;
|
|
|
|
|
2014-06-19 19:00:49 +00:00
|
|
|
describe('scope', function () {
|
2013-04-12 21:35:06 +00:00
|
|
|
|
2014-01-24 17:09:53 +00:00
|
|
|
before(function () {
|
|
|
|
db = getSchema();
|
|
|
|
Railway = db.define('Railway', {
|
|
|
|
URID: {type: String, index: true}
|
2014-08-08 16:01:24 +00:00
|
|
|
}, {
|
|
|
|
scopes: {
|
|
|
|
highSpeed: {
|
|
|
|
where: {
|
|
|
|
highSpeed: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2013-04-11 23:56:51 +00:00
|
|
|
});
|
2014-01-24 17:09:53 +00:00
|
|
|
Station = db.define('Station', {
|
|
|
|
USID: {type: String, index: true},
|
|
|
|
capacity: {type: Number, index: true},
|
|
|
|
thoughput: {type: Number, index: true},
|
|
|
|
isActive: {type: Boolean, index: true},
|
|
|
|
isUndeground: {type: Boolean, index: true}
|
2013-04-11 23:56:51 +00:00
|
|
|
});
|
2014-01-24 17:09:53 +00:00
|
|
|
});
|
2013-04-11 23:56:51 +00:00
|
|
|
|
2014-01-24 17:09:53 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Railway.destroyAll(function () {
|
|
|
|
Station.destroyAll(done);
|
2013-04-11 23:56:51 +00:00
|
|
|
});
|
2014-01-24 17:09:53 +00:00
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-08 16:01:24 +00:00
|
|
|
it('should define scope using options.scopes', function () {
|
|
|
|
Railway.scopes.should.have.property('highSpeed');
|
|
|
|
Railway.highSpeed.should.be.function;
|
|
|
|
});
|
2013-04-11 23:56:51 +00:00
|
|
|
|
2014-01-24 17:09:53 +00:00
|
|
|
it('should define scope with query', function (done) {
|
|
|
|
Station.scope('active', {where: {isActive: true}});
|
2014-08-08 16:01:24 +00:00
|
|
|
Station.scopes.should.have.property('active');
|
2014-01-24 17:09:53 +00:00
|
|
|
Station.active.create(function (err, station) {
|
|
|
|
should.not.exist(err);
|
|
|
|
should.exist(station);
|
|
|
|
should.exist(station.isActive);
|
|
|
|
station.isActive.should.be.true;
|
|
|
|
done();
|
2013-04-11 23:56:51 +00:00
|
|
|
});
|
2014-01-24 17:09:53 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should allow scope chaining', function (done) {
|
|
|
|
Station.scope('active', {where: {isActive: true}});
|
|
|
|
Station.scope('subway', {where: {isUndeground: true}});
|
|
|
|
Station.active.subway.create(function (err, station) {
|
|
|
|
should.not.exist(err);
|
|
|
|
should.exist(station);
|
|
|
|
station.isActive.should.be.true;
|
|
|
|
station.isUndeground.should.be.true;
|
|
|
|
done();
|
|
|
|
})
|
|
|
|
});
|
2013-04-11 23:56:51 +00:00
|
|
|
|
2014-01-24 17:09:53 +00:00
|
|
|
it('should query all', function (done) {
|
|
|
|
Station.scope('active', {where: {isActive: true}});
|
|
|
|
Station.scope('inactive', {where: {isActive: false}});
|
|
|
|
Station.scope('ground', {where: {isUndeground: true}});
|
|
|
|
Station.active.ground.create(function () {
|
|
|
|
Station.inactive.ground.create(function () {
|
|
|
|
Station.ground.inactive(function (err, ss) {
|
|
|
|
ss.should.have.lengthOf(1);
|
|
|
|
done();
|
2013-04-11 23:56:51 +00:00
|
|
|
});
|
2014-01-24 17:09:53 +00:00
|
|
|
});
|
2013-04-11 23:56:51 +00:00
|
|
|
});
|
2014-01-24 17:09:53 +00:00
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2013-04-11 23:56:51 +00:00
|
|
|
});
|
2014-08-13 14:24:11 +00:00
|
|
|
|
|
|
|
describe('scope - order', function () {
|
|
|
|
|
|
|
|
before(function () {
|
|
|
|
db = getSchema();
|
|
|
|
Station = db.define('Station', {
|
|
|
|
name: {type: String, index: true},
|
|
|
|
order: {type: Number, index: true}
|
|
|
|
});
|
|
|
|
Station.scope('reverse', {order: 'order DESC'});
|
|
|
|
});
|
|
|
|
|
|
|
|
beforeEach(function (done) {
|
|
|
|
Station.destroyAll(done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-13 14:24:11 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Station.create({ name: 'a', order: 1 }, done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-13 14:24:11 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Station.create({ name: 'b', order: 2 }, done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-13 14:24:11 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Station.create({ name: 'c', order: 3 }, done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-13 14:24:11 +00:00
|
|
|
it('should define scope with default order', function (done) {
|
|
|
|
Station.reverse(function(err, stations) {
|
|
|
|
stations[0].name.should.equal('c');
|
|
|
|
stations[0].order.should.equal(3);
|
|
|
|
stations[1].name.should.equal('b');
|
|
|
|
stations[1].order.should.equal(2);
|
|
|
|
stations[2].name.should.equal('a');
|
|
|
|
stations[2].order.should.equal(1);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-13 14:24:11 +00:00
|
|
|
it('should override default scope order', function (done) {
|
|
|
|
Station.reverse({order: 'order ASC'}, function(err, stations) {
|
|
|
|
stations[0].name.should.equal('a');
|
|
|
|
stations[0].order.should.equal(1);
|
|
|
|
stations[1].name.should.equal('b');
|
|
|
|
stations[1].order.should.equal(2);
|
|
|
|
stations[2].name.should.equal('c');
|
|
|
|
stations[2].order.should.equal(3);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-13 14:24:11 +00:00
|
|
|
});
|
|
|
|
|
2015-03-28 20:25:24 +00:00
|
|
|
describe('scope - filtered count, updateAll and destroyAll', function () {
|
2014-08-26 12:54:19 +00:00
|
|
|
|
2015-03-20 15:37:46 +00:00
|
|
|
var stationA;
|
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
before(function () {
|
|
|
|
db = getSchema();
|
|
|
|
Station = db.define('Station', {
|
|
|
|
name: {type: String, index: true},
|
|
|
|
order: {type: Number, index: true},
|
2015-03-28 20:25:24 +00:00
|
|
|
active: {type: Boolean, index: true, default: true},
|
|
|
|
flagged: {type: Boolean, index: true, default: false}
|
2014-08-26 12:54:19 +00:00
|
|
|
});
|
|
|
|
Station.scope('ordered', {order: 'order'});
|
|
|
|
Station.scope('active', {where: { active: true}});
|
|
|
|
Station.scope('inactive', {where: { active: false}});
|
2015-03-28 20:25:24 +00:00
|
|
|
Station.scope('flagged', {where: { flagged: true}});
|
2014-08-26 12:54:19 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
beforeEach(function (done) {
|
|
|
|
Station.destroyAll(done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Station.create({ name: 'b', order: 2, active: false }, done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
beforeEach(function (done) {
|
2015-03-20 15:37:46 +00:00
|
|
|
Station.create({ name: 'a', order: 1 }, function(err, inst) {
|
|
|
|
stationA = inst;
|
|
|
|
done();
|
|
|
|
});
|
2014-08-26 12:54:19 +00:00
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Station.create({ name: 'd', order: 4, active: false }, done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Station.create({ name: 'c', order: 3 }, done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
it('should find all - verify', function(done) {
|
|
|
|
Station.ordered(function(err, stations) {
|
|
|
|
should.not.exist(err);
|
|
|
|
stations.should.have.length(4);
|
|
|
|
stations[0].name.should.equal('a');
|
|
|
|
stations[1].name.should.equal('b');
|
|
|
|
stations[2].name.should.equal('c');
|
|
|
|
stations[3].name.should.equal('d');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2015-03-21 12:44:06 +00:00
|
|
|
it('should find one', function(done) {
|
|
|
|
Station.active.findOne(function(err, station) {
|
|
|
|
should.not.exist(err);
|
|
|
|
station.name.should.equal('a');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2015-03-21 12:44:06 +00:00
|
|
|
it('should find one - with filter', function(done) {
|
|
|
|
Station.active.findOne({ where: { name: 'c' } }, function(err, station) {
|
|
|
|
should.not.exist(err);
|
|
|
|
station.name.should.equal('c');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2015-03-20 15:37:46 +00:00
|
|
|
it('should find by id - match', function(done) {
|
|
|
|
Station.active.findById(stationA.id, function(err, station) {
|
|
|
|
should.not.exist(err);
|
|
|
|
station.name.should.equal('a');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2015-03-20 15:37:46 +00:00
|
|
|
it('should find by id - no match', function(done) {
|
|
|
|
Station.inactive.findById(stationA.id, function(err, station) {
|
|
|
|
should.not.exist(err);
|
|
|
|
should.not.exist(station);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
it('should count all in scope - active', function(done) {
|
|
|
|
Station.active.count(function(err, count) {
|
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(2);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
it('should count all in scope - inactive', function(done) {
|
|
|
|
Station.inactive.count(function(err, count) {
|
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(2);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
it('should count filtered - active', function(done) {
|
|
|
|
Station.active.count({ order: { gt: 1 } }, function(err, count) {
|
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(1);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should count filtered - inactive', function(done) {
|
|
|
|
Station.inactive.count({ order: 2 }, function(err, count) {
|
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(1);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2015-03-28 20:25:24 +00:00
|
|
|
|
|
|
|
it('should allow updateAll', function(done) {
|
|
|
|
Station.inactive.updateAll({ flagged: true }, function(err, result) {
|
|
|
|
should.not.exist(err);
|
|
|
|
result.count.should.equal(2);
|
|
|
|
verify();
|
|
|
|
});
|
|
|
|
|
|
|
|
var verify = function() {
|
|
|
|
Station.flagged.count(function(err, count) {
|
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(2);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should allow filtered updateAll', function(done) {
|
|
|
|
Station.ordered.updateAll({ active: true }, { flagged: true }, function(err, result) {
|
|
|
|
should.not.exist(err);
|
|
|
|
result.count.should.equal(2);
|
|
|
|
verify();
|
|
|
|
});
|
|
|
|
|
|
|
|
var verify = function() {
|
|
|
|
Station.flagged.count(function(err, count) {
|
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(2);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
it('should allow filtered destroyAll', function(done) {
|
|
|
|
Station.ordered.destroyAll({ active: false }, function(err) {
|
|
|
|
should.not.exist(err);
|
|
|
|
verify();
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
var verify = function() {
|
|
|
|
Station.ordered.count(function(err, count) {
|
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(2);
|
|
|
|
Station.inactive.count(function(err, count) {
|
|
|
|
should.not.exist(err);
|
|
|
|
count.should.equal(0);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
};
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-26 12:54:19 +00:00
|
|
|
});
|
2014-08-30 18:58:06 +00:00
|
|
|
|
|
|
|
describe('scope - dynamic target class', function () {
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-30 18:58:06 +00:00
|
|
|
var Collection, Media, Image, Video;
|
2015-05-11 04:05:22 +00:00
|
|
|
|
|
|
|
|
2014-08-30 18:58:06 +00:00
|
|
|
before(function () {
|
|
|
|
db = getSchema();
|
|
|
|
Image = db.define('Image', {name: String});
|
|
|
|
Video = db.define('Video', {name: String});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-30 18:58:06 +00:00
|
|
|
Collection = db.define('Collection', {name: String, modelName: String});
|
2014-08-30 19:08:23 +00:00
|
|
|
Collection.scope('items', function() {
|
|
|
|
return {}; // could return a scope based on `this` (receiver)
|
|
|
|
}, null, {}, { isStatic: false, modelTo: function(receiver) {
|
2014-08-30 18:58:06 +00:00
|
|
|
return db.models[receiver.modelName];
|
|
|
|
} });
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-30 18:58:06 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Collection.destroyAll(function() {
|
|
|
|
Image.destroyAll(function() {
|
|
|
|
Video.destroyAll(done);
|
|
|
|
})
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-30 18:58:06 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Collection.create({ name: 'Images', modelName: 'Image' }, done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-30 18:58:06 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Collection.create({ name: 'Videos', modelName: 'Video' }, done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-30 18:58:06 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Collection.create({ name: 'Things', modelName: 'Unknown' }, done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-30 18:58:06 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Image.create({ name: 'Image A' }, done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-30 18:58:06 +00:00
|
|
|
beforeEach(function (done) {
|
|
|
|
Video.create({ name: 'Video A' }, done);
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-30 18:58:06 +00:00
|
|
|
it('should deduce modelTo at runtime - Image', function(done) {
|
|
|
|
Collection.findOne({ where: { modelName: 'Image' } }, function(err, coll) {
|
|
|
|
should.not.exist(err);
|
|
|
|
coll.name.should.equal('Images');
|
|
|
|
coll.items(function(err, items) {
|
|
|
|
should.not.exist(err);
|
|
|
|
items.length.should.equal(1);
|
|
|
|
items[0].name.should.equal('Image A');
|
|
|
|
items[0].should.be.instanceof(Image);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should deduce modelTo at runtime - Video', function(done) {
|
|
|
|
Collection.findOne({ where: { modelName: 'Video' } }, function(err, coll) {
|
|
|
|
should.not.exist(err);
|
|
|
|
coll.name.should.equal('Videos');
|
|
|
|
coll.items(function(err, items) {
|
|
|
|
should.not.exist(err);
|
|
|
|
items.length.should.equal(1);
|
|
|
|
items[0].name.should.equal('Video A');
|
|
|
|
items[0].should.be.instanceof(Video);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
2014-08-30 18:58:06 +00:00
|
|
|
it('should throw if modelTo is invalid', function(done) {
|
|
|
|
Collection.findOne({ where: { name: 'Things' } }, function(err, coll) {
|
|
|
|
should.not.exist(err);
|
|
|
|
coll.modelName.should.equal('Unknown');
|
|
|
|
(function () {
|
|
|
|
coll.items(function(err, items) {});
|
|
|
|
}).should.throw();
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2015-05-11 04:05:22 +00:00
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('scope - dynamic function', function () {
|
|
|
|
|
|
|
|
var Item,seed=0;
|
|
|
|
|
|
|
|
before(function () {
|
|
|
|
db = getSchema();
|
|
|
|
Item = db.define('Item', {title: Number,creator:Number});
|
|
|
|
Item.scope('dynamicQuery', function () {
|
|
|
|
seed++;
|
|
|
|
return {where:{creator:seed}};
|
|
|
|
})
|
|
|
|
});
|
|
|
|
|
|
|
|
beforeEach(function (done) {
|
|
|
|
Item.create({ title:1,creator:1 }, function () {
|
|
|
|
Item.create({ title:2,creator:2 },done)
|
|
|
|
})
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should deduce item by runtime creator', function (done) {
|
|
|
|
Item.dynamicQuery.findOne(function (err,firstQuery) {
|
|
|
|
should.not.exist(err);
|
|
|
|
firstQuery.title.should.equal(1);
|
|
|
|
Item.dynamicQuery.findOne(function (err,secondQuery) {
|
|
|
|
should.not.exist(err);
|
|
|
|
secondQuery.title.should.equal(2);
|
|
|
|
done();
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
2014-08-30 19:08:23 +00:00
|
|
|
});
|