From 8bed670aee111a92dc010b8e661778c6c815a241 Mon Sep 17 00:00:00 2001 From: Charmander <~@charmander.me> Date: Thu, 5 Nov 2020 16:07:49 -0800 Subject: [PATCH] Add more error handling to error handling tests --- .../client/error-handling-tests.js | 39 ++++++++++++------- packages/pg/test/test-helper.js | 9 +++++ 2 files changed, 35 insertions(+), 13 deletions(-) diff --git a/packages/pg/test/integration/client/error-handling-tests.js b/packages/pg/test/integration/client/error-handling-tests.js index 93959e02b..88e6d39f7 100644 --- a/packages/pg/test/integration/client/error-handling-tests.js +++ b/packages/pg/test/integration/client/error-handling-tests.js @@ -19,7 +19,10 @@ const suite = new helper.Suite('error handling') suite.test('sending non-array argument as values causes an error callback', (done) => { const client = new Client() - client.connect(() => { + client.connect((err) => { + if (err) { + return done(err) + } client.query('select $1::text as name', 'foo', (err) => { assert(err instanceof Error) client.query('SELECT $1::text as name', ['foo'], (err, res) => { @@ -32,7 +35,10 @@ suite.test('sending non-array argument as values causes an error callback', (don suite.test('re-using connections results in error callback', (done) => { const client = new Client() - client.connect(() => { + client.connect((err) => { + if (err) { + return done(err) + } client.connect((err) => { assert(err instanceof Error) client.end(done) @@ -40,19 +46,22 @@ suite.test('re-using connections results in error callback', (done) => { }) }) -suite.test('re-using connections results in promise rejection', (done) => { +suite.testAsync('re-using connections results in promise rejection', () => { const client = new Client() - client.connect().then(() => { - client.connect().catch((err) => { + return client.connect().then(() => { + return helper.rejection(client.connect()).then((err) => { assert(err instanceof Error) - client.end().then(done) + return client.end() }) }) }) suite.test('using a client after closing it results in error', (done) => { const client = new Client() - client.connect(() => { + client.connect((err) => { + if (err) { + return done(err) + } client.end( assert.calls(() => { client.query( @@ -227,12 +236,16 @@ suite.test('connected, idle client error', (done) => { suite.test('cannot pass non-string values to query as text', (done) => { const client = new Client() - client.connect() - client.query({ text: {} }, (err) => { - assert(err) - client.query({}, (err) => { - client.on('drain', () => { - client.end(done) + client.connect((err) => { + if (err) { + return done(err) + } + client.query({ text: {} }, (err) => { + assert(err) + client.query({}, (err) => { + client.on('drain', () => { + client.end(done) + }) }) }) }) diff --git a/packages/pg/test/test-helper.js b/packages/pg/test/test-helper.js index 4ca9da1b3..319b8ee79 100644 --- a/packages/pg/test/test-helper.js +++ b/packages/pg/test/test-helper.js @@ -232,6 +232,14 @@ var resetTimezoneOffset = function () { Date.prototype.getTimezoneOffset = getTimezoneOffset } +const rejection = (promise) => + promise.then( + (value) => { + throw new Error(`Promise resolved when rejection was expected; value: ${sys.inspect(value)}`) + }, + (error) => error + ) + module.exports = { Sink: Sink, Suite: Suite, @@ -242,4 +250,5 @@ module.exports = { Client: Client, setTimezoneOffset: setTimezoneOffset, resetTimezoneOffset: resetTimezoneOffset, + rejection: rejection, }