目前,我正在为我的项目实现单元测试,并且有一个包含 window.location.href
的文件。
我想模拟这个来测试,这是我的示例代码:
it("method A should work correctly", () => {
const url = "http://dummy.com";
Object.defineProperty(window.location, "href", {
value: url,
writable: true
});
const data = {
id: "123",
name: null
};
window.location.href = url;
wrapper.vm.methodA(data);
expect(window.location.href).toEqual(url);
});
但是我得到这个错误:
TypeError: Cannot redefine property: href
at Function.defineProperty (<anonymous>)
我尝试了一些解决方案,但没有解决。我需要一些提示来帮助我摆脱这个麻烦。请帮忙。
最佳答案
你可以试试:
global.window = Object.create(window);
const url = "http://dummy.com";
Object.defineProperty(window, 'location', {
value: {
href: url
}
});
expect(window.location.href).toEqual(url);
看看这个问题的 Jest Issue:
Jest Issue
关于vue.js - 如何用 Jest + Vuejs 模拟 window.location.href?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54021037/