使用酶对选择元素的"onChange"功能进行单元测试



我在 React 中有一个下拉组件,它使用一些选项呈现一个选择元素。这是我的测试的样子:

import React from 'react';
import { shallow, mount } from 'enzyme';
import expect from 'expect';
import Dropdown from './Dropdown';
fdescribe('Dropdown', () => {
it('should trigger onChange', () => {
const handleChange = jasmine.createSpy('handleChange');
const dropdown = mount(
<div>
<Dropdown
options={[
{ key: '', display: 'Please select a value' },
{ key: 'NJ', display: 'New Jersey' },
{ key: 'NY', display: 'New York' },
]}
onChange={handleChange}
/>
</div>,
);
dropdown.find('select').simulate('change', { target: { value: 'New Jersey' } });
expect(handleChange).toHaveBeenCalled();
});
});

我在控制台中收到以下错误:The "actual" argument in expect(actual).toHaveBeenCalled() must be a spy

关于如何在下拉列表中测试onchange()的任何想法?谢谢!

下面的语法帮助我测试了选择元素的值。

it('should trigger onChange', () => {
const dropdown = mount(<App />);
dropdown.find("select").simulate("change",{target: { value : "New Jersey"}});
expect(dropdown.find("select").props().value).toBe("New Jersey");
});

最新更新