亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

假計時器不會在 Jest 中正確觸發 setTimeout 調用

假計時器不會在 Jest 中正確觸發 setTimeout 調用

暮色呼如 2023-07-06 19:44:29
我有一個簡單的 React UI-less 組件,用于顯示傳遞操作的狀態。有 4 種狀態 - 待處理、正在運行、已完成、失敗。這里的主要問題是運行和完成狀態必須至少持續一段時間(例如 2 秒)。我正在嘗試使用 Jest (26.6.3) 及其假計時器來測試此行為,但我無法讓它工作。組件代碼:export const TaskState = {    PENDING: "pending",    RUNNING: "running",    FINISHED: "finished",    FAILED: "failed",};export default function Task({ action, minDelay = 2000, children }) {    const [state, setState] = useState(TaskState.PENDING);    const [error, setError] = useState(null);    const timeoutHandle = useRef(null);    useEffect(() => {        return () => {            if (timeoutHandle.current) {                clearTimeout(timeoutHandle.current);            }        };    }, []);    const resetState = () => {        setState(TaskState.PENDING);        setError(null);    };    const onSuccess = () => {        setState(TaskState.FINISHED);        timeoutHandle.current = setTimeout(resetState, minDelay);    };    const onError = errMsg => {        setState(TaskState.FAILED);        setError(errMsg);    };    const startAction = () => {        setState(TaskState.RUNNING);        const start = performance.now();        let err = null;        try {            action();        } catch (e) {            err = e.message;        } finally {            const end = performance.now();            const elapsedTime = end - start;            const delayTime = minDelay - elapsedTime;            if (elapsedTime < minDelay && minDelay > 0) {                timeoutHandle.current = setTimeout(() => {                    err ? onError(err) : onSuccess();                }, delayTime);            } else {                err ? onError(err) : onSuccess();            }        }    };    return children({        state,        error,        startAction,    });}Task.propTypes = {    action: PropTypes.func.isRequired,    minDelay: PropTypes.number,    children: PropTypes.func.isRequired,};調用操作回調,執行從掛起到運行的狀態轉換,但不執行從運行到失敗的下一個狀態轉換。當我手動測試它時它有效。最小示例 - https://codesandbox.io/s/heuristic-khorana-7vygv?file=/src/App.js
查看完整描述

1 回答

?
吃雞游戲

TA貢獻1829條經驗 獲得超7個贊

在全局窗口對象上正確調用 setTimeout 解決了該問題。這在實際應用程序中并不重要,但對于專門修補 window.setTimeout 和其他函數的 jest 假定時器來說很重要。



查看完整回答
反對 回復 2023-07-06
  • 1 回答
  • 0 關注
  • 195 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號