From d18684d7cc8f91332e9ad86ce54f564804c7d06c Mon Sep 17 00:00:00 2001 From: Igor Savin Date: Fri, 5 Jul 2024 13:30:59 +0300 Subject: [PATCH] Relax validation requirements for DomainEventEmitter, to prevent failure due to missing metadata when full-blown messages with metadata are used as events --- .../lib/events/DomainEventEmitter.spec.ts | 24 +++++++++++++++++-- .../core/lib/events/DomainEventEmitter.ts | 6 ++--- .../core/lib/events/fakes/FakeListener.ts | 10 ++++---- packages/core/package.json | 4 ++-- packages/schemas/lib/events/eventTypes.ts | 6 ++--- packages/schemas/package.json | 2 +- 6 files changed, 36 insertions(+), 16 deletions(-) diff --git a/packages/core/lib/events/DomainEventEmitter.spec.ts b/packages/core/lib/events/DomainEventEmitter.spec.ts index 48a19c88..1cd6d1ed 100644 --- a/packages/core/lib/events/DomainEventEmitter.spec.ts +++ b/packages/core/lib/events/DomainEventEmitter.spec.ts @@ -109,7 +109,14 @@ describe('AutopilotEventEmitter', () => { const fakeListener = new FakeListener(diContainer.cradle.eventRegistry.supportedEvents) eventEmitter.onAny(fakeListener) - await eventEmitter.emit(TestEvents.created, createdEventPayload, { + const partialCreatedEventPayload = { + ...createdEventPayload, + metadata: { + ...createdEventPayload.metadata, + producedBy: undefined, + }, + } + await eventEmitter.emit(TestEvents.created, partialCreatedEventPayload, { correlationId: 'dummy', }) @@ -129,7 +136,20 @@ describe('AutopilotEventEmitter', () => { type: 'entity.created', }) expect(fakeListener.receivedEvents).toHaveLength(1) - expect(fakeListener.receivedEvents[0]).toMatchObject(expectedCreatedPayload) + expect(fakeListener.receivedEvents[0]).toMatchObject({ + id: expect.any(String), + metadata: { + correlationId: expect.any(String), + originatedFrom: 'service', + producedBy: undefined, + schemaVersion: '1', + }, + payload: { + message: 'msg', + }, + timestamp: expect.any(String), + type: 'entity.created', + }) expect(fakeListener.receivedMetadata).toHaveLength(1) expect(fakeListener.receivedMetadata[0]).toMatchObject({ correlationId: 'dummy', diff --git a/packages/core/lib/events/DomainEventEmitter.ts b/packages/core/lib/events/DomainEventEmitter.ts index c3ce1498..ac502a4d 100644 --- a/packages/core/lib/events/DomainEventEmitter.ts +++ b/packages/core/lib/events/DomainEventEmitter.ts @@ -21,7 +21,7 @@ export class DomainEventEmitter private readonly eventHandlerMap: Record< string, - EventHandler>[] + EventHandler>[] > = {} private readonly anyHandlers: AnyEventHandler[] = [] private readonly metadataFiller: MetadataFiller @@ -49,7 +49,7 @@ export class DomainEventEmitter } get handlerSpy(): PublicHandlerSpy< - CommonEventDefinitionConsumerSchemaType + CommonEventDefinitionPublisherSchemaType > { if (!this._handlerSpy) { throw new Error( @@ -90,7 +90,7 @@ export class DomainEventEmitter const validatedEvent = this.eventRegistry .getEventDefinitionByTypeName(eventTypeName) - .consumerSchema.parse({ + .publisherSchema.parse({ type: eventTypeName, ...data, }) diff --git a/packages/core/lib/events/fakes/FakeListener.ts b/packages/core/lib/events/fakes/FakeListener.ts index 702ee41f..24394a38 100644 --- a/packages/core/lib/events/fakes/FakeListener.ts +++ b/packages/core/lib/events/fakes/FakeListener.ts @@ -1,19 +1,19 @@ -import type { ConsumerMessageMetadataType } from '@message-queue-toolkit/schemas' +import type { PublisherMessageMetadataType } from '@message-queue-toolkit/schemas' import type { AnyEventHandler, CommonEventDefinition } from '../eventTypes' export class FakeListener implements AnyEventHandler { - public receivedEvents: SupportedEvents[number]['consumerSchema']['_output'][] = [] - public receivedMetadata: ConsumerMessageMetadataType[] = [] + public receivedEvents: SupportedEvents[number]['publisherSchema']['_output'][] = [] + public receivedMetadata: PublisherMessageMetadataType[] = [] constructor(_supportedEvents: SupportedEvents) { this.receivedEvents = [] } handleEvent( - event: SupportedEvents[number]['consumerSchema']['_output'], - metadata: ConsumerMessageMetadataType, + event: SupportedEvents[number]['publisherSchema']['_output'], + metadata: PublisherMessageMetadataType, ): void | Promise { this.receivedEvents.push(event) this.receivedMetadata.push(metadata) diff --git a/packages/core/package.json b/packages/core/package.json index 95a3cf68..d468fe52 100644 --- a/packages/core/package.json +++ b/packages/core/package.json @@ -1,6 +1,6 @@ { "name": "@message-queue-toolkit/core", - "version": "15.1.0", + "version": "15.1.1", "private": false, "license": "MIT", "description": "Useful utilities, interfaces and base classes for message queue handling. Supports AMQP and SQS with a common abstraction on top currently", @@ -26,7 +26,7 @@ }, "dependencies": { "@lokalise/node-core": "^10.0.1", - "@message-queue-toolkit/schemas": "^2.0.0", + "@message-queue-toolkit/schemas": "^2.1.1", "fast-equals": "^5.0.1", "json-stream-stringify": "^3.1.4", "tmp": "^0.2.3", diff --git a/packages/schemas/lib/events/eventTypes.ts b/packages/schemas/lib/events/eventTypes.ts index 9a2bdce0..2e2a6525 100644 --- a/packages/schemas/lib/events/eventTypes.ts +++ b/packages/schemas/lib/events/eventTypes.ts @@ -39,7 +39,7 @@ export type CommonEventDefinitionPublisherSchemaType = CommonEventDefinitionConsumerSchemaType, + CommonEventDefinitionPublisherSchemaType = CommonEventDefinitionPublisherSchemaType, MetadataDefinitionSchema extends Partial = Partial, > = { @@ -50,7 +50,7 @@ export type EventHandler< } export type AnyEventHandler = EventHandler< - CommonEventDefinitionConsumerSchemaType + CommonEventDefinitionPublisherSchemaType > export type SingleEventHandler< @@ -62,6 +62,6 @@ type EventFromArrayByTypeName< EventDefinition extends CommonEventDefinition[], EventTypeName extends EventTypeNames, > = Extract< - CommonEventDefinitionConsumerSchemaType, + CommonEventDefinitionPublisherSchemaType, { type: EventTypeName } > diff --git a/packages/schemas/package.json b/packages/schemas/package.json index 889e3ea7..c622759d 100644 --- a/packages/schemas/package.json +++ b/packages/schemas/package.json @@ -1,6 +1,6 @@ { "name": "@message-queue-toolkit/schemas", - "version": "2.1.0", + "version": "2.1.1", "private": false, "license": "MIT", "description": "Useful utilities, interfaces and base classes for message queue handling. Supports AMQP and SQS with a common abstraction on top currently",