Skip to content
/ miniq Public

A minimal in-process queue system for TypeScript/JavaScript that supports TTL mechanism.

License

Notifications You must be signed in to change notification settings

moznion/miniq

Repository files navigation

miniq .github/workflows/check.yml codecov npm version

A minimal in-process queue system for TypeScript/JavaScript that supports TTL mechanism.

Synopsis

let i = 0;
const queueTaskRunner = new QueueTaskRunner<number>();

const task1 = await Task.make<number>(async (): Promise<number> => {
  return new Promise<number>(resolve => {
    setTimeout(() => {
      resolve(++i);
    }, 500);
  });
});
const task2 = await Task.make<number>(async (): Promise<number> => {
  return new Promise<number>(resolve => {
    resolve(++i);
  });
});
const task3 = await Task.make<number>(async (): Promise<number> => {
  return new Promise<number>(resolve => {
    resolve(++i);
  });
});

queueTaskRunner.enqueue(task1); // runner runs task1, and the task takes 500ms
queueTaskRunner.enqueue(task2); // runner queues task2 and defer it after task1
queueTaskRunner.enqueue(task3); // runner queues task3 and defer it after task2

console.log(await task1.getResult()); // => 1
console.log(await task2.getResult()); // => 2
console.log(await task3.getResult()); // => 3

Description

QueueTaskRunner#enqueue(task: Task<T>) receives a task and appends that task to the queue and runs the tasks in a queue from the beginning of the queue.

Task<T> represents the task that you wanted to do according to the FIFO, and the task runner executes the enqueued task's async do(): Promise<void>. The point is this do() returns the Promise<void> so the client code cannot get the result of the actual procedure, but you can use async Task#getResult(): Promise<T> to take that. So the basic usage should be enqueuing a task and waiting for the result by await getResult() for the task.

Please see also typedoc.

TTL

You can give a task the TTL like:

const task = await Task.make<string>(async (): Promise<string> => {
  return 'foo';
}, Date.now() + 60000);
// ~~~~~~~~~~~~~~~~~~ TTL that represents 60 secs from now

...

await task.getResult(); // if the TTL has exceeded, it rejects this task and throws `TaskTTLExceededError`.

And a task that has the TTL has been enqueued and when the task runner takes the task to run, if the TTL exceeds the current timestamp at that moment, it doesn't run that task and it rejects the task with TaskTTLExceededError.

LISENCE

MIT

About

A minimal in-process queue system for TypeScript/JavaScript that supports TTL mechanism.

Resources

License

Stars

Watchers

Forks

Packages

No packages published