gpt4 book ai didi

javascript - 带有 preventDefault 的 React/Unit Test (Jest) 单击方法

转载 作者:行者123 更新时间:2023-11-30 19:18:55 25 4
gpt4 key购买 nike

所以我遇到了一个让我难过的小问题......

我有一个 Link 组件,如果满足特定条件,它将通过 to 属性转到特定路径。如果不满足该条件,则单击该链接时会执行其他操作(在我的示例中启动自定义模式)。

我有一个类方法绑定(bind)到我的 Link 组件上的 onClick 处理程序

// Card.jsx

import Link from 'components/Link';

...

static props = {
condition: PropTypes.bool
};

constructor(props) {
this.state = {
showModal: false
};
}

...

goToUrlOrLaunchModal() {
return (
<Link
to="www.google.com"
onClick={this.handleClick}
/>
);
}


...


handleClick(e) {
const { condition } = this.props;

if (!condition) {
e.preventDefault();

this.setState({
showModal: true
});
}
}

我的问题是单元测试。当 conditionfalse

时,我有一个点击链接的单元测试
// Card.test.js

...

import renderer from 'react-test-renderer';

...

const event = {
preventDefault: jest.fn()
};

const component = renderer.create(<Card>).getInstance();

instance.handleClick(event);
expect(event.preventDefault).toHaveBeenCalled();
expect(instance.state.showModal).toBe(true);

我迷路的地方是测试另一端 - 当 conditiontrue 时,我不需要调用 preventDefault 或执行任何之后的逻辑。我不需要 handleClick 中的任何内容来触发。 handleClick 中的唯一逻辑是当 condition 为 false 时。

点击Link组件时跳转到路由的逻辑没问题,只是conditiontrue时的单元测试。

我需要测试 preventDefault 没有被调用,并且 instance.state.showModaltrue,但我是难倒。这是我一直认为必须的,但无法超越它...

const event = {
preventDefault: jest.fn()
};

expect(instance.handleManageClick).not.toHaveBeenCalled();
expect(event.preventDefault).not.toHaveBeenCalled();
expect(instance.state.showModal).toBe(false);

如有高人指点,不胜感激!谢谢!

最佳答案

我得到了答案,感谢Andrew的帮助谁对最初的帖子发表了评论。

这是我做的:

// Card.test.js

const event = {
preventDefault: jest.fn()
};

const component = renderer.create(<Card>).getInstance();

const spy = jest.spyOn(instance, 'handleManageClick');

expect(spy).not.toHaveBeenCalled();
expect(event.preventDefault).not.toHaveBeenCalled();
expect(instance.state.showModal).toBe(false);

感谢您的帮助!

关于javascript - 带有 preventDefault 的 React/Unit Test (Jest) 单击方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57696294/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com