我在NestJS 6上有一项服务。我将TypeORM与MySQL配合使用。
当我尝试使用@Transaction()
和@TransactionManager()
装饰器编写方法的单元测试时,出现错误:ConnectionNotFoundError: Connection "default" was not found.
。
@Put(':id')
@Transaction()
update(
@Body() someData: SomeDto,
@Param('id') id: number,
@UserDecorator() user: User,
@TransactionManager() manager: EntityManager,
) {
return this.someService.update(id, someData, user, manager);
}
我的测试:
beforeEach(async () => {
manager = new EntityManager(null);
someService = new SomeService();
someController = new SomeController(someService);
});
describe('update', () => {
it('should update', async () => {
jest.spyOn(someService, 'update').mockResolvedValue(result);
await expect(await someController.update(someData, 1, user, manager)).toBe(result);
expect(someService.update).toBeCalledWith(1, someDto, user, manager);
});
});
是否有更好的编写和测试方法?
答案 0 :(得分:0)
像这样使用 typeorm 的 @Transaction 与 nest 的 DI 背道而驰,因此使测试变得非常困难,请参阅此问题:github.com/nestjs/typeorm/issues/57 关于如何在 nest 中进行事务的官方文档将很快跟进。>
来自 Kim Kern 的上述建议对我有用。我按照 NestJS 文档的建议将 @Transaction
替换为 connection.transaction(cb)
,现在我可以正确模拟 TypeORM 内容并进行隔离测试。