From da2fb46c5ad827cfe6f4eae74e7a2daf9960cac4 Mon Sep 17 00:00:00 2001 From: Balte de Wit Date: Mon, 4 Dec 2023 13:09:50 +0100 Subject: [PATCH 1/2] feat: fetch versions of external components --- src/controllers/serverVersions.ts | 7 +++++++ src/lib/lib.ts | 26 ++++++++++++++++++++++++++ 2 files changed, 33 insertions(+) diff --git a/src/controllers/serverVersions.ts b/src/controllers/serverVersions.ts index 920bf80..7110b2d 100644 --- a/src/controllers/serverVersions.ts +++ b/src/controllers/serverVersions.ts @@ -23,6 +23,13 @@ function compileVersions(component: any, prefix = ''): Versions { Object.keys(compiledVersions).forEach((key) => (versions[key] = compiledVersions[key])) }) } + if (component._extVersions) { + component._extVersions.forEach((child: PromiseSettledResult) => { + if (child.status === 'rejected' || child.value.error) return + const compiledVersions = compileVersions(child.value, '~' + child.value.name + '.') + Object.keys(compiledVersions).forEach((key) => (versions[key] = compiledVersions[key])) + }) + } return versions } diff --git a/src/lib/lib.ts b/src/lib/lib.ts index 1e77b7d..3140adc 100644 --- a/src/lib/lib.ts +++ b/src/lib/lib.ts @@ -3,6 +3,7 @@ import fetch from 'node-fetch' import { URL, URLSearchParams } from 'url' const HEALTH_PATH = 'health' +const EXT_VERSIONS = ['external/sisyfos/health'] export async function getServerHealth(serverHost: string): Promise { if (serverHost !== '') { @@ -26,6 +27,30 @@ export async function getServerHealth(serverHost: string): Promise { } } +export async function getExternalVersions(serverHost: string): Promise[]> { + const result: any[] = [] + if (serverHost !== '') { + const serverLocation = /^https?:\/\//.test(serverHost) ? new URL(serverHost) : new URL(`http://${serverHost}`) + + return Promise.allSettled( + EXT_VERSIONS.map(async (extUrl) => { + const url = `${serverLocation.href}${extUrl}` + + try { + const response = await fetch(url, { method: 'GET' }) + return await response.json() + } catch (error) { + return { + error: new Error(`Unable to fetch resource ${url}: ${error}`), + } + } + }) + ) + } + + return result +} + /** * Accepts a list of server hosts and returns the responses from a query to * each server's /health service. @@ -41,6 +66,7 @@ export async function getServerData(serverHosts: Array): Promise { const serverHealth = await getServerHealth(host) + serverHealth._extVersions = await getExternalVersions(host) serverHealth._host = host return serverHealth }) From f0033e3a2ae2d5ddcca3de385d10c78f9f38fd27 Mon Sep 17 00:00:00 2001 From: Balte de Wit Date: Wed, 6 Dec 2023 11:53:54 +0100 Subject: [PATCH 2/2] chore: update unit tests --- test/serverStatus.test.ts | 7 +++++-- test/serverVersions.test.ts | 7 +++++-- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/test/serverStatus.test.ts b/test/serverStatus.test.ts index 4e57dcc..0e9c63e 100644 --- a/test/serverStatus.test.ts +++ b/test/serverStatus.test.ts @@ -31,8 +31,11 @@ describe('GET /serverStatus', () => { expect(dom.window.document.characterSet).toEqual('UTF-8') dom.window.document.getElementById('versions') - expect(fetch).toHaveBeenCalledTimes(1) - expect(fetch).toHaveBeenCalledWith('http://localhost:3000/health', { + expect(fetch).toHaveBeenCalledTimes(2) + expect(fetch).toHaveBeenNthCalledWith(1, 'http://localhost:3000/health', { + method: 'GET', + }) + expect(fetch).toHaveBeenNthCalledWith(2, 'http://localhost:3000/external/sisyfos/health', { method: 'GET', }) }) diff --git a/test/serverVersions.test.ts b/test/serverVersions.test.ts index c7e1d3e..ead314d 100644 --- a/test/serverVersions.test.ts +++ b/test/serverVersions.test.ts @@ -32,8 +32,11 @@ describe('GET /serverVersions', () => { expect(dom.window.document.characterSet).toEqual('UTF-8') dom.window.document.getElementById('versions') - expect(fetch).toHaveBeenCalledTimes(1) - expect(fetch).toHaveBeenCalledWith('http://localhost:3000/health', { + expect(fetch).toHaveBeenCalledTimes(2) + expect(fetch).toHaveBeenNthCalledWith(1, 'http://localhost:3000/health', { + method: 'GET', + }) + expect(fetch).toHaveBeenNthCalledWith(2, 'http://localhost:3000/external/sisyfos/health', { method: 'GET', }) })