После того, как пользователь щелкнет логин, мне нужно проверять статус сервера каждые 3 секунды. После проверки 20 раз отобразите тайм-аут и сбросьте таймер.
мой код:
onCheckStatus = () => {
MAX_POLLING_COUNT = 20;
this.timer = setInterval(() => {
if (MAX_POLLING_COUNT > 0) {
MAX_POLLING_COUNT -= 1;
loginStatus(this.state.sessionId).then(
res => {
const { goto, sessionId, errorMessageCode, result, hint } = res;
........
if (goto === 'SUCCESS') {
this.setState({
messageInfo: {
type: 'success',
title: '',
description: result.description,
},
});
} else if (goto === 'ERROR') {
}
},
() => {
clearInterval(this.timer);
this.setState({ error: true, loading: false });
}
);
} else {
this.setState({ error: true, loading: false });
}
}, 3000);
};
тестовый код:
jest.useFakeTimers();
const wrapper = shallow(
<AddGPForm step = "GP_SIGNIN" uuid = "testuuid" {...props} />
);
const form = shallow(wrapper.prop('children')(getMockFormApi(wrapper)));
form.find('Login').simulate('submit', {
reqestBody: '10x010101x0101x0101x10x0',
});
jest.runAllTimer();
// jest.runTimersToTime(60000);
// jest.runOnlyPendingTimers();
onCheckStatus будет срабатывать, коды внутри таймера никогда не срабатывают. Я попытался выбрать логику внутри таймера как один единственный метод.
новый код:
onCheckStatus = () => {
this.timer = setInterval(this.check(), 3000);
}
метод проверки запускается только один раз.



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Используйте jest.runAllTimers() вместо jest.runAllTicks()
Используйте jest.advanceTimersByTime, чтобы продвинуть свой таймер и проверить в своем тестовом файле.
это опечатка. Я перепробовал все api-макеты таймера шутки, все они не работают.