Как увеличить время ожидания для одного теста в мокко
Я отправляю сетевой запрос в тестовом примере, но иногда это занимает больше 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
Вы также можете подумать о том, чтобы выбрать другой подход и заменить вызов сетевого ресурса заглушкой или фиктивным объектом. Используя 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
});