Как увеличить время ожидания для одного теста в мокко

Я отправляю сетевой запрос в тестовом примере, но иногда это занимает больше 2 секунд (время ожидания по умолчанию).

Как увеличить время ожидания для одного теста?

7 ответов

Вот и вы: http://mochajs.org/

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, вы можете добавить .timeout(ms) до конца вашего it определение:

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

По крайней мере, это работает в Typescript.

(так как я столкнулся с этим сегодня)

Будьте осторожны при использовании синтаксиса жирной стрелки 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 не может привязаться к функции обратного вызова и предоставить функцию тайм-аута.

Итог: не используйте функции стрелок для функций, которые требуют увеличенного времени ожидания.

Если вы используете в NodeJS, вы можете установить тайм-аут в package.json

"test": "mocha --timeout 10000"

тогда вы можете запустить с помощью npm, как:

npm test

Из командной строки:

mocha -t 100000 test.js

Вы также можете подумать о том, чтобы выбрать другой подход и заменить вызов сетевого ресурса заглушкой или фиктивным объектом. Используя Sinon, вы можете отделить приложение от сетевого сервиса, сосредоточив свои усилия на разработке.

Для проверки навеса на Express :

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

describe('navegation', () => {
    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 (4 с).

Замечания: setTimeout(done, 3500) является второстепенным для чем done вызывается во время теста, но clearTimeout(timeOut) это избежать, чем использовать все это время.

Это сработало для меня! Не удалось найти ничего, с чем можно было бы работать раньше ()

describe("When in a long running test", () => {
  it("Should not time out with 2000ms", async () => {
    let service = new SomeService();
    let result = await service.callToLongRunningProcess();
    expect(result).to.be.true;
  }).timeout(10000); // Custom Timeout 
});
Другие вопросы по тегам