1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-07 12:26:47 +01:00

refactor(server): domain and infra modules (#6301)

This commit is contained in:
Jason Rasmussen 2024-01-09 17:07:01 -05:00 committed by GitHub
parent 26e6602ed3
commit 12dc7c48c9
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 39 additions and 47 deletions

View file

@ -37,7 +37,6 @@ export default async () => {
} }
process.env.NODE_ENV = 'development'; process.env.NODE_ENV = 'development';
process.env.IMMICH_TEST_ENV = 'true';
process.env.IMMICH_CONFIG_FILE = path.normalize(`${__dirname}/../../../server/test/e2e/immich-e2e-config.json`); process.env.IMMICH_CONFIG_FILE = path.normalize(`${__dirname}/../../../server/test/e2e/immich-e2e-config.json`);
process.env.TZ = 'Z'; process.env.TZ = 'Z';
}; };

View file

@ -1,5 +1,5 @@
import { ImmichLogger } from '@app/infra/logger'; import { ImmichLogger } from '@app/infra/logger';
import { DynamicModule, Global, Module, ModuleMetadata, Provider } from '@nestjs/common'; import { Global, Module, Provider } from '@nestjs/common';
import { ActivityService } from './activity'; import { ActivityService } from './activity';
import { AlbumService } from './album'; import { AlbumService } from './album';
import { APIKeyService } from './api-key'; import { APIKeyService } from './api-key';
@ -31,10 +31,11 @@ const providers: Provider[] = [
AuditService, AuditService,
AuthService, AuthService,
DatabaseService, DatabaseService,
ImmichLogger,
JobService, JobService,
LibraryService,
MediaService, MediaService,
MetadataService, MetadataService,
LibraryService,
PersonService, PersonService,
PartnerService, PartnerService,
SearchService, SearchService,
@ -46,18 +47,12 @@ const providers: Provider[] = [
SystemConfigService, SystemConfigService,
TagService, TagService,
UserService, UserService,
ImmichLogger,
]; ];
@Global() @Global()
@Module({}) @Module({
export class DomainModule { imports: [],
static register(options: Pick<ModuleMetadata, 'imports'>): DynamicModule { providers: [...providers],
return { exports: [...providers],
module: DomainModule, })
imports: options.imports, export class DomainModule {}
providers: [...providers],
exports: [...providers],
};
}
}

View file

