mirror of
https://github.com/brianc/node-postgres.git
synced 2025-12-08 20:16:25 +00:00
* Initial work * Make progress on custom pool * Make all original tests pass * Fix test race * Fix test when DNS is missing * Test more error conditions * Add test for byop * Add BYOP tests for errors * Add test for idle client error expunging * Fix typo * Replace var with const/let * Remove var usage * Fix linting * Work on connection timeout * Work on error condition tests * Remove logging * Add connection timeout * Add idle timeout * Test for returning to client to pool after error fixes #48 * Add idleTimeout support to native client * Add pg as peer dependency fixes #45 * Rename properties * Fix lint * use strict * Add draining to pool.end * Ensure ending pools drain properly * Remove yarn.lock * Remove object-assign * Remove node 8 * Remove closure for waiter construction * Ensure client.connect is never sync * Fix lint * Change to es6 class * Code cleanup & lint fixes
63 lines
1.6 KiB
JavaScript
63 lines
1.6 KiB
JavaScript
'use strict'
|
|
const net = require('net')
|
|
const co = require('co')
|
|
const expect = require('expect.js')
|
|
|
|
const describe = require('mocha').describe
|
|
const it = require('mocha').it
|
|
const before = require('mocha').before
|
|
const after = require('mocha').after
|
|
|
|
const Pool = require('../')
|
|
|
|
describe('connection timeout', () => {
|
|
before((done) => {
|
|
this.server = net.createServer((socket) => {
|
|
})
|
|
|
|
this.server.listen(() => {
|
|
this.port = this.server.address().port
|
|
done()
|
|
})
|
|
})
|
|
|
|
after((done) => {
|
|
this.server.close(done)
|
|
})
|
|
|
|
it('should callback with an error if timeout is passed', (done) => {
|
|
const pool = new Pool({ connectionTimeoutMillis: 10, port: this.port })
|
|
pool.connect((err, client, release) => {
|
|
expect(err).to.be.an(Error)
|
|
expect(err.message).to.contain('timeout')
|
|
expect(client).to.equal(undefined)
|
|
expect(pool.idleCount).to.equal(0)
|
|
done()
|
|
})
|
|
})
|
|
|
|
it('should reject promise with an error if timeout is passed', (done) => {
|
|
const pool = new Pool({ connectionTimeoutMillis: 10, port: this.port })
|
|
pool.connect().catch(err => {
|
|
expect(err).to.be.an(Error)
|
|
expect(err.message).to.contain('timeout')
|
|
expect(pool.idleCount).to.equal(0)
|
|
done()
|
|
})
|
|
})
|
|
|
|
it('should handle multiple timeouts', co.wrap(function * () {
|
|
const errors = []
|
|
const pool = new Pool({ connectionTimeoutMillis: 1, port: this.port })
|
|
for (var i = 0; i < 15; i++) {
|
|
try {
|
|
yield pool.connect()
|
|
} catch (e) {
|
|
errors.push(e)
|
|
}
|
|
}
|
|
expect(errors).to.have.length(15)
|
|
}.bind(this)))
|
|
})
|
|
|