У меня проблемы с тестированием моего (устаревшего) компонента с помощью jest / энзима. Это выглядит так:
export default class MyComponent extends Component {
constructor( props ) {
super( props );
this.handleSelect = this.handleSelect.bind( this );
}
handleSelect( event ) {
const { name, value } = event.target;
this.props[ name ]( value );
}
render() {
return (
<label>
Dropdown 1{ ' ' }
<select
name="dropdown1"
value={ status }
data-testid="dropdown-1"
onChange={ this.handleSelect }
>
<option value="">Any</option>
<option value="item1">Item 1</option>
<option value="item2">Item 2</option>
<option value="item3">Item 3</option>
</select>
</label>
);
}
}
Методы передаются как реквизиты! В этом случае при изменении значения будет вызываться handleSelect
и вызывается this.props['dropdown1'](value)
.
И мой тест выглядит так:
import React from 'react';
import { shallow } from 'enzyme';
test( 'select an item from the dropdown', () => {
const status = wrapper.find( 'select[data-testid="dropdown-1"]' );
status.simulate( 'change', { target: { value: 'item1' } } );
expect(status.prop('value')).toEqual('item1');
} );
Он отображает следующую ошибку:
TypeError: this.props[name] is not a function
Зависимости в package.json
:
"devDependencies": {
...
"enzyme-to-json": "^3.4.0",
"jest": "^24.9.0",
"react": "^16.9.0",
"react-dom": "^16.9.0",
Кто-нибудь может мне с этим помочь?