所以我使用的是Typescript / RequireJs / Jasmine,并且不能让我的间谍为另一个模块中加载的模块工作。
这是我的规范:
import { CrmWebApiLib } from "../../../webresources/allgnt_/scripts/Allgnt.RestLib";
import { TextFormatter } from "../../../webresources/new_/scripts/script/TextFormatter";
describe("Test", () => {
it("A Test", () => {
spyOn(CrmWebApiLib, "create").and.callFake((a, b) => { });
TextFormatter.test();
expect(CrmWebApiLib.create).toHaveBeenCalled();
});
it("B Test", () => {
var stub = {
CrmWebApiLib: {
create(a, b) { }
}
};
define("../../../webresources/allgnt_/scripts/Allgnt.RestLib", [], stub as any);
spyOn(stub.CrmWebApiLib, "create").and.callFake((a, b) => { });
TextFormatter.test();
expect(CrmWebApiLib.create).toHaveBeenCalled();
});
});
这是TextFormatter:
import { RestLib, CrmWebApiLib } from "../../../allgnt_/scripts/allgnt.restlib";
export module TextFormatter {
export function test() {
CrmWebApiLib.create("A", "Test");
}
}
在" A Test"或" B测试"我无法让间谍发挥作用。它总是调用实际的实现和错误。我可以更改TextFormatter
以允许注入TextFormatter的定义,但这感觉不对。
如何让spyOn调用在这样的情况下工作?