-
Notifications
You must be signed in to change notification settings - Fork 42
Expand file tree
/
Copy pathtest-pool-specific.js
More file actions
103 lines (84 loc) · 2.74 KB
/
test-pool-specific.js
File metadata and controls
103 lines (84 loc) · 2.74 KB
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
const sql = require('./lib/sql')
const { TestEnv } = require('./test/env/test-env')
const env = new TestEnv()
async function testPoolErrorQueries() {
console.log('Starting test...')
try {
await env.open()
console.log('Test environment opened')
const size = 4
const iterations = 4
const pool = env.pool(size)
const checkin = []
const checkout = []
const errors = []
pool.on('error', e => {
console.log('Pool error:', e.message)
errors.push(e)
})
pool.on('debug', s => {
console.log('Pool debug:', s)
})
pool.open()
await new Promise((resolve, reject) => {
pool.on('open', () => {
console.log('Pool opened')
pool.on('status', s => {
console.log('Pool status:', s)
switch (s.op) {
case 'checkout':
checkout.push(s)
break
case 'checkin':
checkin.push(s)
break
}
})
let done = 0
let free = 0
let submissions = 0
function submit(sql, index) {
console.log(`Submitting query ${index}: ${sql}`)
const q = pool.query(sql, (e, result, more) => {
console.log(`Query ${index} callback called - error:`, e?.message, 'result:', !!result, 'more:', more)
if (e) errors.push(e)
})
q.on('submitted', () => {
++submissions
console.log(`Query submitted: ${submissions}`)
})
q.on('done', () => {
++done
console.log(`Query done: ${done}`)
})
q.on('free', () => {
++free
console.log(`Query free: ${free}`)
if (free === iterations) {
console.log('All queries freed, closing pool...')
pool.close(() => {
console.log(`Test complete: errors=${errors.length}, checkin=${checkin.length}, checkout=${checkout.length}`)
if (errors.length === iterations && checkin.length === iterations && checkout.length === iterations) {
resolve()
} else {
reject(new Error(`Expected ${iterations} of each, got errors=${errors.length}, checkin=${checkin.length}, checkout=${checkout.length}`))
}
})
}
})
return q
}
const testSql = 'select a;'
for (let i = 0; i < iterations; ++i) {
submit(testSql, i)
}
})
})
console.log('Test passed!')
await env.close()
} catch (err) {
console.error('Test failed:', err)
process.exit(1)
}
}
testPoolErrorQueries()