Skip to content

How to properly fail factory.create ?Β #273

@silverbucket

Description

@silverbucket

From the documentation it seems that you should not handle exceptions during .createPool() but instead during .aquire(). However if the factory.create() function fails, it continues to retry. I've tried both throwing an exception and rejecting the promise and I'm unable to get any controlled failure path from the operation.

const genericPool = require('generic-pool');
const pool = genericPool.createPool({
  create: () => {
    console.log('create called');
    return new Promise((resolve, reject) => {
      console.log('rejecting promise');
      throw new Error('connection problem');
      //reject('connection problem');
    });
  },
  destroy: () => {
    return new Promise((resolve, reject) => { resolve(); });
  }
}, { max: 2 });

console.log("acquire");
pool.acquire().then((client) => {
  console.log("success");
}, (err) => {
  console.log("controlled failure 1");
}).catch((err) => {
  console.log("controlled failure 2");
});

In the above example, aquire is never reached, and I get an endless loop of 'create called' and 'rejecting promise'. The behaviour is the same if I reject or throw.

...
create called
rejecting promise
create called
rejecting promise
create called
rejecting promise
create called
rejecting promise
^C

How can I reliably handle, for example, connection errors to a database, if the user provides incorrect config? Currently either I get a timeout unhandled exception from the DB library, or a hang/endless loop.

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions