我有一个使用 Mocha 的 typescript 项目。假设我们有两个模块,如下所示。
// http.ts
export class Http {
}
// app.ts
import Http from './http';
export class App {
}
当我测试应用程序时,如何模拟 Http 模块?
测试通过npm脚本执行,如下。
"test": "cross-env NODE_ENV=test ./node_modules/mocha/bin/mocha",
Mocha 选项 (mocha.opts) 如下所示。
test/setup.ts
--compilers ts:ts-node/register
--compilers tsx:ts-node/register
./src/**/*.spec.ts
最佳答案
ts-mock-imports使您可以在运行时控制导入并保持类型安全。
在app.spec.ts
import * as httpModule from 'http';
import { App } from '../src/app';
import { ImportMock } from 'ts-mock-imports';
const httpMock = ImportMock.mockClass(httpModule, 'Http');
const app = new App(); // App now uses a fake version of the Http class
现在您可以控制 Http 模块在测试中的行为方式。
模拟对 get 的响应:
httpMock.mock('get', { data: true });
const response = app.makeGetRequest(); // returns { data: true }
关于node.js - 使用 Mocha 和 Typescript 模拟依赖关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38016997/