From 80c312f7862b4021180f3e587f63c6b0dd87202c Mon Sep 17 00:00:00 2001 From: Gxkl Date: Tue, 22 Oct 2024 21:07:20 +0800 Subject: [PATCH] feat: add dump switcher (#252) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ##### Checklist - [ ] `npm test` passes - [ ] tests and/or benchmarks are included - [ ] documentation is changed or added - [ ] commit message follows commit guidelines ##### Affected core subsystem(s) ##### Description of change ## Summary by CodeRabbit - **New Features** - Introduced a new optional property `dump` in the `EggModuleLoaderOptions` and `RunnerOptions` interfaces, allowing users to control module descriptor dumping. - Enhanced configurability of the `Runner` class with the new `dump` option. - **Bug Fixes** - Improved error handling and logging during the module descriptor dumping process. - **Tests** - Added new test cases to validate the behavior of the `main` function with the `dump` option in different configurations. --- standalone/standalone/package.json | 1 + standalone/standalone/src/EggModuleLoader.ts | 17 +++++++++------- standalone/standalone/src/Runner.ts | 2 ++ standalone/standalone/test/index.test.ts | 21 ++++++++++++++++++-- 4 files changed, 32 insertions(+), 9 deletions(-) diff --git a/standalone/standalone/package.json b/standalone/standalone/package.json index 3a5b291a..81eb23fc 100644 --- a/standalone/standalone/package.json +++ b/standalone/standalone/package.json @@ -58,6 +58,7 @@ "@types/mocha": "^10.0.1", "@types/node": "^20.2.4", "cross-env": "^7.0.3", + "mm": "^3.2.1", "mocha": "^10.2.0", "ts-node": "^10.9.1", "typescript": "^5.0.4" diff --git a/standalone/standalone/src/EggModuleLoader.ts b/standalone/standalone/src/EggModuleLoader.ts index 3b11342d..b0befaad 100644 --- a/standalone/standalone/src/EggModuleLoader.ts +++ b/standalone/standalone/src/EggModuleLoader.ts @@ -13,6 +13,7 @@ import { Logger } from '@eggjs/tegg'; export interface EggModuleLoaderOptions { logger: Logger; baseDir: string; + dump?: boolean; } export class EggModuleLoader { @@ -26,13 +27,15 @@ export class EggModuleLoader { private static generateAppGraph(moduleReferences: readonly ModuleReference[], options: EggModuleLoaderOptions) { const moduleDescriptors = LoaderFactory.loadApp(moduleReferences); - for (const moduleDescriptor of moduleDescriptors) { - ModuleDescriptorDumper.dump(moduleDescriptor, { - dumpDir: options.baseDir, - }).catch(e => { - e.message = 'dump module descriptor failed: ' + e.message; - options.logger.warn(e); - }); + if (options.dump !== false) { + for (const moduleDescriptor of moduleDescriptors) { + ModuleDescriptorDumper.dump(moduleDescriptor, { + dumpDir: options.baseDir, + }).catch(e => { + e.message = 'dump module descriptor failed: ' + e.message; + options.logger.warn(e); + }); + } } const globalGraph = GlobalGraph.create(moduleDescriptors); return globalGraph; diff --git a/standalone/standalone/src/Runner.ts b/standalone/standalone/src/Runner.ts index 9bddde88..358c9428 100644 --- a/standalone/standalone/src/Runner.ts +++ b/standalone/standalone/src/Runner.ts @@ -60,6 +60,7 @@ export interface RunnerOptions { name?: string; innerObjectHandlers?: Record; dependencies?: (string | ModuleDependency)[]; + dump?: boolean; } export class Runner { @@ -147,6 +148,7 @@ export class Runner { this.loadUnitLoader = new EggModuleLoader(this.moduleReferences, { logger: ((this.innerObjects.logger && this.innerObjects.logger[0])?.obj as Logger) || console, baseDir: this.cwd, + dump: options?.dump, }); GlobalGraph.instance!.registerBuildHook(crossCutGraphHook); GlobalGraph.instance!.registerBuildHook(pointCutGraphHook); diff --git a/standalone/standalone/test/index.test.ts b/standalone/standalone/test/index.test.ts index eff49a5e..cd942d4b 100644 --- a/standalone/standalone/test/index.test.ts +++ b/standalone/standalone/test/index.test.ts @@ -1,16 +1,33 @@ import { strict as assert, deepStrictEqual } from 'node:assert'; import path from 'node:path'; import fs from 'node:fs/promises'; -import { ModuleConfig, ModuleConfigs } from '@eggjs/tegg/helper'; +import { setTimeout as sleep } from 'node:timers/promises'; +import mm from 'mm'; +import { ModuleConfig, ModuleConfigs, ModuleDescriptorDumper } from '@eggjs/tegg/helper'; import { main, StandaloneContext, Runner, preLoad } from '..'; import { crosscutAdviceParams, pointcutAdviceParams } from './fixtures/aop-module/Hello'; import { Foo } from './fixtures/dal-module/src/Foo'; describe('standalone/standalone/test/index.test.ts', () => { describe('simple runner', () => { + const fixture = path.join(__dirname, './fixtures/simple'); + + beforeEach(() => { + mm.restore(); + mm.spy(ModuleDescriptorDumper, 'dump'); + }); + it('should work', async () => { - const msg: string = await main(path.join(__dirname, './fixtures/simple')); + const msg: string = await main(fixture); assert(msg === 'hello!hello from ctx'); + await sleep(500); + assert.equal((ModuleDescriptorDumper.dump as any).called, 1); + }); + + it('should not dump', async () => { + await main(fixture, { dump: false }); + await sleep(500); + assert.equal((ModuleDescriptorDumper.dump as any).called, undefined); }); });