1

我正在尝试为编写的简单组件编写单元测试。

这是我的组件:

const ErrorWrpper = (props) =>(
<div className={props.class} style={props.validateForm(props.inputType)?
{display: 'none'}:{}}>
<span>{props.message}</span></div>
)
 export default  ErrorWrpper;

这是我的测试:

import React from 'react';
import { expect } from '../../test_helper';
import { shallow } from 'enzyme';
import { it, describe, beforeEach } from 'mocha';
import  ErrorWrapper  from '../../../src/app/components/login/ErrorWrapper';

let errorWrapper;
describe("ErrorWrapper component unit tests", () => {
 function validateForm(test){

}
before(() => {

    errorWrapper = shallow(<ErrorWrapper class="test"  inputType="all" validateForm={this.validateForm}/>);
});


// these tests check that each className that should exist, exists
describe("className check", () => {
    it('should have className test', () => {
        expect(errorWrapper.find('test')).to.exist;
    });
})
})

现在当我运行它时,我得到了这个:

ErrorWrapper component unit tests "before all" hook:
 TypeError: Cannot read property 'validateForm' of undefined

如您所见,我正在尝试将 validateError 函数作为道具提供,但仍然出现错误。任何想法?

4

2 回答 2

1

目前尚不清楚您为什么要this在测试组件实例化中使用。应该有效:

errorWrapper = shallow(<ErrorWrapper class="test" inputType="all" validateForm={validateForm} />);

此外,您的组件中有一个错字:ErrorWrpperis ErrorWrapper,对吗?您也没有将message道具传递给它。

于 2018-03-01T07:21:00.610 回答
0

看起来你没有this在你的 before all 钩子中得到参考。尝试使用箭头函数来定义您的validateForm函数,以便它会自动将其与this引用绑定,或者您需要validateForm手动绑定函数,如this.validateForm.bind(this).

于 2018-03-01T07:00:57.407 回答