race-cancellation
Version:
Utilities for using Promise.race([task, cancellation]) for async/await code.
32 lines • 1.27 kB
JavaScript
import withDisposableCancel from "./withCancel.js";
/**
* Wrap a cancellable async function with a timeout.
*
* @remarks
*
* @example
* ```js
* async function fetchWithTimeout(url, timeoutMs, raceCancel) {
* return await withTimeout((raceTimeout) => cancellableFetch(url, raceTimeout), timeoutMs, raceCancel);
* }
* ```
*
* @param cancellableAsync - a {@link CancellableAsyncFn} function
* @param milliseconds - a timeout in miliseconds
* @param raceCancel - an optional outer scope {@link RaceCancelFn} function that will be combined with the timeout race before being passed to the {@link CancellableAsyncFn} function
* @public
*/
export default function withTimeout(cancellableAsync, milliseconds, raceCancel) {
return withDisposableCancel(cancellableAsync, (resolve) => {
const id = setTimeout(() => resolve(newTimeoutError(milliseconds)), milliseconds);
return () => clearTimeout(id);
}, raceCancel);
}
function newTimeoutError(milliseconds) {
const timeoutError = new Error(`The operation timed out after taking longer than ${milliseconds}ms`);
timeoutError.name = "TimeoutError";
timeoutError.isCancelled = true;
timeoutError.isTimeout = true;
return timeoutError;
}
//# sourceMappingURL=withTimeout.js.map