@ -6,7 +6,7 @@ import { DisablePasswordLoginCommand, EnablePasswordLoginCommand } from './comma
import { PromptPasswordQuestions, ResetAdminPasswordCommand } from './commands/reset-admin-password.command'; import { PromptPasswordQuestions, ResetAdminPasswordCommand } from './commands/reset-admin-password.command';
@Module({ @Module({
imports: [DomainModule.register({ imports: [InfraModule] })], imports: [InfraModule, DomainModule],
providers: [ providers: [
ResetAdminPasswordCommand, ResetAdminPasswordCommand,
PromptPasswordQuestions, PromptPasswordQuestions,

View file

@ -37,7 +37,8 @@ import { ErrorInterceptor, FileUploadInterceptor } from './interceptors';
@Module({ @Module({
imports: [ imports: [
// //
DomainModule.register({ imports: [InfraModule] }), InfraModule,
DomainModule,
ScheduleModule.forRoot(), ScheduleModule.forRoot(),
TypeOrmModule.forFeature([AssetEntity]), TypeOrmModule.forFeature([AssetEntity]),
], ],

View file

@ -4,11 +4,6 @@ import { QueueOptions } from 'bullmq';
import { RedisOptions } from 'ioredis'; import { RedisOptions } from 'ioredis';
function parseRedisConfig(): RedisOptions { function parseRedisConfig(): RedisOptions {
if (process.env.IMMICH_TEST_ENV == 'true') {
// Currently running e2e tests, do not use redis
return {};
}
const redisUrl = process.env.REDIS_URL; const redisUrl = process.env.REDIS_URL;
if (redisUrl && redisUrl.startsWith('ioredis://')) { if (redisUrl && redisUrl.startsWith('ioredis://')) {
try { try {
@ -28,11 +23,9 @@ function parseRedisConfig(): RedisOptions {
}; };
} }
export const redisConfig: RedisOptions = parseRedisConfig();
export const bullConfig: QueueOptions = { export const bullConfig: QueueOptions = {
prefix: 'immich_bull', prefix: 'immich_bull',
connection: redisConfig, connection: parseRedisConfig(),
defaultJobOptions: { defaultJobOptions: {
attempts: 3, attempts: 3,
removeOnComplete: true, removeOnComplete: true,

View file

@ -94,26 +94,30 @@ const providers: Provider[] = [
SchedulerRegistry, SchedulerRegistry,
]; ];
const imports = [ @Global()
ConfigModule.forRoot(immichAppConfig), @Module({
TypeOrmModule.forRoot(databaseConfig), imports: [
TypeOrmModule.forFeature(databaseEntities), ConfigModule.forRoot(immichAppConfig),
ScheduleModule, TypeOrmModule.forRoot(databaseConfig),
]; TypeOrmModule.forFeature(databaseEntities),
ScheduleModule,
const moduleExports = [...providers]; BullModule.forRoot(bullConfig),
BullModule.registerQueue(...bullQueues),
if (process.env.IMMICH_TEST_ENV !== 'true') { ],
// Currently not running e2e tests, set up redis and bull queues providers: [...providers],
imports.push(BullModule.forRoot(bullConfig)); exports: [...providers, BullModule],
imports.push(BullModule.registerQueue(...bullQueues)); })
moduleExports.push(BullModule); export class InfraModule {}
}
@Global() @Global()
@Module({ @Module({
imports, imports: [
ConfigModule.forRoot(immichAppConfig),
TypeOrmModule.forRoot(databaseConfig),
TypeOrmModule.forFeature(databaseEntities),
ScheduleModule,
],
providers: [...providers], providers: [...providers],
exports: moduleExports, exports: [...providers],
}) })
export class InfraModule {} export class InfraTestModule {}

View file

@ -4,7 +4,7 @@ import { Module, OnModuleInit } from '@nestjs/common';
import { AppService } from './app.service'; import { AppService } from './app.service';
@Module({ @Module({
imports: [DomainModule.register({ imports: [InfraModule] })], imports: [InfraModule, DomainModule],
providers: [AppService], providers: [AppService],
}) })
export class MicroservicesModule implements OnModuleInit { export class MicroservicesModule implements OnModuleInit {

View file

@ -47,7 +47,6 @@ export default async () => {
} }
process.env.NODE_ENV = 'development'; process.env.NODE_ENV = 'development';
process.env.IMMICH_TEST_ENV = 'true';
process.env.IMMICH_CONFIG_FILE = path.normalize(`${__dirname}/immich-e2e-config.json`); process.env.IMMICH_CONFIG_FILE = path.normalize(`${__dirname}/immich-e2e-config.json`);
process.env.TZ = 'Z'; process.env.TZ = 'Z';
}; };

View file

@ -1,10 +1,9 @@
import { AssetCreate, IJobRepository, JobItem, JobItemHandler, LibraryResponseDto, QueueName } from '@app/domain'; import { AssetCreate, IJobRepository, JobItem, JobItemHandler, LibraryResponseDto, QueueName } from '@app/domain';
import { AppModule } from '@app/immich'; import { AppModule } from '@app/immich';
import { dataSource } from '@app/infra'; import { InfraModule, InfraTestModule, dataSource } from '@app/infra';
import { AssetEntity, AssetType, LibraryType } from '@app/infra/entities'; import { AssetEntity, AssetType, LibraryType } from '@app/infra/entities';
import { INestApplication } from '@nestjs/common'; import { INestApplication } from '@nestjs/common';
import { Test } from '@nestjs/testing'; import { Test } from '@nestjs/testing';
import { randomBytes } from 'crypto'; import { randomBytes } from 'crypto';
import * as fs from 'fs'; import * as fs from 'fs';
import { DateTime } from 'luxon'; import { DateTime } from 'luxon';
@ -69,6 +68,8 @@ export const testApp = {
const { jobs } = options || { jobs: false }; const { jobs } = options || { jobs: false };
const moduleFixture = await Test.createTestingModule({ imports: [AppModule], providers: [AppService] }) const moduleFixture = await Test.createTestingModule({ imports: [AppModule], providers: [AppService] })
.overrideModule(InfraModule)
.useModule(InfraTestModule)
.overrideProvider(IJobRepository) .overrideProvider(IJobRepository)
.useValue({ .useValue({
addHandler: (_queueName: QueueName, _concurrency: number, handler: JobItemHandler) => (_handler = handler), addHandler: (_queueName: QueueName, _concurrency: number, handler: JobItemHandler) => (_handler = handler),