2013-04-06 10:57:12 +00:00
|
|
|
// This test written in mocha+should.js
|
|
|
|
var should = require('./init.js');
|
|
|
|
|
|
|
|
var db, Book, Chapter, Author, Reader;
|
2013-03-26 00:39:47 +00:00
|
|
|
|
|
|
|
describe('relations', function() {
|
2013-03-26 20:48:14 +00:00
|
|
|
before(function(done) {
|
2013-03-26 00:39:47 +00:00
|
|
|
db = getSchema();
|
|
|
|
Book = db.define('Book', {name: String});
|
2013-03-26 20:48:14 +00:00
|
|
|
Chapter = db.define('Chapter', {name: {type: String, index: true}});
|
2013-03-26 00:39:47 +00:00
|
|
|
Author = db.define('Author', {name: String});
|
|
|
|
Reader = db.define('Reader', {name: String});
|
2013-03-26 20:48:14 +00:00
|
|
|
|
|
|
|
db.automigrate(function() {
|
|
|
|
Book.destroyAll(function() {
|
|
|
|
Chapter.destroyAll(function() {
|
|
|
|
Author.destroyAll(function() {
|
|
|
|
Reader.destroyAll(done);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2013-03-26 00:39:47 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
after(function() {
|
|
|
|
db.disconnect();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('hasMany', function() {
|
2013-03-26 20:48:14 +00:00
|
|
|
it('can be declared in different ways', function(done) {
|
2013-03-26 00:39:47 +00:00
|
|
|
Book.hasMany(Chapter);
|
|
|
|
Book.hasMany(Reader, {as: 'users'});
|
|
|
|
Book.hasMany(Author, {foreignKey: 'projectId'});
|
|
|
|
var b = new Book;
|
|
|
|
b.chapters.should.be.an.instanceOf(Function);
|
|
|
|
b.users.should.be.an.instanceOf(Function);
|
|
|
|
b.authors.should.be.an.instanceOf(Function);
|
|
|
|
Object.keys((new Chapter).toObject()).should.include('bookId');
|
|
|
|
Object.keys((new Author).toObject()).should.include('projectId');
|
2013-03-26 20:48:14 +00:00
|
|
|
|
|
|
|
db.automigrate(done);
|
2013-03-26 00:39:47 +00:00
|
|
|
});
|
|
|
|
|
2013-03-26 20:48:14 +00:00
|
|
|
it('can be declared in short form', function(done) {
|
2013-03-26 00:39:47 +00:00
|
|
|
Author.hasMany('readers');
|
|
|
|
(new Author).readers.should.be.an.instanceOf(Function);
|
|
|
|
Object.keys((new Reader).toObject()).should.include('authorId');
|
2013-03-26 20:48:14 +00:00
|
|
|
|
2013-03-27 17:53:07 +00:00
|
|
|
db.autoupdate(done);
|
2013-03-26 20:48:14 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should build record on scope', function(done) {
|
|
|
|
Book.create(function(err, book) {
|
|
|
|
var c = book.chapters.build();
|
|
|
|
c.bookId.should.equal(book.id);
|
|
|
|
c.save(done);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should create record on scope', function(done) {
|
|
|
|
Book.create(function(err, book) {
|
|
|
|
book.chapters.create(function(err, c) {
|
|
|
|
should.not.exist(err);
|
|
|
|
should.exist(c);
|
|
|
|
c.bookId.should.equal(book.id);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2013-03-29 07:43:04 +00:00
|
|
|
it.skip('should fetch all scoped instances', function(done) {
|
2013-03-26 20:48:14 +00:00
|
|
|
Book.create(function(err, book) {
|
|
|
|
book.chapters.create({name: 'a'}, function() {
|
|
|
|
book.chapters.create({name: 'z'}, function() {
|
|
|
|
book.chapters.create({name: 'c'}, function() {
|
|
|
|
fetch(book);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
function fetch(book) {
|
|
|
|
book.chapters(function(err, ch) {
|
|
|
|
should.not.exist(err);
|
|
|
|
should.exist(ch);
|
|
|
|
ch.should.have.lengthOf(3);
|
|
|
|
|
|
|
|
book.chapters({order: 'name DESC'}, function(e, c) {
|
|
|
|
should.not.exist(e);
|
|
|
|
should.exist(c);
|
|
|
|
c.shift().name.should.equal('z');
|
|
|
|
c.pop().name.should.equal('a');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
2013-03-26 00:39:47 +00:00
|
|
|
});
|
2013-04-03 20:46:41 +00:00
|
|
|
|
|
|
|
it('should find scoped record', function(done) {
|
|
|
|
var id;
|
|
|
|
Book.create(function(err, book) {
|
|
|
|
book.chapters.create({name: 'a'}, function(err, ch) {
|
|
|
|
id = ch.id;
|
|
|
|
book.chapters.create({name: 'z'}, function() {
|
|
|
|
book.chapters.create({name: 'c'}, function() {
|
|
|
|
fetch(book);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
function fetch(book) {
|
|
|
|
book.chapters.find(id, function(err, ch) {
|
|
|
|
should.not.exist(err);
|
|
|
|
should.exist(ch);
|
|
|
|
ch.id.should.equal(id);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2013-03-26 00:39:47 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('belongsTo', function() {
|
2013-03-26 20:48:14 +00:00
|
|
|
var List, Item, Fear, Mind;
|
|
|
|
|
|
|
|
it('can be declared in different ways', function() {
|
|
|
|
List = db.define('List', {name: String});
|
|
|
|
Item = db.define('Item', {name: String});
|
|
|
|
Fear = db.define('Fear');
|
|
|
|
Mind = db.define('Mind');
|
|
|
|
|
|
|
|
// syntax 1 (old)
|
|
|
|
Item.belongsTo(List);
|
|
|
|
Object.keys((new Item).toObject()).should.include('listId');
|
|
|
|
(new Item).list.should.be.an.instanceOf(Function);
|
|
|
|
|
|
|
|
// syntax 2 (new)
|
|
|
|
Fear.belongsTo('mind');
|
|
|
|
Object.keys((new Fear).toObject()).should.include('mindId');
|
|
|
|
(new Fear).mind.should.be.an.instanceOf(Function);
|
|
|
|
// (new Fear).mind.build().should.be.an.instanceOf(Mind);
|
|
|
|
});
|
|
|
|
|
2013-03-27 17:53:07 +00:00
|
|
|
it('can be used to query data', function(done) {
|
|
|
|
List.hasMany('todos', {model: Item});
|
2013-03-31 11:24:03 +00:00
|
|
|
db.automigrate(function() {
|
|
|
|
List.create(function(e, list) {
|
|
|
|
should.not.exist(e);
|
|
|
|
should.exist(list);
|
|
|
|
list.todos.create(function(err, todo) {
|
|
|
|
todo.list(function(e, l) {
|
|
|
|
should.not.exist(e);
|
|
|
|
should.exist(l);
|
2013-04-15 05:13:31 +00:00
|
|
|
l.should.be.an.instanceOf(List);
|
|
|
|
todo.list().should.equal(l.id);
|
2013-03-31 11:24:03 +00:00
|
|
|
done();
|
|
|
|
});
|
2013-03-27 17:53:07 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2013-04-15 05:13:31 +00:00
|
|
|
|
2013-03-26 00:39:47 +00:00
|
|
|
});
|
|
|
|
|
2013-04-12 21:35:06 +00:00
|
|
|
describe('hasAndBelongsToMany', function() {
|
|
|
|
var Article, Tag, ArticleTag;
|
2013-04-11 23:23:34 +00:00
|
|
|
it('can be declared', function(done) {
|
|
|
|
Article = db.define('Article', {title: String});
|
|
|
|
Tag = db.define('Tag', {name: String});
|
|
|
|
Article.hasAndBelongsToMany('tags');
|
2013-04-12 21:35:06 +00:00
|
|
|
ArticleTag = db.models.ArticleTag;
|
|
|
|
db.automigrate(function() {
|
|
|
|
Article.destroyAll(function() {
|
|
|
|
Tag.destroyAll(function() {
|
|
|
|
ArticleTag.destroyAll(done)
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2013-04-11 23:23:34 +00:00
|
|
|
});
|
2013-04-12 21:35:06 +00:00
|
|
|
|
|
|
|
it('should allow to create instances on scope', function(done) {
|
|
|
|
Article.create(function(e, article) {
|
|
|
|
article.tags.create({name: 'popular'}, function(e, t) {
|
|
|
|
t.should.be.an.instanceOf(Tag);
|
|
|
|
ArticleTag.findOne(function(e, at) {
|
|
|
|
should.exist(at);
|
|
|
|
at.tagId.should.equal(t.id);
|
|
|
|
at.articleId.should.equal(article.id);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should allow to fetch scoped instances', function(done) {
|
|
|
|
Article.findOne(function(e, article) {
|
|
|
|
article.tags(function(e, tags) {
|
|
|
|
should.not.exist(e);
|
|
|
|
should.exist(tags);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should allow to add connection with instance', function(done) {
|
|
|
|
Article.findOne(function(e, article) {
|
|
|
|
Tag.create({name: 'awesome'}, function(e, tag) {
|
|
|
|
article.tags.add(tag, function(e, at) {
|
|
|
|
should.not.exist(e);
|
|
|
|
should.exist(at);
|
|
|
|
at.should.be.an.instanceOf(ArticleTag);
|
|
|
|
at.tagId.should.equal(tag.id);
|
|
|
|
at.articleId.should.equal(article.id);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should allow to remove connection with instance', function(done) {
|
|
|
|
Article.findOne(function(e, article) {
|
|
|
|
article.tags(function(e, tags) {
|
|
|
|
var len = tags.length;
|
|
|
|
article.tags.remove(tags[0], function(e, at) {
|
|
|
|
should.not.exist(e);
|
|
|
|
article.tags(true, function(e, tags) {
|
|
|
|
tags.should.have.lengthOf(len - 1);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2013-03-26 00:39:47 +00:00
|
|
|
});
|
2013-04-11 23:23:34 +00:00
|
|
|
|
2013-03-26 00:39:47 +00:00
|
|
|
});
|