Skip to content

Commit

Permalink
Merge branch 'lovesharma95-lovesharma95-feature/loadAsync'
Browse files Browse the repository at this point in the history
  • Loading branch information
kamilmysliwiec committed Oct 21, 2024
2 parents ebdb8c2 + 7ab5a27 commit fdff9c1
Show file tree
Hide file tree
Showing 4 changed files with 49 additions and 4 deletions.
7 changes: 5 additions & 2 deletions lib/config.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,9 @@ export class ConfigModule {
* Also, registers custom configurations globally.
* @param options
*/
static forRoot(options: ConfigModuleOptions = {}): DynamicModule {
static async forRoot(
options: ConfigModuleOptions = {},
): Promise<DynamicModule> {
const envFilePaths = Array.isArray(options.envFilePath)
? options.envFilePath
: [options.envFilePath || resolve(process.cwd(), '.env')];
Expand Down Expand Up @@ -88,7 +90,8 @@ export class ConfigModule {
}

const isConfigToLoad = options.load && options.load.length;
const providers = (options.load || [])
const configFactory = await Promise.all(options.load || []);
const providers = configFactory
.map(factory =>
createConfigProvider(factory as ConfigFactory & ConfigFactoryKeyHost),
)
Expand Down
4 changes: 2 additions & 2 deletions lib/interfaces/config-module-options.interface.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { DotenvExpandOptions } from 'dotenv-expand';
import { ConfigFactory } from './config-factory.interface';
import { DotenvExpandOptions } from 'dotenv-expand'

/**
* @publicApi
Expand Down Expand Up @@ -57,7 +57,7 @@ export interface ConfigModuleOptions {
* Array of custom configuration files to be loaded.
* See: https://docs.nestjs.com/techniques/configuration
*/
load?: Array<ConfigFactory>;
load?: Array<ConfigFactory | Promise<ConfigFactory>>;

/**
* A boolean value indicating the use of expanded variables, or object
Expand Down
31 changes: 31 additions & 0 deletions tests/e2e/load-files-async.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
import { INestApplication } from '@nestjs/common';
import { Test } from '@nestjs/testing';
import { AppModule } from '../src/app.module';

describe('Async Files', () => {
let app: INestApplication;

beforeEach(async () => {
const module = await Test.createTestingModule({
imports: [AppModule.withLoadedAsyncConfigurations()],
}).compile();

app = module.createNestApplication();
await app.init();
});

it(`should return loaded configuration`, () => {
const host = app.get(AppModule).getDatabaseHost();
expect(host).toEqual('host');
});

it(`should return loaded configuration (injected through constructor)`, () => {
const config = app.get(AppModule).getDatabaseConfig();
expect(config.host).toEqual('host');
expect(config.port).toEqual(4000);
});

afterEach(async () => {
await app.close();
});
});
11 changes: 11 additions & 0 deletions tests/src/app.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -140,6 +140,17 @@ export class AppModule {
};
}

static withLoadedAsyncConfigurations() {
return {
module: AppModule,
imports: [
ConfigModule.forRoot({
load: [Promise.resolve(databaseConfig)],
}),
],
};
}

static withNestedLoadedConfigurations(): DynamicModule {
return {
module: AppModule,
Expand Down

0 comments on commit fdff9c1

Please sign in to comment.