Priority queue based task execution queue.
PriorityQueue based on: https://github.com/janogonzalez/priorityqueuejs
- Async task
- Task timeout terminate
- Custom task generator
- Task execute at priority
- Custom Max Concurrent Execute Task
yarn add priority-worker-runner --save;
import TaskRunner from 'priority-worker-runner';
interface Task {
event: 'timeout' | 'fetch',
payload?: any
}
type TimeRef = {value: number | undefined};
const timeoutTask = (timeRef: TimeRef) => {
return new Promise((resolve) => {
// @ts-ignore
timeRef.value = setTimeout(() => {
resolve('hello world')
}, 1000);
})
}
const runner = new TaskRunner<Task>(({task}) => {
let timeRef: TimeRef = {value: undefined};
const cleanup = () => {
clearTimeout(timeRef.value);
}
const handle = async () => {
const event = task.event;
if (event === 'timeout') {
return await timeoutTask(timeRef);
}
}
return {handle, cleanup}
}, {
concurrentExecuteTaskMax: 5,
timeout: 5,
});
runner.postTask({
event: 'timeout',
}, {
priority: 100,
onResolve: (result) => {
console.log(result);
},
})
runner.postTask({
event: 'timeout',
}, {
priority: 100,
onResolve: (result) => {
console.log(result);
},
})
promiseHandle
:- handle: Task generator function. return
Promise
- cleanup:
function
clean running effect
- handle: Task generator function. return
props
concurrentExecuteTaskMax
:number
. Wait if the task being executed is greater than the maximum concurrency.timeout?
:number
task
: Your custom task. Task will be converted topromise
throughpromiseHandle
function.options
onResolve?
:Function
. Callback function after successful task executiononReject?
:Function
. Callback function after failed task executionpriority
:number
. Task priority, The higher the number, the priority scheduling