我在一个测试用例中提交了一个网络请求,但这有时需要超过2秒(默认超时)。

如何增加单个测试用例的超时时间?


当前回答

对于Express上的测试导航:

const request = require('supertest');
const server = require('../bin/www');

describe('navigation', () => {
    it('login page', function(done) {
        this.timeout(4000);
        const timeOut = setTimeout(done, 3500);

        request(server)
            .get('/login')
            .expect(200)
            .then(res => {
                res.text.should.include('Login');
                clearTimeout(timeOut);
                done();
            })
            .catch(err => {
                console.log(this.test.fullTitle(), err);
                clearTimeout(timeOut);
                done(err);
            });
    });
});

本例中测试时间为4000 (4s)。

注意:setTimeout(done, 3500)是次要的,因为在测试时间内调用了than done,但是clearTimeout(timeOut)避免了在所有这些时间内使用than。

其他回答

对于Express上的测试导航:

const request = require('supertest');
const server = require('../bin/www');

describe('navigation', () => {
    it('login page', function(done) {
        this.timeout(4000);
        const timeOut = setTimeout(done, 3500);

        request(server)
            .get('/login')
            .expect(200)
            .then(res => {
                res.text.should.include('Login');
                clearTimeout(timeOut);
                done();
            })
            .catch(err => {
                console.log(this.test.fullTitle(), err);
                clearTimeout(timeOut);
                done(err);
            });
    });
});

本例中测试时间为4000 (4s)。

注意:setTimeout(done, 3500)是次要的,因为在测试时间内调用了than done,但是clearTimeout(timeOut)避免了在所有这些时间内使用than。

(因为我今天碰到了这个)

使用ES2015胖箭头语法时要小心:

这将失败:

it('accesses the network', done => {

  this.timeout(500); // will not work

  // *this* binding refers to parent function scope in fat arrow functions!
  // i.e. the *this* object of the describe function

  done();
});

编辑:为什么它失败了:

正如@atoth在评论中提到的,胖箭头函数没有自己的这个绑定。因此,it函数不可能绑定回调的this并提供超时函数。

底线:对于需要增加超时的函数,不要使用箭头函数。

给你:http://mochajs.org/#test-level

it('accesses the network', function(done){
  this.timeout(500);
  [Put network code here, with done() in the callback]
})

对于箭头函数,使用方法如下:

it('accesses the network', (done) => {
  [Put network code here, with done() in the callback]
}).timeout(500);

如果你想使用es6箭头函数,你可以在你的it定义的末尾添加一个.timeout(ms):

it('should not timeout', (done) => {
    doLongThing().then(() => {
        done();
    });
}).timeout(5000);

至少在Typescript中是这样的。

如果你在NodeJS中使用,那么你可以在package.json中设置timeout

"test": "mocha --timeout 10000"

然后你可以像这样使用NPM运行:

npm test