为什么我的Supertest测试失败了?

时间:2016-01-02 21:47:15

标签: node.js express supertest

我正在基于此回购开始我的项目: 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)

1 个答案:

答案 0 :(得分:3)

问题是您的测试是异步的,但您的代码是同步的。具体来说,始终会调用done()行。

您需要将done()行移至.end块,并为错误案例添加done(err),如下所示:

.end(function(err, res){
    if(err){
        console.log("error");
        done(err);
    }
    else {
        console.log(res);
        done();
    }
});