- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在编写如下 Jest enzyme 测试:
import React from 'react';
import ManageDrugTermPage from '../js/manageDrugTermPage.jsx';
import toJson from 'enzyme-to-json';
describe('manage drug term page test suite', () => {
it('snapshot test', () => {
const setRouteLeaveHook =jest.fn();
let wrapper = shallow(
<ManageDrugTermPage params={{id : 25, router: setRouteLeaveHook}}/>
);
expect(toJson(wrapper)).toMatchSnapshot();
})
})
我想在快照中查看 ManageDrugTermPage 的详细信息,但快照仅显示:
exports[`manage drug term page test suites snapshot test 1`] = `
<ManageDrugTermPage
params={
Object {
"id": 25,
"router": [Function],
}
}
/>
`;
如何在快照中呈现 ManageDrugTermPage?我不想使用 renderer.create 但想通过 enzyme 来完成。
最佳答案
问题是 shallow
仅渲染一层深度,因此组件中使用的每个子组件都会被渲染,但不会渲染它们的子组件。有两种方法可以使 enzyme 呈现 child 的内容。首先是mount
这将强制所有组件渲染其子组件,直到它们到达 DOM 元素。这样做的问题是它可能会导致非常大且难以读取的快照。
另一个解决方案是使用 dive
强制子组件呈现其内容。如果您使用 redux 中的 connect
等高阶组件,这尤其有用。因为在这种情况下,您渲染的组件将只是包装的组件,并且 shallow
不会渲染您期望的内容。使用dive
,您可以强制包装的组件渲染其子组件,这就是您真正希望在快照中看到的内容。
您的示例中唯一奇怪的事情是,即使是第一级子级也不会渲染。所以也许你也可以发布组件代码。
关于unit-testing - Jest enzyme 浅测试没有渲染React组件的所有元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44034904/
免责声明 这篇文章是关于术语“浅拷贝”和“深拷贝”的正确用法,特别是在谈论复制一个不包含任何引用的对象时。这个问题并不意味着(也不应该)基于意见,除非真的没有关于这个话题的共识。我已将此问题标记为 C
我有这个功能 int getrelation(string name, RELATION& output){ bool found=0; int index=0;
与 why should I make a copy of a data frame in pandas 有关 我注意到在流行的backtesting图书馆, def __init__(self, d
我的问题很基础,但我想 100% 理解所有内容。 SO中的很多问题都引用了我的帖子,但我没有找到满意的答案。 我们知道java中的枚举是引用类型。让我们考虑以下片段: public static cl
请引用这个 fiddle 的问题。 http://jsfiddle.net/AQR55/ 1)为什么附加到隔离范围属性的 watch - 双向绑定(bind)到父属性,不会在更改父范围属性时触发。 在
我想使用 UP3 来完成一项非常具体的任务,我应该能够使用 API 来实现该任务。我想了解是否可以编写以下应用程序。 基于https://jawbone.com/support/articles/00
如何在辅助方法中传递上下文并提取数据? 请参阅以下代码片段: import AppContext from '../../context/AppContext' import extractDatta
我正在尝试使用 simple-git 创建浅克隆。我正在尝试创建与此命令等效的命令:git clone --depth 1 https://github.com/steveukx/git-js.git
我是一名优秀的程序员,十分优秀!