From 86a9ad9b8268a757e7a8cbcf22b5e5b063c72b8c Mon Sep 17 00:00:00 2001 From: Peter Hedenskog Date: Mon, 9 Sep 2024 14:46:34 +0200 Subject: [PATCH] Better internal configuration handling (#84) --- server/src/testrunners.js | 61 ++++++++---------------- server/views/includes/script.pug | 6 ++- testrunner/src/queue/queuehandler.js | 3 +- testrunner/src/sitespeedio-testrunner.js | 9 +++- testrunner/src/validateconfig.js | 1 + 5 files changed, 34 insertions(+), 46 deletions(-) diff --git a/server/src/testrunners.js b/server/src/testrunners.js index a2832c5..dc982be 100755 --- a/server/src/testrunners.js +++ b/server/src/testrunners.js @@ -1,53 +1,34 @@ -import merge from 'lodash.merge'; +const testRunners = {}; -const testRunners = []; -const testRunnersById = []; - -export function addTestRunner(config) { - const index = testRunners.findIndex( - testRunner => testRunner.name == config.name - ); - testRunnersById.push(config); - if (index === -1) { - testRunners.push(config); +function mergeByHostname(target, source) { + if (target[source.hostname]) { + target[source.hostname].setup = [ + ...target[source.hostname].setup, + ...source.setup + ]; } else { - // Maybe we have multiple testrunners for the same location etc - merge(testRunners[index], config); + target[source.hostname] = { ...source }; } } -export function removeTestRunner(config) { - // Runners need to have uniqie ids. - // First remove the runner - testRunnersById.splice( - testRunnersById.findIndex( - testRunner => testRunner.hostname === config.hostname - ), - 1 - ); +function removeByHostname(hostnameToRemove) { + delete testRunners[hostnameToRemove]; +} - // Update the merged version - const index = testRunners.findIndex( - testRunner => testRunner.name == config.name - ); - let updatedSetup = {}; - for (let testRunner of testRunnersById) { - if ((testRunner.name = config.name)) { - merge(updatedSetup, testRunner); - } - } +export function addTestRunner(config) { + mergeByHostname(testRunners, config); +} - if (Object.keys(updatedSetup) > 0) { - testRunners[index] = updatedSetup; - } else { - testRunners.splice(index, 1); - } +export function removeTestRunner(config) { + removeByHostname(config.hostname); } + export function getTestRunners() { - return testRunners; + return Object.values(testRunners); } export function getTestRunnersConfiguration(name) { - const index = testRunners.findIndex(testRunner => testRunner.name === name); - return testRunners[index]; + return Object.values(testRunners).find( + testRunner => testRunner.name === name + ); } diff --git a/server/views/includes/script.pug b/server/views/includes/script.pug index 82cf92e..85103bb 100644 --- a/server/views/includes/script.pug +++ b/server/views/includes/script.pug @@ -33,8 +33,10 @@ script. document.getElementById('connectivity').add(new Option(connectivity,connectivity), undefined); } - for (let testType of location.setup.testTypes) { - document.getElementById('testType').add(new Option(testType,testType), undefined); + for (let setup of location.setup) { + if (setup.type) { + document.getElementById('testType').add(new Option(setup.type, setup.type), undefined); + } } for (let setup of location.setup) { diff --git a/testrunner/src/queue/queuehandler.js b/testrunner/src/queue/queuehandler.js index 2069b6f..c98d90e 100644 --- a/testrunner/src/queue/queuehandler.js +++ b/testrunner/src/queue/queuehandler.js @@ -13,7 +13,7 @@ class QueueHandler { this.queues = {}; } - async start() { + async start(serverConfig) { const port = nconf.get('redis:port') ?? 6379; const host = nconf.get('redis:host') ?? '127.0.0.1'; const password = nconf.get('redis:password'); @@ -72,7 +72,6 @@ class QueueHandler { }); // Lets tell the world (or the testsrunners queue) that we are live - const serverConfig = nconf.get('location'); const testRunnersQueue = await this.getQueue('testrunners'); testRunnersQueue.add({ type: 'start', serverConfig: serverConfig }); } diff --git a/testrunner/src/sitespeedio-testrunner.js b/testrunner/src/sitespeedio-testrunner.js index 348b4b7..b97319f 100644 --- a/testrunner/src/sitespeedio-testrunner.js +++ b/testrunner/src/sitespeedio-testrunner.js @@ -29,7 +29,7 @@ export class SitespeedioTestRunner { // If hostname isn't configured add it const hostname = os.hostname(); - if (nconf.get('hostname') === undefined) { + if (serverConfig.hostname === undefined) { serverConfig.hostname = hostname; logger.info('No hostname found in configuration. Will use %s', hostname); } @@ -69,7 +69,7 @@ export class SitespeedioTestRunner { } } - await queueHandler.start(); + await queueHandler.start(serverConfig); process.on('uncaughtException', error => { // ioredis configuration is tricky to get right @@ -82,6 +82,11 @@ export class SitespeedioTestRunner { try { const serverConfig = nconf.get('location'); + const hostname = os.hostname(); + if (serverConfig.hostname === undefined) { + serverConfig.hostname = hostname; + } + const testRunnerQueue = await queueHandler.getQueue('testrunners'); if (testRunnerQueue.client.status === 'ready') { diff --git a/testrunner/src/validateconfig.js b/testrunner/src/validateconfig.js index 121af6d..34e9b3e 100644 --- a/testrunner/src/validateconfig.js +++ b/testrunner/src/validateconfig.js @@ -6,6 +6,7 @@ import Joi from 'joi'; const setupSchema = Joi.array().items( Joi.object({ name: Joi.string().required(), + hostname: Joi.string().optional(), type: Joi.string().valid('desktop', 'emulatedMobile', 'android').required(), browsers: Joi.array() .items(Joi.string().valid('chrome', 'firefox', 'edge', 'safari'))