Merge pull request #531 from brianc/domains

domain aware connection pool
This commit is contained in:
Brian C 2014-03-15 16:49:29 -05:00
commit 84a3f32ce7
4 changed files with 79 additions and 2 deletions

View File

@ -1,3 +1,4 @@
var url = require('url');
var dns = require('dns'); var dns = require('dns');
var path = require('path'); var path = require('path');
@ -17,7 +18,6 @@ var val = function(key, config, envVar) {
defaults[key]; defaults[key];
}; };
var url = require('url');
//parses a connection string //parses a connection string
var parse = function(str) { var parse = function(str) {
var config; var config;

View File

@ -50,9 +50,27 @@ var pools = {
} }
//monkey-patch with connect method //monkey-patch with connect method
pool.connect = function(cb) { pool.connect = function(cb) {
var domain = process.domain;
pool.acquire(function(err, client) { pool.acquire(function(err, client) {
if(domain) {
cb = domain.bind(cb);
domain.add(client);
//native clients do not have a connection object
if(client.connection) {
domain.add(client.connection);
domain.add(client.connection.stream);
}
}
if(err) return cb(err, null, function() {/*NOOP*/}); if(err) return cb(err, null, function() {/*NOOP*/});
cb(null, client, function(err) { cb(null, client, function(err) {
if(domain) {
//native clients do not have a connection object
if(client.connection) {
domain.remove(client.connection.stream);
domain.remove(client.connection);
}
domain.remove(client);
}
if(err) { if(err) {
pool.destroy(client); pool.destroy(client);
} else { } else {

View File

@ -27,7 +27,8 @@
}, },
"devDependencies": { "devDependencies": {
"jshint": "1.1.0", "jshint": "1.1.0",
"semver": "~1.1.4" "semver": "~1.1.4",
"async": "0.2.10"
}, },
"scripts": { "scripts": {
"test": "make test-travis connectionString=postgres://postgres@localhost:5432/postgres", "test": "make test-travis connectionString=postgres://postgres@localhost:5432/postgres",

View File

@ -0,0 +1,58 @@
var helper = require('./test-helper')
var async = require('async')
var testWithoutDomain = function(cb) {
test('no domain', function() {
assert(!process.domain)
helper.pg.connect(helper.config, assert.success(function(client, done) {
assert(!process.domain)
done()
cb()
}))
})
}
var testWithDomain = function(cb) {
test('with domain', function() {
assert(!process.domain)
var domain = require('domain').create()
domain.run(function() {
var startingDomain = process.domain
assert(startingDomain)
helper.pg.connect(helper.config, assert.success(function(client, done) {
assert(process.domain, 'no domain exists in connect callback')
assert.equal(startingDomain, process.domain, 'domain was lost when checking out a client')
var query = client.query('SELECT NOW()', assert.success(function() {
assert(process.domain, 'no domain exists in query callback')
assert.equal(startingDomain, process.domain, 'domain was lost when checking out a client')
done(true)
process.domain.exit()
cb()
}))
}))
})
})
}
var testErrorWithDomain = function(cb) {
test('error on domain', function() {
var domain = require('domain').create()
domain.on('error', function() {
cb()
})
domain.run(function() {
helper.pg.connect(helper.config, assert.success(function(client, done) {
client.query('SELECT SLDKJFLSKDJF')
client.on('drain', done)
}))
})
})
}
async.series([
testWithoutDomain,
testWithDomain,
testErrorWithDomain
], function() {
helper.pg.end()
})