gpt4 book ai didi

javascript - React Jest 匹配快照,使用子组件测试组件时崩溃

转载 作者:行者123 更新时间:2023-12-03 05:53:31 25 4
gpt4 key购买 nike

我有一些带有来自第三方插件/库的子组件的组件。我使用 Jest 进行单元测试和 toMatchSnapshot() 方法。我尝试使用 jest.unmock('ChildComponet.js') 排除子组件,但收到此错误:

jest.unmock('ChildComponet.js') 被调用,但自动模拟被禁用。删除对 jest.unmock 的不必要调用,或通过 jest.enableAutomock(); 为此测试启用自动模拟。此警告可能是 Jest 15 中默认配置更改的结果。

我启用了jest.enableAutomock();,现在我遇到了错误:

类型错误:无法读取未定义的属性“DEFINE_MANY”

我把它放在我的 package.json 上,但什么也没发生:

"unmockedModulePathPatterns": ["rootDir/node_modules/react"]

有什么想法吗?

在 React 中对组件进行单元测试的正确方法是吗?

最佳答案

到目前为止我发现的模拟 react 组件的最简单方法是使用:

jest.mock('component', ()=> 'ComponentName')

在要测试的模块的导入语句之前。

第一个参数是全局 npm 模块的名称或本地组件的路径(请注意,该路径是相对于测试文件的路径)。第二个参数只是一个返回字符串的函数(我总是返回与 jsx 中使用的名称相同的名称)。这将导致转储组件不执行任何操作,但名称与原始组件相同。因此,在您的快照中,您将看不到任何差异,除了模拟组件不会渲染任何子组件之外。

现在看看您收到的错误消息。

jest.unmock('ChildComponet.js') was called but automocking is disabled...

问题是您使用jest.unmock而不是jest.mock。 Jest 具有自动模拟模块的所有依赖项的功能。启用自动模拟后,您可以使用 jest.unmock 来获得一些基本库(如 lodash 或 moment)的真正植入。由于自动模拟功能让很多人感到困惑,因此他们决定将其设为可选。 Tldr,您试图取消模拟一些最初没有被模拟的东西,因为您没有启用自动模拟。

TypeError: Cannot read property 'DEFINE_MANY' of undefined

当您启用自动模拟时,每个导入的模块都会被替换为未定义。关于 unmockedModulePathPatterns 设置,我不能说太多,但我相信您必须使用与导入模块相同的模式,因此如果它是全局的,则不必将路径放在 node_modules 文件夹。

关于javascript - React Jest 匹配快照,使用子组件测试组件时崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40044730/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com