通常,在通讯录中导入通常的方法会阻止模块被仿真。"。 假设我在 node.js 项目中编写了以下产品代码,我希望测试这些代码:
//host.ts
import http = require('http');
export class Host {
public start(port: number): http.Server {
return http.createServer().listen(port);
}
}
我有下面的单元测试 使用嘲弄( 请求 #3313 中的d.ts ) 和 mocha:
import chai = require('chai');
import mockery = require('mockery');
import webserver = require('../hosting/host');
describe('host', (): void => {
describe('start()', (): void => {
before(() : void => {
mockery.enable();
});
after((): void => {
mockery.deregisterAll();
mockery.disable();
});
it('should create an http server', (): void => {
mockery.registerMock('http', {
Server: mocks.Server,
createServer: (app: any) : any => new mocks.Server(app)
});
var host: webserver.Host = new webserver.Host({ port: 111 });
var server: any = host.start();
chai.expect(server).is.instanceOf(mocks.Server);
});
});
});
module mocks {
'use strict';
export class Server {
app: any;
constructor(app: any) {
this.app = app;
}
}
}
问题是当 import webserver = require('../hosting/host')
被称为测试中的模拟尚未设置,而且返回的is被返回。 我试着尝试 var http = require('http')
在 Host.start
函数中,但这可以防止将 http.Server 声明为返回值。
我应该如何使用mock在 Typescript implementing执行单元测试? 有比嘲笑更好的库?