- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试为 React JS 运行单元测试 - 使用 jest/enzyme。
目前测试失败。不太清楚为什么,也许我没有正确调用 expect(wrapper.find)。这是我测试的一部分:
File.test.js
it('renders modal when open flag is true', () => {
const props = { isOpen: true };
const wrapper = mount(
<div id="root">
<Component {...props} />
</div>
);
wrapper.update();
expect(toJson(wrapper)).toMatchSnapshot();
expect(wrapper.find('.loa-download-header').exists()).toEqual(true);
expect(wrapper.text()).toContain(' Please enter a password.');
});
});
这里是 File.js 的一部分,显示了我正在尝试测试的一段代码作为示例。
render() {
return (
<Modal
<div title="Close Window" className="add-custom-field-close" onClick={() => {this.closeModal()}}><FontAwesome name='xbutton' className='fa-times' /></div>
</div>
</div>
<div className='loa-download-header-wrapper'>
<div className='loa-download-header'>
Please enter a password.
</div>
错误:expect(received).toEqual(expected)
Expected value to equal:
true
Received:
false
对代码的任何更正都将非常有帮助谢谢
最佳答案
我花了一些时间将您的代码集成到沙箱中。您的代码有很多更改,我在下面列出了这些更改。我还包括了一些已填写的测试和一些未填写的测试。您应该做的是花一些时间让自己熟悉这些更改,以便您可以containers/LOAs/__tests__
自己 中填写其余测试。
尽管我为 LOAs
容器编写了一个集成测试,但我鼓励您为较小的 组件
编写一个单元测试,这样您就可以练习模拟 prop
函数,检查它们是否被调用,并确保组件按预期运行。尽管它是多余的,但它会帮助您理解流程、测试什么以及如何测试(对于单元测试,您需要使用 shallowWrap
而不是 mountWrap
函数——或者不使用它们并使用 enzyme
提供的 shallow
和 mount
函数...由你决定)。
工作示例:https://codesandbox.io/s/p3ro0615nm
变化:
UI
和 state
变化的组件this.setState()
callbacks保持 state
和辅助操作同步。同样重要的是,这也减少了不需要的组件闪烁。filter
、map
和 isEmpty
函数(它们很方便,我更喜欢它们而不是原生 JS 函数)setTimeout
,因为这会影响您的测试)。在 fakeAPI.post
函数中,我添加了一个假密码来检查,因此,提供的密码必须是 12345!methods
以 handle
开头,而向下传递的方法以 on
开头。components/LOAModal/LOAModal.js
分解为更小/可重用的组件,使其更易于阅读PropType
检查以确保 props 在初始声明期间和跨组件时保持一致。注意事项:
enzyme
那样查看DOM
,那么您可以console.log(wrapper.debug());
在你的 it
测试中。beforeEach()
函数中使用 jest.useFakeTimers()
并在 afterEach 中使用 jest.runAllTimers()
()
函数来模拟 setTimeout
函数,而无需等待实时时间过去。Promise
(API 调用)之后包含一个 .catch()
。如果您不捕获
您的 Promise,那么它可能会使您的应用崩溃。关于reactjs - expect(received).toEqual(expected) - 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54518329/
如果数据是从另一台计算机(首先)“发送”的,我如何设置我的套接字例程以“发送”(首先)或(切换)“接收”? 谢谢 通用代码: -(void) TcpClient{ char buffer[12
我正在尝试在代码中使用 Java 8 方法引用。有四种类型的方法引用可用。 静态方法引用。 实例方法(绑定(bind)接收者)。 实例方法(未绑定(bind)接收者)。 构造函数引用。 使用静态方法引
我正在尝试在我的代码中使用 Java 8 方法引用。有四种类型的方法引用可用。 静态方法引用。 实例方法(绑定(bind)接收器)。 实例方法(UnBound 接收器)。 构造函数引用。 使用静态方法
这个问题在这里已经有了答案: X does not implement Y (... method has a pointer receiver) (4 个答案) 关闭 3 年前。 最近在研究Iri
我把这个问题/错误发布到 GIT 官方 channel ,但没有得到任何回应。希望这里有人可以帮助我。 当 receive.denyCurrentBranch 设置为 updateInstead 并且
我正在开发一个新的监控系统,该系统可以测量 Celery 队列吞吐量并在队列备份时帮助提醒团队。在我的工作过程中,我遇到了一些我不理解的奇怪行为(并且在 Celery 规范中没有详细记录)。 出于测试
我正在开发一个新的监控系统,该系统可以测量 Celery 队列吞吐量并在队列备份时帮助提醒团队。在我的工作过程中,我遇到了一些我不理解的奇怪行为(并且在 Celery 规范中没有详细记录)。 出于测试
这个问题在这里已经有了答案: What does this Google Play APK publish error message mean? (17 个答案) 关闭 3 年前。 我为我的应用程
我正在寻找一种解决方案来从我的 child “药物”中获取数据,并使用 ID 从“medication_plan”节点接收特定数据并将它们显示在 Recyclerview 中。 数据库结构: 目前我正
我正在构建 DNN 来预测对象是否存在于图像中。我的网络有两个隐藏层,最后一层看起来像这样: # Output layer W_fc2 = weight_variable([2048, 1])
我有一个模拟销售漏斗的 WF4 服务。它的工作原理是从“注册”接听电话开始。之后,有 10 个类似的阶段(每个阶段包含 2 个接收)。在当前阶段验证接收到的数据之前,您不能前进到一个阶段。但我不确定的
我有一个用 NSubstitute 伪造的对象,它有一个被调用两次的方法。我想验证该方法实际上已被调用两次(且仅调用两次)。我浏览了文档和谷歌,但没有运气。任何帮助,将不胜感激。谢谢。 最佳答案 NS
我在 Windows 上使用 D 编写了一个套接字服务器,现在我想将它移植到 Linux 上。这是代码摘要: /* * this.rawsocks - SocketSet * this.serve
我有一个在 AndroidManifest.xml 中定义了 Receiver 的应用程序,它似乎随机地被禁用,这导致应用程序强制关闭,直到重新安装应用程序。在发生这种情况之前,应用可能会在一天、一周
我正在尝试使用 android 注释库通过两种方式进行广播接收器,但 ide 无法识别此代码中的 @Receiver 或 @ReceiverAction import android.content.
我正在试验 Android 的 LiveData .我只是试图将大量通知推送给观察 LiveData 对象的观察者。我让一个线程在后台运行,在一个 while 循环中,我不断地通过 LiveData
当我运行以下代码时: [Test] public async Task Can_Test_Update() { var response = await _controller.UpdateA
查看 header 时,似乎第二台接收邮件的服务器直到最终 header 中报告的送达日期之后才转发它。 在 c9mailgw11.amadis.com,报告的时间是 22:47:49 -0800
我在这里搜索了几个问题都没有得到答案,所以我会根据我的具体情况询问。 真正简单的接收后 Hook ,它只是 curl 到 Redmine 以强制 Redmine 在提交时更新 repo 的 View
我目前正在尝试 Elixir。我对 Ruby 或函数式编程的经验很少,所以我不太熟悉语法。我在读Learn Elixir in Y minutes其中一个例子让我有点困惑。起初,指南显示了 case
我是一名优秀的程序员,十分优秀!