-
Notifications
You must be signed in to change notification settings - Fork 260
Open
Description
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.
grugknuckle, PragunSaini, sparcs360, baac0, gapa and 16 more
Metadata
Metadata
Assignees
Labels
No labels