测试时,React props函数未定义

时间:2018-04-03 10:39:04

标签: javascript reactjs

我正在构建一个处理预算的反应应用程序,我已经为BillContainer组件和AddBill组件编写了代码。

这是我的代码:

BillContainer.js

import React from 'react';
import BillList from './BillList';
import AddBill from './AddBill';

class BillContainer extends React.Component {
  constructor(props) {
    super(props)

    this.state = {
      bills: [
      ]
    }

    this.addBill = this.addBill.bind(this)
  }
  addBill(bill) {
    this.setState((state) => ({
      bills: state.bills.concat([bill])
    }));
  }
  render() {
    return (
      <div>
      <AddBill addNew={this.addBill} />
        <BillList bills={this.state.bills} />
      </div>
    )
  }
}

export default BillContainer;

AddBill.js

import React from 'react';

class AddBill extends React.Component {
  constructor(props) {
    super(props)

    this.state = {
      newBill: ''
    };

    this.updateNewBill = this.updateNewBill.bind(this)
    this.handleAddNew = this.handleAddNew.bind(this)
  }

  updateNewBill(e) {
    this.setState({
      newBill: e.target.value
    })
  }
  handleAddNew(bill) {
    this.props.addNew(this.state.newBill)
    this.setState({
      newBill: ''
    })
  }

  render() {
    return (
      <div>
        <input
          type='text'
          value={this.state.newBill}
          onChange={this.updateNewBill}
        />
        <button onClick={this.handleAddNew}> Add Bill </button>
      </div>
    )
  }
}

export default AddBill;

这是我的 AddBill.test.js 测试:

import React from 'react';
import ReactDOM from 'react-dom';
import Enzyme from 'enzyme';
import { shallow, mount, render } from 'enzyme';
import EnzymeAdapter from 'enzyme-adapter-react-16';
import AddBill from '../components/AddBill';

let Sinon = require('sinon')

Enzyme.configure({adapter: new EnzymeAdapter() });

it('Adds a bill to the list', () => {
  const clickSpy = Sinon.spy(AddBill.prototype, 'handleAddNew');
  const wrapper = shallow(
    <AddBill />
  );
  wrapper.find('button').simulate('click');
  expect(clickSpy.calledOnce).toEqual(true)
})

我试图测试在点击添加帐单按钮时添加新帐单。我已将addBill函数作为prop传递,但测试是抛出错误TypeError: this.props.AddNew is not a function

如何阻止错误消息并使this.props.addNew()未定义?

2 个答案:

答案 0 :(得分:1)

你可以这样使用jest.spyOn

it('Adds a bill to the list', () => {
  const wrapper = shallow(
    <AddBill addNew={() => {}} />
  );
  const clickSpy = jest.spyOn(wrapper.instance(), 'handleAddNew');
  wrapper.find('button').simulate('click');
  expect(clickSpy).toHaveBeenCalledTimes(1);
})

答案 1 :(得分:0)

您没有传递addNew属性:

const wrapper = shallow(
  <AddBill addNew={yourAddNewFunction} />
);