2013-04-06 10:57:12 +00:00
|
|
|
// This test written in mocha+should.js
|
|
|
|
var should = require('./init.js');
|
|
|
|
|
2013-04-06 10:34:16 +00:00
|
|
|
var db, Model;
|
|
|
|
|
2013-04-06 10:57:12 +00:00
|
|
|
describe('datatypes', function() {
|
2013-04-06 10:34:16 +00:00
|
|
|
|
|
|
|
before(function(done){
|
|
|
|
db = getSchema();
|
|
|
|
Model = db.define('Model', {
|
|
|
|
str: String,
|
|
|
|
date: Date,
|
|
|
|
num: Number,
|
|
|
|
bool: Boolean,
|
|
|
|
list: {type: []},
|
|
|
|
});
|
|
|
|
db.automigrate(function() {
|
|
|
|
Model.destroyAll(done);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should keep types when get read data from db', function(done) {
|
|
|
|
var d = new Date, id;
|
2013-04-07 13:59:24 +00:00
|
|
|
|
2013-04-06 10:34:16 +00:00
|
|
|
Model.create({
|
2013-04-07 13:59:24 +00:00
|
|
|
str: 'hello', date: d, num: '3', bool: 1, list: ['test']
|
2013-04-06 10:34:16 +00:00
|
|
|
}, function(err, m) {
|
|
|
|
should.not.exist(err);
|
|
|
|
should.exist(m && m.id);
|
2013-04-07 13:59:24 +00:00
|
|
|
m.str.should.be.a('string');
|
|
|
|
m.num.should.be.a('number');
|
|
|
|
m.bool.should.be.a('boolean');
|
2013-04-06 10:34:16 +00:00
|
|
|
id = m.id;
|
|
|
|
testFind(testAll);
|
|
|
|
});
|
|
|
|
|
|
|
|
function testFind(next) {
|
|
|
|
Model.find(id, function(err, m) {
|
|
|
|
should.not.exist(err);
|
|
|
|
should.exist(m);
|
|
|
|
m.str.should.be.a('string');
|
|
|
|
m.num.should.be.a('number');
|
|
|
|
m.bool.should.be.a('boolean');
|
|
|
|
m.date.should.be.an.instanceOf(Date);
|
|
|
|
m.date.toString().should.equal(d.toString(), 'Time must match');
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function testAll() {
|
|
|
|
Model.findOne(function(err, m) {
|
|
|
|
should.not.exist(err);
|
|
|
|
should.exist(m);
|
|
|
|
m.str.should.be.a('string');
|
|
|
|
m.num.should.be.a('number');
|
|
|
|
m.bool.should.be.a('boolean');
|
|
|
|
m.date.should.be.an.instanceOf(Date);
|
|
|
|
m.date.toString().should.equal(d.toString(), 'Time must match');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
}
|
2013-04-07 13:59:24 +00:00
|
|
|
|
2013-04-06 10:34:16 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
});
|