我想测试我的“ missing_body”是否被抛出。但是我的测试仅显示已捕获的错误,但是预期测试仍然失败。你能帮我理解吗?
async add(req) {
const db = _.get(req, 'app.locals.db');
const bookDescription = req.body;
logger.info('books.add', bookDescription);
if (_.isEmpty(bookDescription)) {
throw new Error('missing_body');
}
[...]
}
describe('+add(req)', function() {
it('should fail because of missing body', async function() {
const req = {
body: {},
};
expect(await this.ctrl.add(req)).to.throw(new Error('missing_body'));
});
});
答案 0 :(得分:1)
另一个错误是提供一个对象方法(或任何依赖于此的独立函数)作为断言的目标。这样做是有问题的,因为当.throw调用函数时,此上下文将丢失。它无法知道应该是什么。有两种方法可以解决此问题。一种解决方案是将方法或函数调用包装在另一个函数中。另一个解决方案是使用绑定。如果您测试同步功能。
expect(function () { cat.meow(); }).to.throw(); // Function expression
expect(() => cat.meow()).to.throw(); // ES6 arrow function
expect(cat.meow.bind(cat)).to.throw(); // Bind
但是在异步(await add()).to.throw(Error)
中将永远无法工作:如果fail()拒绝,则会引发错误,并且永远不会执行.to.throw(Error)。因此,您需要执行以下操作:
it('should fail', async () => {
await expect(this.ctrl.add(req.body)).to.be.rejectedWith(Error);
})
解决方案:
async add(req) {
const db = _.get(req, 'app.locals.db');
const bookDescription = req.body;
logger.info('books.add', bookDescription);
if (_.isEmpty(bookDescription)) {
throw new Error('missing_body');
}
[...]
}
describe('+add(req)', function() {
it('should fail because of missing body', async function() {
const req = {
body: {},
};
await expect(this.ctrl.add(req.body)).to.be.rejectedWith(Error);
});
});
答案 1 :(得分:0)
如果您期望捕获某些错误,则需要在catch块内声明。您试图断言创建新的Error实例的错误。如果您正在使用同步编程,那么您需要捕获以下错误:
it('should fail because of missing body', async function() {
const req = {
body: {},
};
try {
await this.ctrl.add(req)
} catch(e) {
expect(e.message).to.equal('missing_body');
}
});