我正在尝试为以下 javascript 函数编写单元测试。
const $ = require("jquery");
const Toggle = (function (toggle, $) {
toggle.clickHandler = () => {
$(".active").not(this).removeClass("active").next().hide(300);
$(this).toggleClass("active");
if (false == $(this).next().is(":visible")) {
$("#accordion > ul").slideUp(300);
}
$(this).next().slideToggle(300);
};
$("#accordion > li > div").on("click", toggle.clickHandler);
return {
toggle,
};
})({}, $);
module.exports = Toggle.toggle;
我写了以下笑话测试
const toggle = require("./toggle");
const $ = require("jquery");
jest.dontMock("jquery");
jest.dontMock("./acc");
describe("Toggle", () => {
it("It should call click handler", () => {
document.body.innerHTML = ` <ul id="accordion">
<li>
<div>Sports</div>
<ul>
<li><a href="#">Golf</a></li>
<li><a href="#">Cricket</a></li>
<li><a href="#">Football</a></li>
</ul>
</li>
</ul>
`;
const spy = jest.spyOn(toggle, "clickHandler");
$("div").trigger("click");
$("div").trigger("click");
expect(spy).toBeCalledTimes(2);
});
});
但是当我运行测试时,我收到以下错误。
预期来电数:2 已接来电数:0