1.0.6 • Published 6 years ago

honeydew v1.0.6

Weekly downloads
7
License
GPL-3.0
Repository
github
Last release
6 years ago

Honeydew 🍈

Build Status Coverage Status Known Vulnerabilities

Honeydew is a lightweight helper to monitor & automate promise-returning tasks with NO dependencies.

This utility grew out of frustration with promise queue strategies when executing large numbers of async tasks. Chaining promises requires thorough error handling, or it is easy for errors to cascade with the result that the remainder of your promised tasks are never attempted.

Honeydew is a monitor utility that, rather than queuing the entire workload, looks for a unit of work, executes it, awaits the promise's resolution, rejection, or timeout, and then repeats this process. The intention here is to create a more stable way of executing large numbers of async tasks, that is resilient to promise rejections, timeouts, and can recover smoothly from unexpected stops.

Installation

npm i honeydew

Usage

const { Worker } = require('honeydew');

// findTask parameter is the only required parameter for Worker instantiation
// this will generally be a database query
// to find relevant work to be done
const findTask = () => {
    // this function must return a function (or a promise that resolves to a function)
    return db.Requests.findOne({ status: 'Queued' }).then(request => {
        const task = () => {
            // when this returned function is executed, it must return a promise
            // this is the actual unit of work to be done
            return VendorAPI.post(request).then(res => {
                const response = Object.assign({}, res, {
                    request: request._id
                });
                return db.Responses.create(response);
            });
        };
        return task;
    });
};

// on initialization, the worker will begin to find and run tasks
const worker = new Worker(findTask);

Tests

npm test

To-Do

  • Document with JSDoc
  • Implement parallel execution of multiple tasks up to options.maxTasks
  • Log or return promise rejections and timeouts appropriately according to options.errorHandling

Contributing

In lieu of a formal style guide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code.

1.0.6

6 years ago

1.0.5

6 years ago

1.0.4

6 years ago

1.0.2

6 years ago

1.0.1

6 years ago

1.0.0

6 years ago

0.0.0

7 years ago