我正在基于此回购开始我的项目: https://github.com/madhums/node-express-mongoose
我决定做的第一件事就是编写测试,所以我去了测试文件,它看起来像这样:
var mongoose = require('mongoose');
var should = require('should');
var request = require('supertest');
var app = require('../server');
var context = describe;
// other stuff you want to include for tests
before(function (done) {
// clear db and other stuff
done();
});
describe('Users', function () {
describe('POST /users', function () {
it('should create a user', function (done) {
request(app)
.post('/users')
.field('name', 'foo')
.field('email', 'foo')
.field('password', 'foo')
.expect('Content-Type', /json/)
.expect(200)
.end(function(err, res){
console.log(err);
if(err){
console.log("error");
}
// console.log(res);
});
done();
});
});
});
after(function (done) {
// do some stuff
done();
});
我实际上没有创建路由,所以测试应该失败,我甚至会在.end上出现错误,所以任何想法为什么测试没有失败?
当我运行npm test
时,我的控制台会向我显示此信息Express app started on port 3000
Users
POST /users
✓ should create a user
[Error: expected "Content-Type" matching /json/, got "text/html; charset=utf-8"]
error
1 passing (653ms)
答案 0 :(得分:3)
问题是您的测试是异步的,但您的代码是同步的。具体来说,始终会调用done()
行。
您需要将done()
行移至.end
块,并为错误案例添加done(err)
,如下所示:
.end(function(err, res){
if(err){
console.log("error");
done(err);
}
else {
console.log(res);
done();
}
});