tdd – 单元测试反应原生的触摸事件

前端之家收集整理的这篇文章主要介绍了tdd – 单元测试反应原生的触摸事件前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试使用 this指南测试驱动器反应本机代码. reactjs覆盖react native,以使用jestjs进行浅层渲染和测试.

即使我能够测试浅层渲染组件(检查其存在和子项),我也无法测试触摸事件.

handleTouch() {
 this.setState({ showDescription: !this.state.showDescription });
}


render() {
const description = this.state.showDescription ? (<Text style={styles.description}>{this.props.entry.description}</Text>) : null;
return (
  <TouchableNativeFeedback onPress={() => this.handleTouch()}>
    <View style={styles.rowContainer}>
      <View style={styles.row}>
      </View>
      {description}
    </View>
  </TouchableNativeFeedback>
 )
}

我正在尝试测试触摸TouchableNativeFeedback,是否呈现了描述标记. reactjs TestUtils提供模拟,但它不起作用.

这是我的规格设置:

beforeEach(function() {
    profileView = TestUtils.renderIntoDocument(<ProfileEntryView entry={entry}/>);
    var touchableNativeFeedback = TestUtils.findRenderedComponentWithType(profileView,TouchableNativeFeedback);
    TestUtils.Simulate.onTouchEnd(touchableNativeFeedback);
});

我如何使用reactjs TestUtils测试用户反应原生的UI交互?

因为ReactTestUtils模拟没有onTouchEnd或onPress事件.所以你需要添加模拟对象mocks / react-native.js:
const NativeComponent = (type) => {
    return React.createClass({
        render() {
            var properties = {className: type};
            if (typeof this.props.onPress !== 'undefined') {
                properties.onClick = this.props.onPress;
            }
            Object.assign(properties,this.props);
            return (
                <div {...properties}>{this.props.children}</div>
            );
      }
};
...
ReactNative.TouchableNativeFeedback = NativeComponent("TouchableNativeFeedback");

并将您的测试代码更新为:

var touchableNativeFeedback = TestUtils.findRenderedDOMComponentWithClass(profileView,'TouchableNativeFeedback');
TestUtils.Simulate.click(touchableNativeFeedback);

正在寻找更多的代码from this page.

猜你在找的设计模式相关文章