我的目标是在运行Jest单元测试时在Angular应用程序中模拟resize-observer-polyfill。
当前,出现以下错误:
TypeError: resize_observer_polyfill_1.default is not a constructor
我找到了related issue here,因此尝试在组件旁边实现模拟。所以这是我尝试过的:
_mocks_ / resizeObserver.ts
class ResizeObserver {
observe() {
// do nothing
}
unobserve() {
// do nothing
}
}
window.ResizeObserver = ResizeObserver;
export default ResizeObserver;
然后在我的规格文件中导入:
import ResizeObserver from './_mocks_/resizeObserver';
但这不能解决问题。
在代码中,我这样使用polyfill:
import ResizeObserver from 'resize-observer-polyfill';
这是一个非常令人沮丧的问题,所以我真的希望以某种方式解决该问题。
答案 0 :(得分:0)
据我所知,您正在单元测试中导入该模拟,但您没有使用它。您需要在单元测试文件的顶部添加以下内容:
import ResizeObserver from './_mocks_/resizeObserver';
jest.mock('resize-observer-polyfill', () => { return ResizeObserver; });
答案 1 :(得分:0)
来自同一个 GitHub 问题:
jest.mock('resize-observer-polyfill', () => ({
__esModule: true,
default: jest.fn().mockImplementation(() => ({
observe: jest.fn(),
unobserve: jest.fn(),
disconnect: jest.fn(),
})),
}));
如果您想立即调用调整大小处理函数,可以将其添加到实现中:
jest.mock('resize-observer-polyfill', () => ({
__esModule: true,
default: jest.fn().mockImplementation((cb) => {
// call event handler immediately
cb()
return {
observe: jest.fn(),
unobserve: jest.fn(),
disconnect: jest.fn(),
}
}),
}));
如果您想按需调用它,一种方法是向observe 函数添加一些实际的事件处理程序。