第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

假計時器不會在 Jest 中正確觸發(fā) setTimeout 調(diào)用

假計時器不會在 Jest 中正確觸發(fā) setTimeout 調(diào)用

暮色呼如 2023-07-06 19:44:29
我有一個簡單的 React UI-less 組件,用于顯示傳遞操作的狀態(tài)。有 4 種狀態(tài) - 待處理、正在運行、已完成、失敗。這里的主要問題是運行和完成狀態(tài)必須至少持續(xù)一段時間(例如 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,};調(diào)用操作回調(diào),執(zhí)行從掛起到運行的狀態(tài)轉(zhuǎn)換,但不執(zhí)行從運行到失敗的下一個狀態(tài)轉(zhuǎn)換。當我手動測試它時它有效。最小示例 - https://codesandbox.io/s/heuristic-khorana-7vygv?file=/src/App.js
查看完整描述

1 回答

?
吃雞游戲

TA貢獻1829條經(jīng)驗 獲得超7個贊

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



查看完整回答
反對 回復 2023-07-06
  • 1 回答
  • 0 關(guān)注
  • 203 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號