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