From 8471bda44fc030205abec45b1581b2cf6ed7c800 Mon Sep 17 00:00:00 2001 From: Bob den Os <108393871+BobdenOs@users.noreply.github.com> Date: Wed, 15 Nov 2023 14:20:58 +0100 Subject: [PATCH] fix: Disconnect db service on shutdown (#327) Co-authored-by: Patrice Bender --- db-service/lib/common/DatabaseService.js | 25 ++++++++++++++++++------ 1 file changed, 19 insertions(+), 6 deletions(-) diff --git a/db-service/lib/common/DatabaseService.js b/db-service/lib/common/DatabaseService.js index 94abf8935..96e32bff2 100644 --- a/db-service/lib/common/DatabaseService.js +++ b/db-service/lib/common/DatabaseService.js @@ -6,10 +6,16 @@ const cds = require('@sap/cds/lib') /** @typedef {unknown} DatabaseDriver */ class DatabaseService extends cds.Service { + + init() { + cds.on('shutdown', () => this.disconnect()) + return super.init() + } + /** * Dictionary of connection pools per tenant */ - pools = { _factory: this.factory } + pools = Object.setPrototypeOf({}, { _factory: this.factory }) /** * Return a pool factory + options property as expected by @@ -111,11 +117,18 @@ class DatabaseService extends cds.Service { * @param {string} tenant */ async disconnect(tenant) { - const pool = this.pools[tenant] - if (!pool) return - await pool.drain() - await pool.clear() - delete this.pools[tenant] + const _disconnect = async tenant => { + const pool = this.pools[tenant] + if (!pool) { + return + } + await pool.drain() + await pool.clear() + delete this.pools[tenant] + } + if (tenant == null) + return Promise.all(Object.keys(this.pools).map(_disconnect)) + return _disconnect(tenant) } /**