events.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. 'use strict'
  2. const expect = require('expect.js')
  3. const EventEmitter = require('events').EventEmitter
  4. const describe = require('mocha').describe
  5. const it = require('mocha').it
  6. const Pool = require('../')
  7. describe('events', function () {
  8. it('emits connect before callback', function (done) {
  9. const pool = new Pool()
  10. let emittedClient = false
  11. pool.on('connect', function (client) {
  12. emittedClient = client
  13. })
  14. pool.connect(function (err, client, release) {
  15. if (err) return done(err)
  16. release()
  17. pool.end()
  18. expect(client).to.be(emittedClient)
  19. done()
  20. })
  21. })
  22. it('emits "connect" only with a successful connection', function () {
  23. const pool = new Pool({
  24. // This client will always fail to connect
  25. Client: mockClient({
  26. connect: function (cb) {
  27. process.nextTick(() => {
  28. cb(new Error('bad news'))
  29. })
  30. },
  31. }),
  32. })
  33. pool.on('connect', function () {
  34. throw new Error('should never get here')
  35. })
  36. return pool.connect().catch((e) => expect(e.message).to.equal('bad news'))
  37. })
  38. it('emits acquire every time a client is acquired', function (done) {
  39. const pool = new Pool()
  40. let acquireCount = 0
  41. pool.on('acquire', function (client) {
  42. expect(client).to.be.ok()
  43. acquireCount++
  44. })
  45. for (let i = 0; i < 10; i++) {
  46. pool.connect(function (err, client, release) {
  47. if (err) return done(err)
  48. release()
  49. })
  50. pool.query('SELECT now()')
  51. }
  52. setTimeout(function () {
  53. expect(acquireCount).to.be(20)
  54. pool.end(done)
  55. }, 100)
  56. })
  57. it('emits release every time a client is released', function (done) {
  58. const pool = new Pool()
  59. let releaseCount = 0
  60. pool.on('release', function (err, client) {
  61. expect(err instanceof Error).not.to.be(true)
  62. expect(client).to.be.ok()
  63. releaseCount++
  64. })
  65. const promises = []
  66. for (let i = 0; i < 10; i++) {
  67. pool.connect(function (err, client, release) {
  68. if (err) return done(err)
  69. release()
  70. })
  71. promises.push(pool.query('SELECT now()'))
  72. }
  73. Promise.all(promises).then(() => {
  74. pool.end(() => {
  75. expect(releaseCount).to.be(20)
  76. done()
  77. })
  78. })
  79. })
  80. it('emits release with an error if client is released due to an error', function (done) {
  81. const pool = new Pool()
  82. pool.connect(function (err, client, release) {
  83. expect(err).to.equal(undefined)
  84. const releaseError = new Error('problem')
  85. pool.once('release', function (err, errClient) {
  86. expect(err).to.equal(releaseError)
  87. expect(errClient).to.equal(client)
  88. pool.end(done)
  89. })
  90. release(releaseError)
  91. })
  92. })
  93. it('emits error and client if an idle client in the pool hits an error', function (done) {
  94. const pool = new Pool()
  95. pool.connect(function (err, client) {
  96. expect(err).to.equal(undefined)
  97. client.release()
  98. setImmediate(function () {
  99. client.emit('error', new Error('problem'))
  100. })
  101. pool.once('error', function (err, errClient) {
  102. expect(err.message).to.equal('problem')
  103. expect(errClient).to.equal(client)
  104. done()
  105. })
  106. })
  107. })
  108. })
  109. function mockClient(methods) {
  110. return function () {
  111. const client = new EventEmitter()
  112. Object.assign(client, methods)
  113. return client
  114. }
  115. }