Не удалось найти способ имитации щелчка элемента, существующего в дочернем компоненте, из родительского тестового файла.
let card;
const displayCardSection = (cardName) => {
card = cardName;
};
describe('Parent component', () => {
it('simulate click event on child link', () => {
const component = mount(<Parent
/>);
const res = component.find(<Child
onLinkClick={displayCardSection(CM_CARD)}
/>);
expect(res).toBeDefined();
res.exists('#cm_link').simulate('click');
expect(card).toBe(CM_CARD);
})
})
Это тестовый файл родительского компонента.
Parent.jsx:
class Parent extends Component {
handleClick = () => {
console.log('link clicked!');
};
render() {
const linkText = 'Link'
return (
<Child
linkText={linkText}
onLinkClick={handleClick}
/>
);
}
}
Child.jsx:
function Child({linkText, onLinkClick}) {
return (
<Link id="cm_link" onClick={onLinkClick}>{linkText}</Link>
);
}
Это компоненты, которые у меня есть.
Я ожидаю смоделировать щелчок по ссылкедочерний компонент от родительского, и на выходе должна быть отображаемая карта 'CM_CARD'. Я могу написать утверждение assert, но я не должен имитировать событие click элемента, который существует в child, но событие обрабатывается в самом parent.