|
| 1 | +var helper = require(__dirname + '/test-helper'); |
| 2 | +var util = require('util'); |
| 3 | + |
| 4 | +function killIdleQuery(targetQuery) { |
| 5 | + var client2 = new Client(helper.args); |
| 6 | + var pidColName = 'procpid' |
| 7 | + var queryColName = 'current_query'; |
| 8 | + client2.connect(assert.success(function() { |
| 9 | + helper.versionGTE(client2, '9.2.0', assert.success(function(isGreater) { |
| 10 | + if(isGreater) { |
| 11 | + pidColName = 'pid'; |
| 12 | + queryColName = 'query'; |
| 13 | + } |
| 14 | + var killIdleQuery = "SELECT " + pidColName + ", (SELECT pg_terminate_backend(" + pidColName + ")) AS killed FROM pg_stat_activity WHERE " + queryColName + " = $1"; |
| 15 | + client2.query(killIdleQuery, [targetQuery], assert.calls(function(err, res) { |
| 16 | + assert.ifError(err); |
| 17 | + assert.equal(res.rows.length, 1); |
| 18 | + client2.end(); |
| 19 | + assert.emits(client2, 'end'); |
| 20 | + })); |
| 21 | + })); |
| 22 | + })); |
| 23 | +} |
| 24 | + |
| 25 | +test('query killed during query execution of prepared statement', function() { |
| 26 | + if(helper.args.native) { |
| 27 | + return false; |
| 28 | + } |
| 29 | + var client = new Client(helper.args); |
| 30 | + client.connect(assert.success(function() { |
| 31 | + var sleepQuery = 'select pg_sleep($1)'; |
| 32 | + var query1 = client.query({ |
| 33 | + name: 'sleep query', |
| 34 | + text: sleepQuery, |
| 35 | + values: [5] }, |
| 36 | + assert.calls(function(err, result) { |
| 37 | + assert.equal(err.message, 'terminating connection due to administrator command'); |
| 38 | + })); |
| 39 | + |
| 40 | + query1.on('error', function(err) { |
| 41 | + assert.fail('Prepared statement should not emit error'); |
| 42 | + }); |
| 43 | + |
| 44 | + query1.on('row', function(row) { |
| 45 | + assert.fail('Prepared statement should not emit row'); |
| 46 | + }); |
| 47 | + |
| 48 | + query1.on('end', function(err) { |
| 49 | + assert.fail('Prepared statement when executed should not return before being killed'); |
| 50 | + }); |
| 51 | + |
| 52 | + killIdleQuery(sleepQuery); |
| 53 | + })); |
| 54 | +}); |
| 55 | + |
| 56 | + |
| 57 | +test('client end during query execution of prepared statement', function() { |
| 58 | + var client = new Client(helper.args); |
| 59 | + client.connect(assert.success(function() { |
| 60 | + var sleepQuery = 'select pg_sleep($1)'; |
| 61 | + var query1 = client.query({ |
| 62 | + name: 'sleep query', |
| 63 | + text: sleepQuery, |
| 64 | + values: [5] }, |
| 65 | + assert.calls(function(err, result) { |
| 66 | + assert.equal(err.message, 'Connection was ended during query'); |
| 67 | + })); |
| 68 | + |
| 69 | + query1.on('error', function(err) { |
| 70 | + assert.fail('Prepared statement should not emit error'); |
| 71 | + }); |
| 72 | + |
| 73 | + query1.on('row', function(row) { |
| 74 | + assert.fail('Prepared statement should not emit row'); |
| 75 | + }); |
| 76 | + |
| 77 | + query1.on('end', function(err) { |
| 78 | + assert.fail('Prepared statement when executed should not return before being killed'); |
| 79 | + }); |
| 80 | + |
| 81 | + client.end(); |
| 82 | + })); |
| 83 | +}); |
0 commit comments