不要怂,就是干,撸起袖子干!

Commit 3e53556c by sdepold

some helpers for setting up the tests

1 parent 646fe949
if (typeof require === 'function') { if (typeof require === 'function') {
const buster = require("buster") const buster = require("buster")
, Sequelize = require("../../index") , Helpers = require('../buster-helpers')
, config = require("../config/config") , Sequelize = require('../../index')
, sequelize = new Sequelize(config.database, config.username, config.password, {
logging: false
})
} }
buster.spec.expose() buster.spec.expose()
...@@ -14,23 +11,20 @@ describe('BelongsTo', function() { ...@@ -14,23 +11,20 @@ describe('BelongsTo', function() {
before(function(done) { before(function(done) {
var self = this var self = this
sequelize.getQueryInterface() Helpers.initTests({
.dropAllTables() beforeComplete: function(sequelize) { self.sequelize = sequelize },
.success(function() { onComplete: done
sequelize.daoFactoryManager.daos = []
done()
}) })
.error(function(err) { console.log(err) })
}) })
describe('setAssociation', function() { describe('setAssociation', function() {
it('clears the association if null is passed', function(done) { it('clears the association if null is passed', function(done) {
var User = sequelize.define('User', { username: Sequelize.STRING }) var User = this.sequelize.define('User', { username: Sequelize.STRING })
, Task = sequelize.define('Task', { title: Sequelize.STRING }) , Task = this.sequelize.define('Task', { title: Sequelize.STRING })
Task.belongsTo(User) Task.belongsTo(User)
sequelize.sync({ force: true }).success(function() { this.sequelize.sync({ force: true }).success(function() {
User.create({ username: 'foo' }).success(function(user) { User.create({ username: 'foo' }).success(function(user) {
Task.create({ title: 'task' }).success(function(task) { Task.create({ title: 'task' }).success(function(task) {
task.setUser(user).success(function() { task.setUser(user).success(function() {
......
if (typeof require === 'function') { if (typeof require === 'function') {
const buster = require("buster") const buster = require("buster")
, Sequelize = require("../../index") , Helpers = require('../buster-helpers')
, config = require("../config/config") , Sequelize = require('../../index')
, sequelize = new Sequelize(config.database, config.username, config.password, {
logging: false
})
} }
buster.spec.expose() buster.spec.expose()
...@@ -14,26 +11,21 @@ describe('HasMany', function() { ...@@ -14,26 +11,21 @@ describe('HasMany', function() {
before(function(done) { before(function(done) {
var self = this var self = this
sequelize.getQueryInterface() Helpers.initTests({
.dropAllTables() beforeComplete: function(sequelize) { self.sequelize = sequelize },
.success(function() { onComplete: done
sequelize.daoFactoryManager.daos = []
done()
}) })
.error(function(err) { console.log(err) })
}) })
describe('(1:N)', function() { describe('(1:N)', function() {
describe('hasSingle', function() { describe('hasSingle', function() {
before(function(done) { before(function(done) {
var self = this this.Article = this.sequelize.define('Article', { 'title': Sequelize.STRING })
this.Label = this.sequelize.define('Label', { 'text': Sequelize.STRING })
this.Article = sequelize.define('Article', { 'title': Sequelize.STRING })
this.Label = sequelize.define('Label', { 'text': Sequelize.STRING })
this.Article.hasMany(this.Label) this.Article.hasMany(this.Label)
sequelize.sync({ force: true }).success(done) this.sequelize.sync({ force: true }).success(done)
}) })
it('does not have any labels assigned to it initially', function(done) { it('does not have any labels assigned to it initially', function(done) {
...@@ -86,14 +78,12 @@ describe('HasMany', function() { ...@@ -86,14 +78,12 @@ describe('HasMany', function() {
describe('hasAll', function() { describe('hasAll', function() {
before(function(done) { before(function(done) {
var self = this this.Article = this.sequelize.define('Article', { 'title': Sequelize.STRING })
this.Label = this.sequelize.define('Label', { 'text': Sequelize.STRING })
this.Article = sequelize.define('Article', { 'title': Sequelize.STRING })
this.Label = sequelize.define('Label', { 'text': Sequelize.STRING })
this.Article.hasMany(this.Label) this.Article.hasMany(this.Label)
sequelize.sync({ force: true }).success(done) this.sequelize.sync({ force: true }).success(done)
}) })
it('answers false if only some labels have been assigned', function(done) { it('answers false if only some labels have been assigned', function(done) {
...@@ -137,12 +127,12 @@ describe('HasMany', function() { ...@@ -137,12 +127,12 @@ describe('HasMany', function() {
describe('setAssociations', function() { describe('setAssociations', function() {
it("clears associations when passing null to the set-method", function(done) { it("clears associations when passing null to the set-method", function(done) {
var User = sequelize.define('User', { username: Sequelize.STRING }) var User = this.sequelize.define('User', { username: Sequelize.STRING })
, Task = sequelize.define('Task', { title: Sequelize.STRING }) , Task = this.sequelize.define('Task', { title: Sequelize.STRING })
Task.hasMany(User) Task.hasMany(User)
sequelize.sync({ force: true }).success(function() { this.sequelize.sync({ force: true }).success(function() {
User.create({ username: 'foo' }).success(function(user) { User.create({ username: 'foo' }).success(function(user) {
Task.create({ title: 'task' }).success(function(task) { Task.create({ title: 'task' }).success(function(task) {
task.setUsers([ user ]).success(function() { task.setUsers([ user ]).success(function() {
...@@ -164,13 +154,14 @@ describe('HasMany', function() { ...@@ -164,13 +154,14 @@ describe('HasMany', function() {
}) })
it("clears associations when passing null to the set-method with omitNull set to true", function(done) { it("clears associations when passing null to the set-method with omitNull set to true", function(done) {
sequelize.options.omitNull = true; this.sequelize.options.omitNull = true;
var User = sequelize.define('User', { username: Sequelize.STRING })
, Task = sequelize.define('Task', { title: Sequelize.STRING }) var User = this.sequelize.define('User', { username: Sequelize.STRING })
, Task = this.sequelize.define('Task', { title: Sequelize.STRING })
Task.hasMany(User) Task.hasMany(User)
sequelize.sync({ force: true }).success(function() { this.sequelize.sync({ force: true }).success(function() {
User.create({ username: 'foo' }).success(function(user) { User.create({ username: 'foo' }).success(function(user) {
Task.create({ title: 'task' }).success(function(task) { Task.create({ title: 'task' }).success(function(task) {
task.setUsers([ user ]).success(function() { task.setUsers([ user ]).success(function() {
...@@ -194,12 +185,12 @@ describe('HasMany', function() { ...@@ -194,12 +185,12 @@ describe('HasMany', function() {
before(function(done) { before(function(done) {
var self = this; var self = this;
this.User = sequelize.define('User', { username: Sequelize.STRING }) this.User = this.sequelize.define('User', { username: Sequelize.STRING })
this.Task = sequelize.define('Task', { title: Sequelize.STRING, active: Sequelize.BOOLEAN }) this.Task = this.sequelize.define('Task', { title: Sequelize.STRING, active: Sequelize.BOOLEAN })
self.User.hasMany(self.Task) this.User.hasMany(self.Task)
sequelize.sync({ force: true }).done(function() { this.sequelize.sync({ force: true }).done(function() {
var chainer = new Sequelize.Utils.QueryChainer([ var chainer = new Sequelize.Utils.QueryChainer([
self.User.create({ username: 'John'}), self.User.create({ username: 'John'}),
self.Task.create({ title: 'Get rich', active: true}), self.Task.create({ title: 'Get rich', active: true}),
...@@ -237,12 +228,13 @@ describe('HasMany', function() { ...@@ -237,12 +228,13 @@ describe('HasMany', function() {
before(function(done) { before(function(done) {
var self = this; var self = this;
this.User = sequelize.define('User', { username: Sequelize.STRING }) this.User = this.sequelize.define('User', { username: Sequelize.STRING })
this.Task = sequelize.define('Task', { title: Sequelize.STRING, active: Sequelize.BOOLEAN }) this.Task = this.sequelize.define('Task', { title: Sequelize.STRING, active: Sequelize.BOOLEAN })
self.User.hasMany(self.Task) self.User.hasMany(self.Task)
self.Task.hasMany(self.User) self.Task.hasMany(self.User)
sequelize.sync({ force: true }).done(function() { this.sequelize.sync({ force: true }).done(function() {
var chainer = new Sequelize.Utils.QueryChainer([ var chainer = new Sequelize.Utils.QueryChainer([
self.User.create({ username: 'John'}), self.User.create({ username: 'John'}),
self.Task.create({ title: 'Get rich', active: true}), self.Task.create({ title: 'Get rich', active: true}),
...@@ -275,8 +267,8 @@ describe('HasMany', function() { ...@@ -275,8 +267,8 @@ describe('HasMany', function() {
}) })
it("removes the reference id, which was added in the first place", function() { it("removes the reference id, which was added in the first place", function() {
var User = sequelize.define('User', { username: Sequelize.STRING }) var User = this.sequelize.define('User', { username: Sequelize.STRING })
, Task = sequelize.define('Task', { title: Sequelize.STRING }) , Task = this.sequelize.define('Task', { title: Sequelize.STRING })
User.hasMany(Task) User.hasMany(Task)
expect(Task.attributes.UserId).toBeDefined() expect(Task.attributes.UserId).toBeDefined()
...@@ -286,8 +278,8 @@ describe('HasMany', function() { ...@@ -286,8 +278,8 @@ describe('HasMany', function() {
}) })
it("adds three items to the query chainer when calling sync", function() { it("adds three items to the query chainer when calling sync", function() {
var User = sequelize.define('User', { username: Sequelize.STRING }) var User = this.sequelize.define('User', { username: Sequelize.STRING })
, Task = sequelize.define('Task', { title: Sequelize.STRING }) , Task = this.sequelize.define('Task', { title: Sequelize.STRING })
User.hasMany(Task) User.hasMany(Task)
Task.hasMany(User) Task.hasMany(User)
...@@ -296,19 +288,19 @@ describe('HasMany', function() { ...@@ -296,19 +288,19 @@ describe('HasMany', function() {
this.stub(Sequelize.Utils, 'QueryChainer').returns({ add: add, run: function(){} }) this.stub(Sequelize.Utils, 'QueryChainer').returns({ add: add, run: function(){} })
sequelize.sync({ force: true }) this.sequelize.sync({ force: true })
expect(add).toHaveBeenCalledThrice() expect(add).toHaveBeenCalledThrice()
}) })
describe('setAssociations', function() { describe('setAssociations', function() {
it("clears associations when passing null to the set-method", function(done) { it("clears associations when passing null to the set-method", function(done) {
var User = sequelize.define('User', { username: Sequelize.STRING }) var User = this.sequelize.define('User', { username: Sequelize.STRING })
, Task = sequelize.define('Task', { title: Sequelize.STRING }) , Task = this.sequelize.define('Task', { title: Sequelize.STRING })
User.hasMany(Task) User.hasMany(Task)
Task.hasMany(User) Task.hasMany(User)
sequelize.sync({ force: true }).success(function() { this.sequelize.sync({ force: true }).success(function() {
User.create({ username: 'foo' }).success(function(user) { User.create({ username: 'foo' }).success(function(user) {
Task.create({ title: 'task' }).success(function(task) { Task.create({ title: 'task' }).success(function(task) {
task.setUsers([ user ]).success(function() { task.setUsers([ user ]).success(function() {
......
if (typeof require === 'function') { if (typeof require === 'function') {
const buster = require("buster") const buster = require("buster")
, Sequelize = require("../../index") , Sequelize = require("../../index")
, config = require("../config/config") , Helpers = require('../buster-helpers')
, sequelize = new Sequelize(config.database, config.username, config.password, {
logging: false
})
} }
buster.spec.expose() buster.spec.expose()
...@@ -14,23 +11,20 @@ describe('HasOne', function() { ...@@ -14,23 +11,20 @@ describe('HasOne', function() {
before(function(done) { before(function(done) {
var self = this var self = this
sequelize.getQueryInterface() Helpers.initTests({
.dropAllTables() beforeComplete: function(sequelize) { self.sequelize = sequelize },
.success(function() { onComplete: done
sequelize.daoFactoryManager.daos = []
done()
}) })
.error(function(err) { console.log(err) })
}) })
describe('setAssociation', function() { describe('setAssociation', function() {
it('clears the association if null is passed', function(done) { it('clears the association if null is passed', function(done) {
var User = sequelize.define('User', { username: Sequelize.STRING }) var User = this.sequelize.define('User', { username: Sequelize.STRING })
, Task = sequelize.define('Task', { title: Sequelize.STRING }) , Task = this.sequelize.define('Task', { title: Sequelize.STRING })
User.hasOne(Task) User.hasOne(Task)
sequelize.sync({ force: true }).success(function() { this.sequelize.sync({ force: true }).success(function() {
User.create({ username: 'foo' }).success(function(user) { User.create({ username: 'foo' }).success(function(user) {
Task.create({ title: 'task' }).success(function(task) { Task.create({ title: 'task' }).success(function(task) {
user.setTask(task).success(function() { user.setTask(task).success(function() {
......
const Sequelize = require(__dirname + "/../index")
, DataTypes = require(__dirname + "/../lib/data-types")
, config = require(__dirname + "/config/config")
var BusterHelpers = module.exports = {
initTests: function(options) {
var sequelize = this.createSequelizeInstance(options)
this.clearDatabase(sequelize, function() {
options.beforeComplete && options.beforeComplete(sequelize, DataTypes)
options.onComplete && options.onComplete(sequelize, DataTypes)
})
},
createSequelizeInstance: function(options) {
options = options || {}
options.dialect = options.dialect || 'mysql'
return new Sequelize(
config[options.dialect].database,
config[options.dialect].username,
config[options.dialect].password,
{
logging: false,
dialect: options.dialect,
port: config[options.dialect].port
}
)
},
clearDatabase: function(sequelize, callback) {
sequelize
.getQueryInterface()
.dropAllTables()
.success(function() {
sequelize.daoFactoryManager.daos = []
callback && callback()
})
.error(function(err) { console.log(err) })
}
}
if(typeof require === 'function') { if(typeof require === 'function') {
const buster = require("buster") const buster = require("buster")
, Sequelize = require("../index")
, config = require("./config/config")
, dialects = ['sqlite', 'mysql', 'postgres'] , dialects = ['sqlite', 'mysql', 'postgres']
, Helpers = require('./buster-helpers')
} }
buster.spec.expose() buster.spec.expose()
...@@ -12,27 +11,19 @@ dialects.forEach(function(dialect) { ...@@ -12,27 +11,19 @@ dialects.forEach(function(dialect) {
before(function(done) { before(function(done) {
var self = this var self = this
this.sequelize = new Sequelize(config.database, config.username, config.password, { Helpers.initTests({
logging: false dialect: dialect,
}) beforeComplete: function(sequelize, DataTypes) {
self.sequelize = sequelize
this.User = this.sequelize.define('User', { self.User = sequelize.define('User', {
username: { type: Sequelize.STRING }, username: { type: DataTypes.STRING },
touchedAt: { type: Sequelize.DATE, defaultValue: Sequelize.NOW } touchedAt: { type: DataTypes.DATE, defaultValue: DataTypes.NOW }
})
self.sequelize
.getQueryInterface()
.dropAllTables()
.success(function() {
self.User
.sync({ force: true })
.success(done)
.error(function(err) {
console.log(err)
}) })
},
onComplete: function(sequelize) {
self.User.sync({ force: true }).success(done)
}
}) })
.error(function(err) { console.log(err) })
}) })
describe('default values', function() { describe('default values', function() {
......
if(typeof require === 'function') { if(typeof require === 'function') {
const buster = require("buster") const buster = require("buster")
, Sequelize = require("../../index") , Helpers = require('../buster-helpers')
, config = require("../config/config")
} }
buster.spec.expose() buster.spec.expose()
...@@ -10,22 +9,19 @@ describe('DAO@sqlite', function() { ...@@ -10,22 +9,19 @@ describe('DAO@sqlite', function() {
before(function(done) { before(function(done) {
var self = this var self = this
this.sequelize = new Sequelize(config.database, config.username, config.password, { Helpers.initTests({
logging: false, dialect: 'sqlite',
dialect: 'sqlite' beforeComplete: function(sequelize, DataTypes) {
}) self.sequelize = sequelize
this.User = this.sequelize.define('User', { self.User = sequelize.define('User', {
username: Sequelize.STRING username: DataTypes.STRING
}) })
},
self.sequelize onComplete: function(sequelize) {
.getQueryInterface()
.dropAllTables()
.success(function() {
self.User.sync({ force: true }).success(done) self.User.sync({ force: true }).success(done)
}
}) })
.error(function(err) { console.log(err) })
}) })
describe('findAll', function() { describe('findAll', function() {
......
Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!