fix: resolve E2E test failures and API runtime issues for Docker dev environment

- Fix DI issues: circular MCP module dependency, EventBus type import,
  SearchModule provider, CacheService metric counters placement
- Fix Express 5 readonly req.query in SanitizeInputMiddleware
- Fix Typesense client lazy initialization (getter instead of constructor)
- Fix MinIO bucket init error handling (non-fatal on 403)
- Fix missing class-validator decorators on bigint DTO fields (priceVND, amountVND)
- Fix subscription plan 404 (was returning 500 for invalid tier)
- Disable CSRF and raise rate limits in test environment
- Update E2E tests to match actual API response shapes
- Update CI workflow with Redis, Typesense, MinIO services and env vars

All 101 API E2E tests now pass against Docker dev environment.

Co-Authored-By: Paperclip <noreply@paperclip.ing>
This commit is contained in:
Ho Ngoc Hai
2026-04-08 05:44:00 +07:00
parent 00d2f26e25
commit 271ad76e6f
28 changed files with 197 additions and 114 deletions

View File

@@ -48,14 +48,14 @@ const LISTING_SCHEMA: CollectionCreateSchema = {
@Injectable()
export class TypesenseSearchRepository implements ISearchRepository {
private readonly client: TypesenseClient;
private get client(): TypesenseClient {
return this.typesenseClient.getClient();
}
constructor(
private readonly typesenseClient: TypesenseClientService,
private readonly logger: LoggerService,
) {
this.client = this.typesenseClient.getClient();
}
) {}
async ensureCollection(): Promise<void> {
try {

View File

@@ -30,7 +30,8 @@ const QueryHandlers = [SearchPropertiesHandler, GeoSearchHandler];
providers: [
// Infrastructure
TypesenseClientService,
{ provide: SEARCH_REPOSITORY, useClass: TypesenseSearchRepository },
TypesenseSearchRepository,
{ provide: SEARCH_REPOSITORY, useExisting: TypesenseSearchRepository },
ListingIndexerService,
// Event handlers