X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Fcharging-station%2FBootstrap.ts;h=e29c6445fefcccb383b4387f93d670a948c57326;hb=45c0ae82dee8cf065f6303c4853c8adfe239dee1;hp=eb437ab08cf5e6e81baa1e8bf69499133200e456;hpb=ba7965c4b933e479b36fc81f934a643336efcbea;p=e-mobility-charging-stations-simulator.git diff --git a/src/charging-station/Bootstrap.ts b/src/charging-station/Bootstrap.ts index eb437ab0..e29c6445 100644 --- a/src/charging-station/Bootstrap.ts +++ b/src/charging-station/Bootstrap.ts @@ -2,7 +2,7 @@ import path from 'path'; import { fileURLToPath } from 'url'; -import { isMainThread } from 'worker_threads'; +import { type Worker, isMainThread } from 'worker_threads'; import chalk from 'chalk'; @@ -18,7 +18,7 @@ import { ChargingStationWorkerMessageEvents, } from '../types/ChargingStationWorker'; import type { StationTemplateUrl } from '../types/ConfigurationData'; -import type Statistics from '../types/Statistics'; +import type { Statistics } from '../types/Statistics'; import Configuration from '../utils/Configuration'; import logger from '../utils/Logger'; import Utils from '../utils/Utils'; @@ -30,8 +30,10 @@ import UIServerFactory from './ui-server/UIServerFactory'; const moduleName = 'Bootstrap'; -const missingChargingStationsConfigurationExitCode = 1; -const noChargingStationTemplatesExitCode = 2; +enum exitCodes { + missingChargingStationsConfiguration = 1, + noChargingStationTemplates = 2, +} export class Bootstrap { private static instance: Bootstrap | null = null; @@ -75,6 +77,9 @@ export class Bootstrap { public async start(): Promise { if (isMainThread && this.started === false) { try { + // Enable unconditionally for now + this.logUnhandledRejection(); + this.logUncaughtException(); this.initialize(); await this.storage?.open(); await this.workerImplementation.start(); @@ -104,13 +109,13 @@ export class Bootstrap { console.warn( chalk.yellow("'stationTemplateUrls' not defined or empty in configuration, exiting") ); - process.exit(missingChargingStationsConfigurationExitCode); + process.exit(exitCodes.missingChargingStationsConfiguration); } if (this.numberOfChargingStations === 0) { console.warn( chalk.yellow('No charging station template enabled in configuration, exiting') ); - process.exit(noChargingStationTemplatesExitCode); + process.exit(exitCodes.noChargingStationTemplates); } else { console.info( chalk.green( @@ -174,6 +179,7 @@ export class Bootstrap { workerChoiceStrategy: Configuration.getWorker().poolStrategy, }, messageHandler: this.messageHandler.bind(this) as ( + this: Worker, msg: ChargingStationWorkerMessage ) => void, } @@ -222,11 +228,25 @@ export class Bootstrap { private workerEventStarted = (data: ChargingStationData) => { this.uiServer?.chargingStations.set(data.stationInfo.hashId, data); ++this.numberOfStartedChargingStations; + logger.info( + `${this.logPrefix()} ${moduleName}.workerEventStarted: Charging station '${ + data.stationInfo.chargingStationId + } (hashId: ${data.stationInfo.hashId})' started (${ + this.numberOfStartedChargingStations + } started from ${this.numberOfChargingStations})` + ); }; private workerEventStopped = (data: ChargingStationData) => { this.uiServer?.chargingStations.set(data.stationInfo.hashId, data); --this.numberOfStartedChargingStations; + logger.info( + `${this.logPrefix()} ${moduleName}.workerEventStopped: Charging station '${ + data.stationInfo.chargingStationId + } (hashId: ${data.stationInfo.hashId})' stopped (${ + this.numberOfStartedChargingStations + } started from ${this.numberOfChargingStations})` + ); }; private workerEventUpdated = (data: ChargingStationData) => { @@ -244,6 +264,18 @@ export class Bootstrap { this.initializeWorkerImplementation(); } + private logUncaughtException(): void { + process.on('uncaughtException', (error: Error) => { + console.error(chalk.red('Uncaught exception: '), error); + }); + } + + private logUnhandledRejection(): void { + process.on('unhandledRejection', (reason: unknown) => { + console.error(chalk.red('Unhandled rejection: '), reason); + }); + } + private async startChargingStation( index: number, stationTemplateUrl: StationTemplateUrl