【发布时间】:2019-09-11 06:38:27
【问题描述】:
我正在测试一个使用setTimeout 的react 组件。 问题是 Jest 说 setTimeout 被调用,即使它显然不是。有一个 setTimeout 可以从 ui 中删除某些内容,另一个可以暂停计时器鼠标悬停在组件上。
我尝试在setTimeout 所在的位置添加console.log(),并且从不调用控制台日志,这意味着未调用应用程序中的setTimeout。
//app
const App = (props) => {
const [show, setShow] = useState(true);
const date = useRef(Date.now());
const remaining = useRef(props.duration);
let timeout;
useEffect(() => {
console.log('Should not run');
if (props.duration) {
timeout = setTimeout(() => {
setShow(false)
}, props.duration);
}
}, [props.duration]);
const pause = () => {
remaining.current -= Date.now() - date.current;
clearTimeout(timeout);
}
const play = () => {
date.current = Date.now();
clearTimeout(timeout);
console.log('should not run');
timeout = setTimeout(() => {
setIn(false);
}, remaining.current);
}
return (
<div onMouseOver={pause} onMouseLeave={play}>
{ show &&
props.content
}
</div>
)
}
//test
it('Should not setTimeout when duration is false', () => {
render(<Toast content="" duration={false} />);
//setTimeout is called once but does not come from App
expect(setTimeout).toHaveBeenCalledTimes(0);
});
it('Should pause the timer when pauseOnHover is true', () => {
const { container } = render(<Toast content="" pauseOnHover={true} />);
fireEvent.mouseOver(container.firstChild);
expect(clearTimeout).toHaveBeenCalledTimes(1);
fireEvent.mouseLeave(container.firstChild);
//setTimeout is called 3 times but does not come from App
expect(setTimeout).toHaveBeenCalledTimes(1);
});
所以在第一个测试中,setTimeout 不应该被调用,但我收到它调用一次。在第二个测试中,setTimeout 应该被调用一次,但被调用了 3 次。 该应用程序运行良好我只是不明白jest 发生了什么,这表明setTimeout 被调用的次数超过是的。
【问题讨论】:
-
这里还有解决方案吗?...
标签: reactjs unit-testing timer jestjs react-hooks