Ich versuche eine Timer-Komponente zu erstellen, die es Kindern ermöglicht, einen Timer zu starten, und ihnen dann angibt, wie viel Zeit in 1-Sekunden-Intervallen verbleibt.Jest: fake setInterval funktioniert nicht wie erwartet
Ich habe den folgenden Test:
/* Test */
jest.useFakeTimers()
it.only('should update the reamining time every second',() => {
const time = 1/12
const wrapper = shallow(<Timer time={time} />)
wrapper.find('.start').simulate('click')
jest.runAllTimers()
expect(setInterval.mock.calls.length).toBe(4)
})
/* Code */
updateTimeLeft() {
const now: number = +new Date()
const timeLeft = this.state.endTime - now
if (timeLeft < 0) {
clearInterval(this.state.timeInterval)
}
this.setState({ timeLeft })
}
intializeTimer(minutes: number) {
const startTime: number = new Date().getTime()
const endTime: number = new Date(startTime + minutes * 60 * 1000).getTime()
this.setState({
startTime,
endTime
})
const timeInterval: NodeJS.Timer = global.setInterval(
() => this.updateTimeLeft(),
1000
)
this.setState({ timeInterval })
}
Der Code funktioniert. Das Problem ist, im Test, setInteval.mock.calls.length = 1
, egal was.
Gibt es irgendetwas, was ich über Jest Fake Timer missverstanden habe?
Vielen Dank ❤️