React-用Jest测试

一、

1.目录结构

二、代码

1.CheckboxWithLabel.jsx

 1 var React = require('react/addons');
 2 var CheckboxWithLabel = React.createClass({
 3     getInitialState: function() {
 4         return {
 5             isChecked: false
 6         };
 7     },
 8     onChange: function() {
 9         this.setState({
10             isChecked: !this.state.isChecked
11         });
12     },
13     render: function() {
14         return ( < label > < input type = "checkbox"
15             checked = {
16                 this.state.isChecked
17             }
18             onChange = {
19                 this.onChange
20             }
21             /> {this.state.isChecked ? this.props.labelOn : this.props.labelOff} </label > );
22     }
23 });
24 
25 module.exports = CheckboxWithLabel;

2.__test__/checkboxwithlabel.js

 1 var jest = require('jest');
 2 
 3 jest.dontMock('../CheckboxWithLabel.js');
 4 describe('CheckboxWithLabel', function() {
 5     it('changes the text after click', function() {
 6         var React = require('react/addons');
 7         var CheckboxWithLabel = require('../CheckboxWithLabel.js');
 8         var TestUtils = React.addons.TestUtils;
 9         var checkbox = TestUtils.renderIntoDocument( < CheckboxWithLabel labelOn = "On"
10             labelOff = "Off" / > );
11         var label = TestUtils.findRenderedDOMComponentWithTag(checkbox, 'label');
12         expect(label.getDOMNode().textContent).toEqual('Off');
13         var input = TestUtils.findRenderedDOMComponentWithTag(checkbox, 'input');
14         TestUtils.Simulate.change(input);
15         expect(label.getDOMNode().textContent).toEqual('On');
16     });
17 });

 

转载于:https://www.cnblogs.com/shamgod/p/5065145.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值