Retry a promise-returning or async function. Abstraction for exponential and custom retry strategies for failed operations
Attributes
Popular
Repository
Current version released
4 years ago
Dependencies
deno.land/x
P(romise) Retried
Retry a promise-returning or async function
Abstraction for exponential and custom retry strategies for failed operations
Usage
import pRetried, { AbortError } from 'https://deno.land/x/p_retried@1.0.0/mod.ts'
async function run () {
const response = await fetch('https://sindresorhus.com/unicorn')
// Abort retrying if the resource doesn't exist
if (response.status === 404) {
throw new AbortError(response.statusText)
}
return response.blob()
}
console.log(await pRetried(run, { retries: 5 }))
API
See https://doc.deno.land/https/deno.land/x/p_retried@1.0.0/lib/mod.ts
Tip
You can pass arguments to the function being retried by wrapping it in an inline arrow function:
import pRetried from 'https://deno.land/x/p_retried@1.0.0/mod.ts'
const run = async emoji => {
// …
}
// Without arguments
await pRetry(run, {
retries: 5
})
// With arguments
await pRetry(() => run('🦄'), {
retries: 5
})
License
P(romise) Retried is licensed under the MIT license. Code is adapted from https://github.com/sindresorhus/p-retry (also under the MIT license)