@volontariapp/outbox 0.5.0 → 0.6.0-snap-6cba0ec
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +13 -0
- package/dist/pushers/event-queue.pusher.d.ts +5 -1
- package/dist/pushers/event-queue.pusher.d.ts.map +1 -1
- package/dist/pushers/event-queue.pusher.js +67 -7
- package/dist/pushers/event-queue.pusher.js.map +1 -1
- package/dist/pushers/jobs-outbox.pusher.d.ts +3 -3
- package/dist/pushers/jobs-outbox.pusher.d.ts.map +1 -1
- package/dist/pushers/jobs-outbox.pusher.js +4 -11
- package/dist/pushers/jobs-outbox.pusher.js.map +1 -1
- package/dist/test/consumers/event/event-queue.consumer.int.spec.js +6 -2
- package/dist/test/consumers/event/event-queue.consumer.int.spec.js.map +1 -1
- package/dist/test/consumers/event/event-queue.consumer.unit.spec.js +9 -7
- package/dist/test/consumers/event/event-queue.consumer.unit.spec.js.map +1 -1
- package/dist/test/consumers/jobs/jobs-outbox.consumer.int.spec.js +6 -3
- package/dist/test/consumers/jobs/jobs-outbox.consumer.int.spec.js.map +1 -1
- package/dist/test/consumers/jobs/jobs-outbox.consumer.unit.spec.js +16 -9
- package/dist/test/consumers/jobs/jobs-outbox.consumer.unit.spec.js.map +1 -1
- package/dist/test/dispatchers/event/event-queue.dispatcher.int.spec.js +1 -1
- package/dist/test/dispatchers/event/event-queue.dispatcher.int.spec.js.map +1 -1
- package/dist/test/dispatchers/event/event-queue.dispatcher.unit.spec.js +3 -3
- package/dist/test/dispatchers/event/event-queue.dispatcher.unit.spec.js.map +1 -1
- package/dist/test/dispatchers/event/event-queue.generics.int.spec.js +2 -2
- package/dist/test/dispatchers/event/event-queue.generics.int.spec.js.map +1 -1
- package/dist/test/dispatchers/jobs/jobs-outbox.dispatcher.int.spec.js +1 -1
- package/dist/test/dispatchers/jobs/jobs-outbox.dispatcher.int.spec.js.map +1 -1
- package/dist/test/dispatchers/jobs/jobs-outbox.dispatcher.unit.spec.js +3 -3
- package/dist/test/dispatchers/jobs/jobs-outbox.dispatcher.unit.spec.js.map +1 -1
- package/dist/test/dispatchers/jobs/jobs-outbox.generics.int.spec.js +2 -2
- package/dist/test/dispatchers/jobs/jobs-outbox.generics.int.spec.js.map +1 -1
- package/dist/test/pushers/event/event-flow.full.int.spec.d.ts +2 -0
- package/dist/test/pushers/event/event-flow.full.int.spec.d.ts.map +1 -0
- package/dist/test/pushers/event/event-flow.full.int.spec.js +149 -0
- package/dist/test/pushers/event/event-flow.full.int.spec.js.map +1 -0
- package/dist/test/pushers/event/event-queue.pusher.int.spec.d.ts +2 -0
- package/dist/test/pushers/event/event-queue.pusher.int.spec.d.ts.map +1 -0
- package/dist/test/pushers/event/event-queue.pusher.int.spec.js +76 -0
- package/dist/test/pushers/event/event-queue.pusher.int.spec.js.map +1 -0
- package/dist/test/pushers/event/event-queue.pusher.unit.spec.d.ts +2 -0
- package/dist/test/pushers/event/event-queue.pusher.unit.spec.d.ts.map +1 -0
- package/dist/test/pushers/event/event-queue.pusher.unit.spec.js +170 -0
- package/dist/test/pushers/event/event-queue.pusher.unit.spec.js.map +1 -0
- package/dist/test/pushers/jobs/jobs-outbox.pusher.int.spec.d.ts.map +1 -0
- package/dist/test/pushers/{jobs-outbox.pusher.int.spec.js → jobs/jobs-outbox.pusher.int.spec.js} +10 -5
- package/dist/test/pushers/jobs/jobs-outbox.pusher.int.spec.js.map +1 -0
- package/dist/test/pushers/jobs/jobs-outbox.pusher.unit.spec.d.ts.map +1 -0
- package/dist/test/pushers/{jobs-outbox.pusher.unit.spec.js → jobs/jobs-outbox.pusher.unit.spec.js} +32 -52
- package/dist/test/pushers/jobs/jobs-outbox.pusher.unit.spec.js.map +1 -0
- package/dist/test/redis-config.d.ts.map +1 -1
- package/dist/test/redis-config.js +3 -0
- package/dist/test/redis-config.js.map +1 -1
- package/dist/test/runners/event/outbox-runner.event.int.spec.d.ts +2 -0
- package/dist/test/runners/event/outbox-runner.event.int.spec.d.ts.map +1 -0
- package/dist/test/runners/event/outbox-runner.event.int.spec.js +167 -0
- package/dist/test/runners/event/outbox-runner.event.int.spec.js.map +1 -0
- package/dist/test/runners/jobs/outbox-runner.jobs.int.spec.d.ts +2 -0
- package/dist/test/runners/jobs/outbox-runner.jobs.int.spec.d.ts.map +1 -0
- package/dist/test/runners/jobs/outbox-runner.jobs.int.spec.js +214 -0
- package/dist/test/runners/jobs/outbox-runner.jobs.int.spec.js.map +1 -0
- package/dist/test/utils/helpers/event/event-queue-event.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/{event-queue-event.helper.js → event/event-queue-event.helper.js} +1 -0
- package/dist/test/utils/helpers/event/event-queue-event.helper.js.map +1 -0
- package/dist/test/utils/helpers/event/event-queue-generics.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/event/event-queue-generics.helper.js.map +1 -0
- package/dist/test/utils/helpers/{event-queue-pusher-mock.helper.d.ts → event/event-queue-pusher-mock.helper.d.ts} +1 -1
- package/dist/test/utils/helpers/event/event-queue-pusher-mock.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/event/event-queue-pusher-mock.helper.js.map +1 -0
- package/dist/test/utils/helpers/{event-queue-repository-mock.helper.d.ts → event/event-queue-repository-mock.helper.d.ts} +2 -2
- package/dist/test/utils/helpers/event/event-queue-repository-mock.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/{event-queue-repository-mock.helper.js → event/event-queue-repository-mock.helper.js} +2 -2
- package/dist/test/utils/helpers/event/event-queue-repository-mock.helper.js.map +1 -0
- package/dist/test/utils/helpers/job/jobs-outbox-event.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/job/jobs-outbox-event.helper.js.map +1 -0
- package/dist/test/utils/helpers/job/jobs-outbox-generics.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/job/jobs-outbox-generics.helper.js.map +1 -0
- package/dist/test/utils/helpers/{jobs-outbox-pusher-mock.helper.d.ts → job/jobs-outbox-pusher-mock.helper.d.ts} +1 -1
- package/dist/test/utils/helpers/job/jobs-outbox-pusher-mock.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/job/jobs-outbox-pusher-mock.helper.js.map +1 -0
- package/dist/test/utils/helpers/{jobs-outbox-repository-mock.helper.d.ts → job/jobs-outbox-repository-mock.helper.d.ts} +2 -2
- package/dist/test/utils/helpers/job/jobs-outbox-repository-mock.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/{jobs-outbox-repository-mock.helper.js → job/jobs-outbox-repository-mock.helper.js} +2 -2
- package/dist/test/utils/helpers/job/jobs-outbox-repository-mock.helper.js.map +1 -0
- package/dist/test/utils/helpers/shared/bullmq-mock.helper.d.ts +9 -0
- package/dist/test/utils/helpers/shared/bullmq-mock.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/shared/bullmq-mock.helper.js +9 -0
- package/dist/test/utils/helpers/shared/bullmq-mock.helper.js.map +1 -0
- package/dist/test/utils/helpers/shared/logger-mock.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/shared/logger-mock.helper.js.map +1 -0
- package/dist/test/utils/helpers/shared/outbox-consumer-repository-mock.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/shared/outbox-consumer-repository-mock.helper.js.map +1 -0
- package/dist/test/utils/helpers/shared/outbox-repository-mock.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/shared/outbox-repository-mock.helper.js.map +1 -0
- package/dist/test/utils/helpers/shared/outbox-runner.helper.d.ts +33 -0
- package/dist/test/utils/helpers/shared/outbox-runner.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/shared/outbox-runner.helper.js +100 -0
- package/dist/test/utils/helpers/shared/outbox-runner.helper.js.map +1 -0
- package/dist/test/utils/helpers/shared/redis-mock.helper.d.ts +7 -0
- package/dist/test/utils/helpers/shared/redis-mock.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/shared/redis-mock.helper.js +10 -0
- package/dist/test/utils/helpers/shared/redis-mock.helper.js.map +1 -0
- package/dist/test/writers/event/event-queue.writer.int.spec.js +2 -2
- package/dist/test/writers/event/event-queue.writer.int.spec.js.map +1 -1
- package/dist/test/writers/event/event-queue.writer.unit.spec.js +3 -3
- package/dist/test/writers/event/event-queue.writer.unit.spec.js.map +1 -1
- package/dist/test/writers/jobs/jobs-outbox.writer.int.spec.js +2 -2
- package/dist/test/writers/jobs/jobs-outbox.writer.int.spec.js.map +1 -1
- package/dist/test/writers/jobs/jobs-outbox.writer.unit.spec.js +3 -3
- package/dist/test/writers/jobs/jobs-outbox.writer.unit.spec.js.map +1 -1
- package/package.json +6 -4
- package/dist/test/pushers/jobs-outbox.pusher.int.spec.d.ts.map +0 -1
- package/dist/test/pushers/jobs-outbox.pusher.int.spec.js.map +0 -1
- package/dist/test/pushers/jobs-outbox.pusher.unit.spec.d.ts.map +0 -1
- package/dist/test/pushers/jobs-outbox.pusher.unit.spec.js.map +0 -1
- package/dist/test/utils/helpers/event-queue-event.helper.d.ts.map +0 -1
- package/dist/test/utils/helpers/event-queue-event.helper.js.map +0 -1
- package/dist/test/utils/helpers/event-queue-generics.helper.d.ts.map +0 -1
- package/dist/test/utils/helpers/event-queue-generics.helper.js.map +0 -1
- package/dist/test/utils/helpers/event-queue-pusher-mock.helper.d.ts.map +0 -1
- package/dist/test/utils/helpers/event-queue-pusher-mock.helper.js.map +0 -1
- package/dist/test/utils/helpers/event-queue-repository-mock.helper.d.ts.map +0 -1
- package/dist/test/utils/helpers/event-queue-repository-mock.helper.js.map +0 -1
- package/dist/test/utils/helpers/jobs-outbox-event.helper.d.ts.map +0 -1
- package/dist/test/utils/helpers/jobs-outbox-event.helper.js.map +0 -1
- package/dist/test/utils/helpers/jobs-outbox-generics.helper.d.ts.map +0 -1
- package/dist/test/utils/helpers/jobs-outbox-generics.helper.js.map +0 -1
- package/dist/test/utils/helpers/jobs-outbox-pusher-mock.helper.d.ts.map +0 -1
- package/dist/test/utils/helpers/jobs-outbox-pusher-mock.helper.js.map +0 -1
- package/dist/test/utils/helpers/jobs-outbox-repository-mock.helper.d.ts.map +0 -1
- package/dist/test/utils/helpers/jobs-outbox-repository-mock.helper.js.map +0 -1
- package/dist/test/utils/helpers/logger-mock.helper.d.ts.map +0 -1
- package/dist/test/utils/helpers/logger-mock.helper.js.map +0 -1
- package/dist/test/utils/helpers/outbox-consumer-repository-mock.helper.d.ts.map +0 -1
- package/dist/test/utils/helpers/outbox-consumer-repository-mock.helper.js.map +0 -1
- package/dist/test/utils/helpers/outbox-repository-mock.helper.d.ts.map +0 -1
- package/dist/test/utils/helpers/outbox-repository-mock.helper.js.map +0 -1
- /package/dist/test/pushers/{jobs-outbox.pusher.int.spec.d.ts → jobs/jobs-outbox.pusher.int.spec.d.ts} +0 -0
- /package/dist/test/pushers/{jobs-outbox.pusher.unit.spec.d.ts → jobs/jobs-outbox.pusher.unit.spec.d.ts} +0 -0
- /package/dist/test/utils/helpers/{event-queue-event.helper.d.ts → event/event-queue-event.helper.d.ts} +0 -0
- /package/dist/test/utils/helpers/{event-queue-generics.helper.d.ts → event/event-queue-generics.helper.d.ts} +0 -0
- /package/dist/test/utils/helpers/{event-queue-generics.helper.js → event/event-queue-generics.helper.js} +0 -0
- /package/dist/test/utils/helpers/{event-queue-pusher-mock.helper.js → event/event-queue-pusher-mock.helper.js} +0 -0
- /package/dist/test/utils/helpers/{jobs-outbox-event.helper.d.ts → job/jobs-outbox-event.helper.d.ts} +0 -0
- /package/dist/test/utils/helpers/{jobs-outbox-event.helper.js → job/jobs-outbox-event.helper.js} +0 -0
- /package/dist/test/utils/helpers/{jobs-outbox-generics.helper.d.ts → job/jobs-outbox-generics.helper.d.ts} +0 -0
- /package/dist/test/utils/helpers/{jobs-outbox-generics.helper.js → job/jobs-outbox-generics.helper.js} +0 -0
- /package/dist/test/utils/helpers/{jobs-outbox-pusher-mock.helper.js → job/jobs-outbox-pusher-mock.helper.js} +0 -0
- /package/dist/test/utils/helpers/{logger-mock.helper.d.ts → shared/logger-mock.helper.d.ts} +0 -0
- /package/dist/test/utils/helpers/{logger-mock.helper.js → shared/logger-mock.helper.js} +0 -0
- /package/dist/test/utils/helpers/{outbox-consumer-repository-mock.helper.d.ts → shared/outbox-consumer-repository-mock.helper.d.ts} +0 -0
- /package/dist/test/utils/helpers/{outbox-consumer-repository-mock.helper.js → shared/outbox-consumer-repository-mock.helper.js} +0 -0
- /package/dist/test/utils/helpers/{outbox-repository-mock.helper.d.ts → shared/outbox-repository-mock.helper.d.ts} +0 -0
- /package/dist/test/utils/helpers/{outbox-repository-mock.helper.js → shared/outbox-repository-mock.helper.js} +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,18 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## 0.6.0
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- Event queue pusher added
|
|
8
|
+
|
|
9
|
+
### Patch Changes
|
|
10
|
+
|
|
11
|
+
- Updated dependencies []:
|
|
12
|
+
- @volontariapp/messaging@1.1.0
|
|
13
|
+
- @volontariapp/database@1.15.0
|
|
14
|
+
- @volontariapp/shared@0.4.0
|
|
15
|
+
|
|
3
16
|
## 0.5.0
|
|
4
17
|
|
|
5
18
|
### Minor Changes
|
|
@@ -1,8 +1,12 @@
|
|
|
1
1
|
import { OutboxPusher, type EventQueueEntity } from '@volontariapp/database';
|
|
2
2
|
import type { Logger } from '@volontariapp/logger';
|
|
3
|
+
import type { Redis } from 'ioredis';
|
|
3
4
|
export declare class EventQueuePusher extends OutboxPusher<EventQueueEntity> {
|
|
4
5
|
private readonly logger;
|
|
5
|
-
|
|
6
|
+
private readonly redis;
|
|
7
|
+
private readonly MAX_LEN;
|
|
8
|
+
constructor(logger: Logger, redis: Redis);
|
|
9
|
+
private formatMessage;
|
|
6
10
|
pushElement(entity: EventQueueEntity): Promise<void>;
|
|
7
11
|
pushBulkElement(entities: EventQueueEntity[]): Promise<void>;
|
|
8
12
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-queue.pusher.d.ts","sourceRoot":"","sources":["../../src/pushers/event-queue.pusher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,KAAK,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC7E,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"event-queue.pusher.d.ts","sourceRoot":"","sources":["../../src/pushers/event-queue.pusher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,KAAK,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC7E,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAGrC,qBAAa,gBAAiB,SAAQ,YAAY,CAAC,gBAAgB,CAAC;IAIhE,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,KAAK;IAJxB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;gBAGd,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,KAAK;IAK/B,OAAO,CAAC,aAAa;IAaf,WAAW,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IA8BpD,eAAe,CAAC,QAAQ,EAAE,gBAAgB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;CA2BnE"}
|
|
@@ -1,17 +1,77 @@
|
|
|
1
1
|
import { OutboxPusher } from '@volontariapp/database';
|
|
2
|
+
import { getEventStreamName } from '@volontariapp/messaging';
|
|
2
3
|
export class EventQueuePusher extends OutboxPusher {
|
|
3
4
|
logger;
|
|
4
|
-
|
|
5
|
+
redis;
|
|
6
|
+
MAX_LEN = 10000;
|
|
7
|
+
constructor(logger, redis) {
|
|
5
8
|
super();
|
|
6
9
|
this.logger = logger;
|
|
10
|
+
this.redis = redis;
|
|
7
11
|
}
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
12
|
+
formatMessage(entity) {
|
|
13
|
+
const message = {
|
|
14
|
+
id: entity.id,
|
|
15
|
+
type: entity.type,
|
|
16
|
+
emitter: entity.emitter,
|
|
17
|
+
traceId: entity.traceId,
|
|
18
|
+
version: entity.version,
|
|
19
|
+
payload: entity.payload,
|
|
20
|
+
createdAt: entity.createdAt.toISOString(),
|
|
21
|
+
};
|
|
22
|
+
return JSON.stringify(message);
|
|
11
23
|
}
|
|
12
|
-
|
|
13
|
-
this.logger.info(`Pushing ${
|
|
14
|
-
|
|
24
|
+
async pushElement(entity) {
|
|
25
|
+
this.logger.info(`Pushing event queue item ${entity.id}`);
|
|
26
|
+
try {
|
|
27
|
+
const payload = this.formatMessage(entity);
|
|
28
|
+
const pipeline = this.redis.pipeline();
|
|
29
|
+
const targetServices = entity.targetServices;
|
|
30
|
+
if (targetServices.length === 0) {
|
|
31
|
+
this.logger.warn(`Event ${entity.id} has no target services, skipping push`);
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
for (const targetService of targetServices) {
|
|
35
|
+
const streamName = getEventStreamName(targetService);
|
|
36
|
+
pipeline.xadd(streamName, 'MAXLEN', '~', this.MAX_LEN, '*', 'event', payload);
|
|
37
|
+
}
|
|
38
|
+
const results = await pipeline.exec();
|
|
39
|
+
if (results) {
|
|
40
|
+
for (const [err] of results) {
|
|
41
|
+
if (err)
|
|
42
|
+
throw err;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
catch (error) {
|
|
47
|
+
this.logger.error(`Failed to push event queue item ${entity.id}`, { error });
|
|
48
|
+
throw error;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
async pushBulkElement(entities) {
|
|
52
|
+
this.logger.info(`Pushing bulk event queue items (${entities.length.toString()})`);
|
|
53
|
+
try {
|
|
54
|
+
const pipeline = this.redis.pipeline();
|
|
55
|
+
for (const entity of entities) {
|
|
56
|
+
const payload = this.formatMessage(entity);
|
|
57
|
+
const targetServices = entity.targetServices;
|
|
58
|
+
for (const targetService of targetServices) {
|
|
59
|
+
const streamName = getEventStreamName(targetService);
|
|
60
|
+
pipeline.xadd(streamName, 'MAXLEN', '~', this.MAX_LEN, '*', 'event', payload);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
const results = await pipeline.exec();
|
|
64
|
+
if (results) {
|
|
65
|
+
for (const [err] of results) {
|
|
66
|
+
if (err)
|
|
67
|
+
throw err;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
catch (error) {
|
|
72
|
+
this.logger.error('Failed to push bulk event queue items', { error });
|
|
73
|
+
throw error;
|
|
74
|
+
}
|
|
15
75
|
}
|
|
16
76
|
}
|
|
17
77
|
//# sourceMappingURL=event-queue.pusher.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-queue.pusher.js","sourceRoot":"","sources":["../../src/pushers/event-queue.pusher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAyB,MAAM,wBAAwB,CAAC;AAG7E,MAAM,OAAO,gBAAiB,SAAQ,YAA8B;
|
|
1
|
+
{"version":3,"file":"event-queue.pusher.js","sourceRoot":"","sources":["../../src/pushers/event-queue.pusher.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { OutboxPusher, type JobsOutboxEntity } from '@volontariapp/database';
|
|
2
2
|
import type { Logger } from '@volontariapp/logger';
|
|
3
|
-
import type {
|
|
3
|
+
import type { Redis } from 'ioredis';
|
|
4
4
|
export declare class JobsOutboxPusher extends OutboxPusher<JobsOutboxEntity> {
|
|
5
5
|
private readonly logger;
|
|
6
|
+
private readonly redis;
|
|
6
7
|
private readonly queues;
|
|
7
|
-
|
|
8
|
-
constructor(logger: Logger, redisConfig: RedisConfig);
|
|
8
|
+
constructor(logger: Logger, redis: Redis);
|
|
9
9
|
private getQueue;
|
|
10
10
|
pushElement(entity: JobsOutboxEntity): Promise<void>;
|
|
11
11
|
pushBulkElement(entities: JobsOutboxEntity[]): Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"jobs-outbox.pusher.d.ts","sourceRoot":"","sources":["../../src/pushers/jobs-outbox.pusher.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,KAAK,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC7E,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"jobs-outbox.pusher.d.ts","sourceRoot":"","sources":["../../src/pushers/jobs-outbox.pusher.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,KAAK,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC7E,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAErC,qBAAa,gBAAiB,SAAQ,YAAY,CAAC,gBAAgB,CAAC;IAIhE,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,KAAK;IAJxB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA4B;gBAGhC,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,KAAK;IAK/B,OAAO,CAAC,QAAQ;IAoBV,WAAW,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAuBpD,eAAe,CAAC,QAAQ,EAAE,gBAAgB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IA0C5D,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAY7B"}
|
|
@@ -2,26 +2,19 @@ import { Queue } from 'bullmq';
|
|
|
2
2
|
import { OutboxPusher } from '@volontariapp/database';
|
|
3
3
|
export class JobsOutboxPusher extends OutboxPusher {
|
|
4
4
|
logger;
|
|
5
|
+
redis;
|
|
5
6
|
queues = new Map();
|
|
6
|
-
|
|
7
|
-
constructor(logger, redisConfig) {
|
|
7
|
+
constructor(logger, redis) {
|
|
8
8
|
super();
|
|
9
9
|
this.logger = logger;
|
|
10
|
-
this.
|
|
11
|
-
host: redisConfig.host,
|
|
12
|
-
port: redisConfig.port,
|
|
13
|
-
password: redisConfig.password,
|
|
14
|
-
db: redisConfig.dbIndex,
|
|
15
|
-
keyPrefix: redisConfig.keyPrefix,
|
|
16
|
-
maxRetriesPerRequest: null,
|
|
17
|
-
};
|
|
10
|
+
this.redis = redis;
|
|
18
11
|
}
|
|
19
12
|
getQueue(targetService) {
|
|
20
13
|
let queue = this.queues.get(targetService);
|
|
21
14
|
if (!queue) {
|
|
22
15
|
this.logger.debug(`Creating new BullMQ queue for service: ${targetService}`);
|
|
23
16
|
queue = new Queue(targetService, {
|
|
24
|
-
connection: this.
|
|
17
|
+
connection: this.redis,
|
|
25
18
|
defaultJobOptions: {
|
|
26
19
|
attempts: 3,
|
|
27
20
|
backoff: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"jobs-outbox.pusher.js","sourceRoot":"","sources":["../../src/pushers/jobs-outbox.pusher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAoB,MAAM,QAAQ,CAAC;AACjD,OAAO,EAAE,YAAY,EAAyB,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"jobs-outbox.pusher.js","sourceRoot":"","sources":["../../src/pushers/jobs-outbox.pusher.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,20 +3,24 @@ import { databaseMapper, EventQueueModel, EventQueueEntity, OutboxStatus, } from
|
|
|
3
3
|
import { testDataSource, initializeTestDb, closeTestDb } from '../../data-source.js';
|
|
4
4
|
import { EventQueueConsumer } from '../../../consumers/event-queue.consumer.js';
|
|
5
5
|
import { TestEventQueueRepository } from '../../utils/repositories/event-queue-test.repository.js';
|
|
6
|
-
import { makeLoggerMock } from '../../utils/helpers/logger-mock.helper.js';
|
|
6
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
7
7
|
import { EventQueuePusher } from '../../../pushers/event-queue.pusher.js';
|
|
8
|
+
import { createTestRedisConnection } from '../../redis-config.js';
|
|
8
9
|
describe('EventQueueConsumer (Integration)', () => {
|
|
9
10
|
let consumer;
|
|
10
11
|
let repository;
|
|
11
12
|
let pusher;
|
|
13
|
+
let redis;
|
|
12
14
|
const logger = makeLoggerMock();
|
|
13
15
|
beforeAll(async () => {
|
|
14
16
|
await initializeTestDb();
|
|
15
17
|
databaseMapper.registerBidirectional(EventQueueModel, EventQueueEntity);
|
|
16
18
|
repository = testDataSource.getRepository(EventQueueModel);
|
|
17
|
-
|
|
19
|
+
redis = createTestRedisConnection();
|
|
20
|
+
pusher = new EventQueuePusher(logger, redis);
|
|
18
21
|
});
|
|
19
22
|
afterAll(async () => {
|
|
23
|
+
await redis.quit();
|
|
20
24
|
await closeTestDb();
|
|
21
25
|
});
|
|
22
26
|
beforeEach(async () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-queue.consumer.int.spec.js","sourceRoot":"","sources":["../../../../src/test/consumers/event/event-queue.consumer.int.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAC5F,OAAO,EACL,cAAc,EACd,eAAe,EACf,gBAAgB,EAChB,YAAY,GACb,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"event-queue.consumer.int.spec.js","sourceRoot":"","sources":["../../../../src/test/consumers/event/event-queue.consumer.int.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { describe, expect, it, beforeEach, jest, afterEach } from '@jest/globals';
|
|
2
2
|
import { EventQueueConsumer } from '../../../consumers/event-queue.consumer.js';
|
|
3
|
-
import { makeEventQueueConsumerRepositoryMock, } from '../../utils/helpers/event-queue-repository-mock.helper.js';
|
|
4
|
-
import { makeLoggerMock } from '../../utils/helpers/logger-mock.helper.js';
|
|
5
|
-
import { makeEventQueuePusherMock, } from '../../utils/helpers/event-queue-pusher-mock.helper.js';
|
|
3
|
+
import { makeEventQueueConsumerRepositoryMock, } from '../../utils/helpers/event/event-queue-repository-mock.helper.js';
|
|
4
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
5
|
+
import { makeEventQueuePusherMock, } from '../../utils/helpers/event/event-queue-pusher-mock.helper.js';
|
|
6
6
|
import { OutboxStatus } from '@volontariapp/database';
|
|
7
7
|
describe('EventQueueConsumer (Unit)', () => {
|
|
8
8
|
let consumer;
|
|
@@ -38,10 +38,11 @@ describe('EventQueueConsumer (Unit)', () => {
|
|
|
38
38
|
const dispatcher = consumer
|
|
39
39
|
.outboxDispatcher;
|
|
40
40
|
const completedSpy = jest.spyOn(dispatcher, 'markAsCompleted');
|
|
41
|
+
const pushSpy = jest.spyOn(pusher, 'pushElement');
|
|
41
42
|
await consumer.processItems(entities);
|
|
42
|
-
expect(
|
|
43
|
-
expect(
|
|
44
|
-
expect(
|
|
43
|
+
expect(pushSpy).toHaveBeenCalledTimes(2);
|
|
44
|
+
expect(pushSpy).toHaveBeenCalledWith(expect.objectContaining({ id: '1' }));
|
|
45
|
+
expect(pushSpy).toHaveBeenCalledWith(expect.objectContaining({ id: '2' }));
|
|
45
46
|
expect(completedSpy).toHaveBeenCalledTimes(2);
|
|
46
47
|
expect(completedSpy).toHaveBeenCalledWith(expect.objectContaining({ id: '1' }));
|
|
47
48
|
expect(completedSpy).toHaveBeenCalledWith(expect.objectContaining({ id: '2' }));
|
|
@@ -49,12 +50,13 @@ describe('EventQueueConsumer (Unit)', () => {
|
|
|
49
50
|
it('should mark items as failed if pushing throws error', async () => {
|
|
50
51
|
const entities = [{ id: '1', status: OutboxStatus.PROCESSING }];
|
|
51
52
|
const error = new Error('Redis connection lost');
|
|
52
|
-
pusher
|
|
53
|
+
const pushSpy = jest.spyOn(pusher, 'pushElement').mockRejectedValueOnce(error);
|
|
53
54
|
const dispatcher = consumer
|
|
54
55
|
.outboxDispatcher;
|
|
55
56
|
const failedSpy = jest.spyOn(dispatcher, 'markAsFailed');
|
|
56
57
|
const completedSpy = jest.spyOn(dispatcher, 'markAsCompleted');
|
|
57
58
|
await consumer.processItems(entities);
|
|
59
|
+
expect(pushSpy).toHaveBeenCalledWith(expect.objectContaining({ id: '1' }));
|
|
58
60
|
expect(completedSpy).not.toHaveBeenCalled();
|
|
59
61
|
expect(failedSpy).toHaveBeenCalledWith(expect.objectContaining({ id: entities[0].id }), 'Redis connection lost');
|
|
60
62
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-queue.consumer.unit.spec.js","sourceRoot":"","sources":["../../../../src/test/consumers/event/event-queue.consumer.unit.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAC;AAChF,OAAO,EACL,oCAAoC,GAErC,MAAM,
|
|
1
|
+
{"version":3,"file":"event-queue.consumer.unit.spec.js","sourceRoot":"","sources":["../../../../src/test/consumers/event/event-queue.consumer.unit.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,22 +3,25 @@ import { databaseMapper, JobsOutboxModel, JobsOutboxEntity, OutboxStatus, } from
|
|
|
3
3
|
import { testDataSource, initializeTestDb, closeTestDb } from '../../data-source.js';
|
|
4
4
|
import { JobsOutboxConsumer } from '../../../consumers/jobs-outbox.consumer.js';
|
|
5
5
|
import { TestJobsOutboxRepository } from '../../utils/repositories/jobs-outbox-test.repository.js';
|
|
6
|
-
import { makeLoggerMock } from '../../utils/helpers/logger-mock.helper.js';
|
|
6
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
7
7
|
import { JobsOutboxPusher } from '../../../pushers/jobs-outbox.pusher.js';
|
|
8
|
-
import {
|
|
8
|
+
import { createTestRedisConnection } from '../../redis-config.js';
|
|
9
9
|
describe('JobsOutboxConsumer (Integration)', () => {
|
|
10
10
|
let consumer;
|
|
11
11
|
let repository;
|
|
12
12
|
let pusher;
|
|
13
|
+
let redis;
|
|
13
14
|
const logger = makeLoggerMock();
|
|
14
15
|
beforeAll(async () => {
|
|
15
16
|
await initializeTestDb();
|
|
16
17
|
databaseMapper.registerBidirectional(JobsOutboxModel, JobsOutboxEntity);
|
|
17
18
|
repository = testDataSource.getRepository(JobsOutboxModel);
|
|
18
|
-
|
|
19
|
+
redis = createTestRedisConnection();
|
|
20
|
+
pusher = new JobsOutboxPusher(logger, redis);
|
|
19
21
|
});
|
|
20
22
|
afterAll(async () => {
|
|
21
23
|
await pusher.close();
|
|
24
|
+
await redis.quit();
|
|
22
25
|
await closeTestDb();
|
|
23
26
|
});
|
|
24
27
|
beforeEach(async () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"jobs-outbox.consumer.int.spec.js","sourceRoot":"","sources":["../../../../src/test/consumers/jobs/jobs-outbox.consumer.int.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAC5F,OAAO,EACL,cAAc,EACd,eAAe,EACf,gBAAgB,EAChB,YAAY,GACb,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"jobs-outbox.consumer.int.spec.js","sourceRoot":"","sources":["../../../../src/test/consumers/jobs/jobs-outbox.consumer.int.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { describe, expect, it, beforeEach, jest, afterEach } from '@jest/globals';
|
|
2
2
|
import { JobsOutboxConsumer } from '../../../consumers/jobs-outbox.consumer.js';
|
|
3
|
-
import { makeJobsOutboxConsumerRepositoryMock, } from '../../utils/helpers/jobs-outbox-repository-mock.helper.js';
|
|
4
|
-
import { makeLoggerMock } from '../../utils/helpers/logger-mock.helper.js';
|
|
5
|
-
import { makeJobsOutboxPusherMock, } from '../../utils/helpers/jobs-outbox-pusher-mock.helper.js';
|
|
3
|
+
import { makeJobsOutboxConsumerRepositoryMock, } from '../../utils/helpers/job/jobs-outbox-repository-mock.helper.js';
|
|
4
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
5
|
+
import { makeJobsOutboxPusherMock, } from '../../utils/helpers/job/jobs-outbox-pusher-mock.helper.js';
|
|
6
6
|
import { OutboxStatus } from '@volontariapp/database';
|
|
7
7
|
describe('JobsOutboxConsumer (Unit)', () => {
|
|
8
8
|
let consumer;
|
|
@@ -21,7 +21,10 @@ describe('JobsOutboxConsumer (Unit)', () => {
|
|
|
21
21
|
expect(consumer).toBeDefined();
|
|
22
22
|
});
|
|
23
23
|
it('fetchPendingItems() should delegate to repository and return results', async () => {
|
|
24
|
-
const mockEntities = [
|
|
24
|
+
const mockEntities = [
|
|
25
|
+
{ id: '1' },
|
|
26
|
+
{ id: '2' },
|
|
27
|
+
];
|
|
25
28
|
const toEntitiesSpy = jest.spyOn(repository, 'toEntities').mockReturnValue(mockEntities);
|
|
26
29
|
const executeInTransactionSpy = jest.spyOn(repository, 'executeInTransaction');
|
|
27
30
|
const result = await consumer.fetchPendingItems();
|
|
@@ -38,24 +41,28 @@ describe('JobsOutboxConsumer (Unit)', () => {
|
|
|
38
41
|
const dispatcher = consumer
|
|
39
42
|
.outboxDispatcher;
|
|
40
43
|
const completedSpy = jest.spyOn(dispatcher, 'markAsCompleted');
|
|
44
|
+
const pushSpy = jest.spyOn(pusher, 'pushElement');
|
|
41
45
|
await consumer.processItems(entities);
|
|
42
|
-
expect(
|
|
43
|
-
expect(
|
|
44
|
-
expect(
|
|
46
|
+
expect(pushSpy).toHaveBeenCalledTimes(2);
|
|
47
|
+
expect(pushSpy).toHaveBeenCalledWith(expect.objectContaining({ id: '1' }));
|
|
48
|
+
expect(pushSpy).toHaveBeenCalledWith(expect.objectContaining({ id: '2' }));
|
|
45
49
|
const spyMock = completedSpy;
|
|
46
50
|
expect(spyMock).toHaveBeenCalledTimes(2);
|
|
47
51
|
expect(spyMock).toHaveBeenCalledWith(expect.objectContaining({ id: '1' }));
|
|
48
52
|
expect(spyMock).toHaveBeenCalledWith(expect.objectContaining({ id: '2' }));
|
|
49
53
|
});
|
|
50
54
|
it('should mark items as failed if pushing throws error', async () => {
|
|
51
|
-
const entities = [
|
|
55
|
+
const entities = [
|
|
56
|
+
{ id: '1', status: OutboxStatus.PROCESSING },
|
|
57
|
+
];
|
|
52
58
|
const error = new Error('Redis connection lost');
|
|
53
|
-
pusher
|
|
59
|
+
const pushSpy = jest.spyOn(pusher, 'pushElement').mockRejectedValueOnce(error);
|
|
54
60
|
const dispatcher = consumer
|
|
55
61
|
.outboxDispatcher;
|
|
56
62
|
const failedSpy = jest.spyOn(dispatcher, 'markAsFailed');
|
|
57
63
|
const completedSpy = jest.spyOn(dispatcher, 'markAsCompleted');
|
|
58
64
|
await consumer.processItems(entities);
|
|
65
|
+
expect(pushSpy).toHaveBeenCalledTimes(1);
|
|
59
66
|
expect(completedSpy).not.toHaveBeenCalled();
|
|
60
67
|
expect(failedSpy).toHaveBeenCalledWith(expect.objectContaining({ id: entities[0].id }), 'Redis connection lost');
|
|
61
68
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"jobs-outbox.consumer.unit.spec.js","sourceRoot":"","sources":["../../../../src/test/consumers/jobs/jobs-outbox.consumer.unit.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAC;AAChF,OAAO,EACL,oCAAoC,GAErC,MAAM,
|
|
1
|
+
{"version":3,"file":"jobs-outbox.consumer.unit.spec.js","sourceRoot":"","sources":["../../../../src/test/consumers/jobs/jobs-outbox.consumer.unit.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,7 +3,7 @@ import { databaseMapper, EventQueueModel, EventQueueEntity, OutboxStatus, } from
|
|
|
3
3
|
import { testDataSource, initializeTestDb, closeTestDb } from '../../data-source.js';
|
|
4
4
|
import { EventQueueDispatcher } from '../../../dispatchers/event-queue.dispatcher.js';
|
|
5
5
|
import { TestEventQueueRepository } from '../../utils/repositories/event-queue-test.repository.js';
|
|
6
|
-
import { makeLoggerMock } from '../../utils/helpers/logger-mock.helper.js';
|
|
6
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
7
7
|
describe('EventQueueDispatcher (Integration)', () => {
|
|
8
8
|
let dispatcher;
|
|
9
9
|
let repository;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-queue.dispatcher.int.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/event/event-queue.dispatcher.int.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACtF,OAAO,EACL,cAAc,EACd,eAAe,EACf,gBAAgB,EAChB,YAAY,GACb,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACrF,OAAO,EAAE,oBAAoB,EAAE,MAAM,gDAAgD,CAAC;AACtF,OAAO,EAAE,wBAAwB,EAAE,MAAM,yDAAyD,CAAC;AACnG,OAAO,EAAE,cAAc,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"event-queue.dispatcher.int.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/event/event-queue.dispatcher.int.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,9 +2,9 @@ import { describe, expect, it, beforeEach, jest } from '@jest/globals';
|
|
|
2
2
|
import { UnprocessableEntityError } from '@volontariapp/errors';
|
|
3
3
|
import { EventQueueDispatcher } from '../../../dispatchers/event-queue.dispatcher.js';
|
|
4
4
|
import { OutboxStatus } from '@volontariapp/database';
|
|
5
|
-
import { makeLoggerMock } from '../../utils/helpers/logger-mock.helper.js';
|
|
6
|
-
import { makeEventQueueRepositoryMock } from '../../utils/helpers/event-queue-repository-mock.helper.js';
|
|
7
|
-
import { makeEventQueueEvent } from '../../utils/helpers/event-queue-event.helper.js';
|
|
5
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
6
|
+
import { makeEventQueueRepositoryMock } from '../../utils/helpers/event/event-queue-repository-mock.helper.js';
|
|
7
|
+
import { makeEventQueueEvent } from '../../utils/helpers/event/event-queue-event.helper.js';
|
|
8
8
|
describe('EventQueueDispatcher (Unit)', () => {
|
|
9
9
|
let dispatcher;
|
|
10
10
|
let repositoryMock;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-queue.dispatcher.unit.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/event/event-queue.dispatcher.unit.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,gDAAgD,CAAC;AACtF,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"event-queue.dispatcher.unit.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/event/event-queue.dispatcher.unit.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,8 +3,8 @@ import { databaseMapper, EventQueueModel, EventQueueEntity, OutboxStatus, } from
|
|
|
3
3
|
import { testDataSource, initializeTestDb, closeTestDb } from '../../data-source.js';
|
|
4
4
|
import { EventQueueDispatcher } from '../../../dispatchers/event-queue.dispatcher.js';
|
|
5
5
|
import { TestEventQueueRepository } from '../../utils/repositories/event-queue-test.repository.js';
|
|
6
|
-
import { makeLoggerMock } from '../../utils/helpers/logger-mock.helper.js';
|
|
7
|
-
import { EventType } from '../../utils/helpers/event-queue-generics.helper.js';
|
|
6
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
7
|
+
import { EventType } from '../../utils/helpers/event/event-queue-generics.helper.js';
|
|
8
8
|
describe('EventQueue Generics (Integration)', () => {
|
|
9
9
|
let dispatcher;
|
|
10
10
|
let repository;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-queue.generics.int.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/event/event-queue.generics.int.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACtF,OAAO,EACL,cAAc,EACd,eAAe,EACf,gBAAgB,EAChB,YAAY,GACb,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACrF,OAAO,EAAE,oBAAoB,EAAE,MAAM,gDAAgD,CAAC;AACtF,OAAO,EAAE,wBAAwB,EAAE,MAAM,yDAAyD,CAAC;AACnG,OAAO,EAAE,cAAc,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"event-queue.generics.int.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/event/event-queue.generics.int.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,7 +3,7 @@ import { databaseMapper, JobsOutboxModel, JobsOutboxEntity, OutboxStatus, } from
|
|
|
3
3
|
import { testDataSource, initializeTestDb, closeTestDb } from '../../data-source.js';
|
|
4
4
|
import { JobsOutboxDispatcher } from '../../../dispatchers/jobs-outbox.dispatcher.js';
|
|
5
5
|
import { TestJobsOutboxRepository } from '../../utils/repositories/jobs-outbox-test.repository.js';
|
|
6
|
-
import { makeLoggerMock } from '../../utils/helpers/logger-mock.helper.js';
|
|
6
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
7
7
|
describe('JobsOutboxDispatcher (Integration)', () => {
|
|
8
8
|
let dispatcher;
|
|
9
9
|
let repository;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"jobs-outbox.dispatcher.int.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/jobs/jobs-outbox.dispatcher.int.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACtF,OAAO,EACL,cAAc,EACd,eAAe,EACf,gBAAgB,EAChB,YAAY,GACb,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACrF,OAAO,EAAE,oBAAoB,EAAE,MAAM,gDAAgD,CAAC;AACtF,OAAO,EAAE,wBAAwB,EAAE,MAAM,yDAAyD,CAAC;AACnG,OAAO,EAAE,cAAc,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"jobs-outbox.dispatcher.int.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/jobs/jobs-outbox.dispatcher.int.spec.ts"],"names":[],"mappings":"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"}
|