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

Commit 3e53556c by sdepold

some helpers for setting up the tests

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