@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
|
@@ -2,9 +2,9 @@ import { describe, expect, it, beforeEach, jest, afterEach } from '@jest/globals
|
|
|
2
2
|
import { UnprocessableEntityError } from '@volontariapp/errors';
|
|
3
3
|
import { JobsOutboxDispatcher } from '../../../dispatchers/jobs-outbox.dispatcher.js';
|
|
4
4
|
import { OutboxStatus } from '@volontariapp/database';
|
|
5
|
-
import { makeLoggerMock } from '../../utils/helpers/logger-mock.helper.js';
|
|
6
|
-
import { makeJobsOutboxRepositoryMock, } from '../../utils/helpers/jobs-outbox-repository-mock.helper.js';
|
|
7
|
-
import { makeJobsOutboxEvent } from '../../utils/helpers/jobs-outbox-event.helper.js';
|
|
5
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
6
|
+
import { makeJobsOutboxRepositoryMock, } from '../../utils/helpers/job/jobs-outbox-repository-mock.helper.js';
|
|
7
|
+
import { makeJobsOutboxEvent } from '../../utils/helpers/job/jobs-outbox-event.helper.js';
|
|
8
8
|
describe('JobsOutboxDispatcher (Unit)', () => {
|
|
9
9
|
let dispatcher;
|
|
10
10
|
let repositoryMock;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"jobs-outbox.dispatcher.unit.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/jobs/jobs-outbox.dispatcher.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,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":"jobs-outbox.dispatcher.unit.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/jobs/jobs-outbox.dispatcher.unit.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,8 +3,8 @@ 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';
|
|
7
|
-
import { JobType } from '../../utils/helpers/jobs-outbox-generics.helper.js';
|
|
6
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
7
|
+
import { JobType } from '../../utils/helpers/job/jobs-outbox-generics.helper.js';
|
|
8
8
|
describe('JobsOutbox Generics (Integration)', () => {
|
|
9
9
|
let dispatcher;
|
|
10
10
|
let repository;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"jobs-outbox.generics.int.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/jobs/jobs-outbox.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":"jobs-outbox.generics.int.spec.js","sourceRoot":"","sources":["../../../../src/test/dispatchers/jobs/jobs-outbox.generics.int.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event-flow.full.int.spec.d.ts","sourceRoot":"","sources":["../../../../src/test/pushers/event/event-flow.full.int.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
import { describe, expect, it, beforeAll, afterAll, beforeEach } from '@jest/globals';
|
|
2
|
+
import { databaseMapper, EventQueueModel, EventQueueEntity, OutboxStatus, } from '@volontariapp/database';
|
|
3
|
+
import { Redis } from 'ioredis';
|
|
4
|
+
import { testDataSource, initializeTestDb, closeTestDb } from '../../data-source.js';
|
|
5
|
+
import { EventQueueConsumer } from '../../../consumers/event-queue.consumer.js';
|
|
6
|
+
import { EventQueuePusher } from '../../../pushers/event-queue.pusher.js';
|
|
7
|
+
import { TestEventQueueRepository } from '../../utils/repositories/event-queue-test.repository.js';
|
|
8
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
9
|
+
import { clearTestRedis, testRedisOptions } from '../../redis-config.js';
|
|
10
|
+
import { ServiceType } from '@volontariapp/shared';
|
|
11
|
+
describe('Event Full Flow (Integration)', () => {
|
|
12
|
+
let modelRepository;
|
|
13
|
+
let testRepository;
|
|
14
|
+
let pusher;
|
|
15
|
+
let consumer;
|
|
16
|
+
let redis;
|
|
17
|
+
const logger = makeLoggerMock();
|
|
18
|
+
beforeAll(async () => {
|
|
19
|
+
await initializeTestDb();
|
|
20
|
+
databaseMapper.registerBidirectional(EventQueueModel, EventQueueEntity);
|
|
21
|
+
modelRepository = testDataSource.getRepository(EventQueueModel);
|
|
22
|
+
redis = new Redis({ ...testRedisOptions, lazyConnect: true });
|
|
23
|
+
await redis.connect();
|
|
24
|
+
testRepository = new TestEventQueueRepository(modelRepository);
|
|
25
|
+
pusher = new EventQueuePusher(logger, redis);
|
|
26
|
+
consumer = new EventQueueConsumer(logger, testRepository, 200, pusher);
|
|
27
|
+
});
|
|
28
|
+
afterAll(async () => {
|
|
29
|
+
await redis.quit();
|
|
30
|
+
await closeTestDb();
|
|
31
|
+
});
|
|
32
|
+
beforeEach(async () => {
|
|
33
|
+
await modelRepository.createQueryBuilder().delete().execute();
|
|
34
|
+
await clearTestRedis();
|
|
35
|
+
});
|
|
36
|
+
it('should insert an event, fetch via consumer, push to Redis, and mark as COMPLETED', async () => {
|
|
37
|
+
const eventId = '00000000-0000-0000-0000-aabbccddeef0';
|
|
38
|
+
await modelRepository.save(modelRepository.create({
|
|
39
|
+
id: eventId,
|
|
40
|
+
type: 'user.created',
|
|
41
|
+
emitter: 'ms-user',
|
|
42
|
+
status: OutboxStatus.PENDING,
|
|
43
|
+
payload: { after: { userId: 'u-42' } },
|
|
44
|
+
version: 1,
|
|
45
|
+
attempts: 0,
|
|
46
|
+
targetServices: [ServiceType.POST, ServiceType.SOCIAL],
|
|
47
|
+
createdAt: new Date(),
|
|
48
|
+
updatedAt: new Date(),
|
|
49
|
+
}));
|
|
50
|
+
const pendingItems = await consumer.fetchPendingItems();
|
|
51
|
+
expect(pendingItems).toHaveLength(1);
|
|
52
|
+
expect(pendingItems[0].id).toBe(eventId);
|
|
53
|
+
const dbAfterFetch = await modelRepository.findOneByOrFail({ id: eventId });
|
|
54
|
+
expect(dbAfterFetch.status).toBe(OutboxStatus.PROCESSING);
|
|
55
|
+
await consumer.processItems(pendingItems);
|
|
56
|
+
const dbAfterProcess = await modelRepository.findOneByOrFail({ id: eventId });
|
|
57
|
+
expect(dbAfterProcess.status).toBe(OutboxStatus.COMPLETED);
|
|
58
|
+
const postStream = await redis.xrange('stream:post', '-', '+');
|
|
59
|
+
const socialStream = await redis.xrange('stream:social', '-', '+');
|
|
60
|
+
expect(postStream).toHaveLength(1);
|
|
61
|
+
expect(socialStream).toHaveLength(1);
|
|
62
|
+
const [, postFields] = postStream[0];
|
|
63
|
+
const eventIndex = postFields.indexOf('event');
|
|
64
|
+
const rawMessage = postFields[eventIndex + 1];
|
|
65
|
+
const message = JSON.parse(rawMessage);
|
|
66
|
+
expect(message.id).toBe(eventId);
|
|
67
|
+
expect(message.type).toBe('user.created');
|
|
68
|
+
expect(message.emitter).toBe('ms-user');
|
|
69
|
+
expect(message.version).toBe(1);
|
|
70
|
+
expect(message.payload).toEqual({ after: { userId: 'u-42' } });
|
|
71
|
+
expect(typeof message.createdAt).toBe('string');
|
|
72
|
+
});
|
|
73
|
+
it('should push 100 events in bulk and verify total stream entries across services', async () => {
|
|
74
|
+
const count = 100;
|
|
75
|
+
const services = [ServiceType.POST, ServiceType.USER, ServiceType.SOCIAL];
|
|
76
|
+
const models = Array.from({ length: count }).map((_, i) => modelRepository.create({
|
|
77
|
+
id: `00000000-0000-0000-0000-${String(i).padStart(12, '0')}`,
|
|
78
|
+
type: 'stress.event',
|
|
79
|
+
emitter: 'ms-stress',
|
|
80
|
+
status: OutboxStatus.PENDING,
|
|
81
|
+
payload: { after: { index: i } },
|
|
82
|
+
version: 1,
|
|
83
|
+
attempts: 0,
|
|
84
|
+
targetServices: [services[i % services.length]],
|
|
85
|
+
createdAt: new Date(Date.now() + i),
|
|
86
|
+
updatedAt: new Date(),
|
|
87
|
+
}));
|
|
88
|
+
await modelRepository.save(models);
|
|
89
|
+
const pending = await consumer.fetchPendingItems();
|
|
90
|
+
await consumer.processItems(pending);
|
|
91
|
+
const lengths = await Promise.all(services.map((s) => redis.xlen(`stream:${s}`)));
|
|
92
|
+
const totalInStreams = lengths.reduce((sum, l) => sum + l, 0);
|
|
93
|
+
expect(totalInStreams).toBe(count);
|
|
94
|
+
const processingCount = await modelRepository.count({
|
|
95
|
+
where: { status: OutboxStatus.PROCESSING },
|
|
96
|
+
});
|
|
97
|
+
expect(processingCount).toBe(0);
|
|
98
|
+
});
|
|
99
|
+
it('should mark event as FAILED when pusher throws, preserving stream integrity', async () => {
|
|
100
|
+
const goodId = '00000000-0000-0000-0000-000000000001';
|
|
101
|
+
const badId = '00000000-0000-0000-0000-000000000002';
|
|
102
|
+
await modelRepository.save([
|
|
103
|
+
modelRepository.create({
|
|
104
|
+
id: goodId,
|
|
105
|
+
type: 'user.created',
|
|
106
|
+
emitter: 'ms-user',
|
|
107
|
+
status: OutboxStatus.PROCESSING,
|
|
108
|
+
payload: { after: { userId: 'u-1' } },
|
|
109
|
+
version: 1,
|
|
110
|
+
attempts: 0,
|
|
111
|
+
targetServices: [ServiceType.POST],
|
|
112
|
+
createdAt: new Date(),
|
|
113
|
+
updatedAt: new Date(),
|
|
114
|
+
}),
|
|
115
|
+
modelRepository.create({
|
|
116
|
+
id: badId,
|
|
117
|
+
type: 'user.created',
|
|
118
|
+
emitter: 'ms-user',
|
|
119
|
+
status: OutboxStatus.PROCESSING,
|
|
120
|
+
payload: { after: { userId: 'u-2' } },
|
|
121
|
+
version: 1,
|
|
122
|
+
attempts: 0,
|
|
123
|
+
targetServices: [ServiceType.POST],
|
|
124
|
+
createdAt: new Date(),
|
|
125
|
+
updatedAt: new Date(),
|
|
126
|
+
}),
|
|
127
|
+
]);
|
|
128
|
+
const goodEntity = await testRepository.findOneOrFail({ id: goodId });
|
|
129
|
+
const badEntity = await testRepository.findOneOrFail({ id: badId });
|
|
130
|
+
const brokenRedis = new Redis({ ...testRedisOptions, lazyConnect: true });
|
|
131
|
+
await brokenRedis.connect();
|
|
132
|
+
brokenRedis.disconnect();
|
|
133
|
+
const failingPusher = new EventQueuePusher(logger, brokenRedis);
|
|
134
|
+
const failingConsumer = new EventQueueConsumer(logger, testRepository, 10, failingPusher);
|
|
135
|
+
await consumer.processItems([goodEntity]);
|
|
136
|
+
await failingConsumer.processItems([badEntity]);
|
|
137
|
+
const goodDb = await modelRepository.findOneByOrFail({ id: goodId });
|
|
138
|
+
const badDb = await modelRepository.findOneByOrFail({ id: badId });
|
|
139
|
+
expect(goodDb.status).toBe(OutboxStatus.COMPLETED);
|
|
140
|
+
expect(badDb.status).toBe(OutboxStatus.FAILED);
|
|
141
|
+
const postStream = await redis.xrange('stream:post', '-', '+');
|
|
142
|
+
expect(postStream).toHaveLength(1);
|
|
143
|
+
const [, fields] = postStream[0];
|
|
144
|
+
const raw = fields[fields.indexOf('event') + 1];
|
|
145
|
+
const msg = JSON.parse(raw);
|
|
146
|
+
expect(msg.id).toBe(goodId);
|
|
147
|
+
});
|
|
148
|
+
});
|
|
149
|
+
//# sourceMappingURL=event-flow.full.int.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event-flow.full.int.spec.js","sourceRoot":"","sources":["../../../../src/test/pushers/event/event-flow.full.int.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event-queue.pusher.int.spec.d.ts","sourceRoot":"","sources":["../../../../src/test/pushers/event/event-queue.pusher.int.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { describe, expect, it, beforeEach, afterEach, jest } from '@jest/globals';
|
|
2
|
+
import { EventQueuePusher } from '../../../pushers/event-queue.pusher.js';
|
|
3
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
4
|
+
import { makeEventQueueEvent } from '../../utils/helpers/event/event-queue-event.helper.js';
|
|
5
|
+
import { clearTestRedis, testRedisOptions } from '../../redis-config.js';
|
|
6
|
+
import { ServiceType } from '@volontariapp/shared';
|
|
7
|
+
import { Redis } from 'ioredis';
|
|
8
|
+
describe('EventQueuePusher (Integration)', () => {
|
|
9
|
+
let pusher;
|
|
10
|
+
let redis;
|
|
11
|
+
const loggerMock = makeLoggerMock();
|
|
12
|
+
beforeEach(async () => {
|
|
13
|
+
redis = new Redis({
|
|
14
|
+
...testRedisOptions,
|
|
15
|
+
enableOfflineQueue: false,
|
|
16
|
+
});
|
|
17
|
+
await redis.connect();
|
|
18
|
+
await clearTestRedis();
|
|
19
|
+
pusher = new EventQueuePusher(loggerMock, redis);
|
|
20
|
+
});
|
|
21
|
+
afterEach(async () => {
|
|
22
|
+
if (redis.status !== 'end') {
|
|
23
|
+
await redis.quit();
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
it('should push event to multiple streams in Redis', async () => {
|
|
27
|
+
const event = makeEventQueueEvent({
|
|
28
|
+
id: 'evt-1',
|
|
29
|
+
type: 'user.created',
|
|
30
|
+
emitter: ServiceType.USER,
|
|
31
|
+
targetServices: [ServiceType.POST, ServiceType.SOCIAL],
|
|
32
|
+
payload: { after: { userId: '123' } },
|
|
33
|
+
});
|
|
34
|
+
await pusher.pushElement(event);
|
|
35
|
+
const postStream = await redis.xrange('stream:post', '-', '+');
|
|
36
|
+
const socialStream = await redis.xrange('stream:social', '-', '+');
|
|
37
|
+
expect(postStream).toHaveLength(1);
|
|
38
|
+
expect(socialStream).toHaveLength(1);
|
|
39
|
+
const postEntry = postStream[0][1];
|
|
40
|
+
expect(postEntry).toContain('event');
|
|
41
|
+
const eventJson = postEntry[postEntry.indexOf('event') + 1];
|
|
42
|
+
const parsedEvent = JSON.parse(eventJson);
|
|
43
|
+
expect(parsedEvent.id).toBe('evt-1');
|
|
44
|
+
});
|
|
45
|
+
describe('Stress Tests', () => {
|
|
46
|
+
it('should handle 500 events pushed in bulk across multiple services', async () => {
|
|
47
|
+
const count = 500;
|
|
48
|
+
const services = [ServiceType.POST, ServiceType.USER, ServiceType.SOCIAL, ServiceType.EVENT];
|
|
49
|
+
const events = Array.from({ length: count }).map((_, i) => makeEventQueueEvent({
|
|
50
|
+
id: `stress-${i.toString()}`,
|
|
51
|
+
targetServices: [services[i % services.length]],
|
|
52
|
+
}));
|
|
53
|
+
await pusher.pushBulkElement(events);
|
|
54
|
+
const results = await Promise.all(services.map((s) => redis.xlen(`stream:${s}`)));
|
|
55
|
+
const totalInStreams = results.reduce((a, b) => a + b, 0);
|
|
56
|
+
expect(totalInStreams).toBe(count);
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
describe('Resilience Tests', () => {
|
|
60
|
+
it('should recover after a temporary Redis failure', async () => {
|
|
61
|
+
const event1 = makeEventQueueEvent({ id: 'evt-1', targetServices: [ServiceType.POST] });
|
|
62
|
+
const event2 = makeEventQueueEvent({ id: 'evt-2', targetServices: [ServiceType.POST] });
|
|
63
|
+
await pusher.pushElement(event1);
|
|
64
|
+
expect(await redis.xlen('stream:post')).toBe(1);
|
|
65
|
+
const loggerErrorSpy = jest.spyOn(loggerMock, 'error');
|
|
66
|
+
jest.spyOn(redis, 'pipeline').mockImplementationOnce(() => {
|
|
67
|
+
throw new Error('Redis connection lost');
|
|
68
|
+
});
|
|
69
|
+
await expect(pusher.pushElement(event2)).rejects.toThrow('Redis connection lost');
|
|
70
|
+
expect(loggerErrorSpy).toHaveBeenCalled();
|
|
71
|
+
await pusher.pushElement(event2);
|
|
72
|
+
expect(await redis.xlen('stream:post')).toBe(2);
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
//# sourceMappingURL=event-queue.pusher.int.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event-queue.pusher.int.spec.js","sourceRoot":"","sources":["../../../../src/test/pushers/event/event-queue.pusher.int.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event-queue.pusher.unit.spec.d.ts","sourceRoot":"","sources":["../../../../src/test/pushers/event/event-queue.pusher.unit.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
import { describe, expect, it, beforeEach, jest } from '@jest/globals';
|
|
2
|
+
import { makeRedisMock, makePipelineMock } from '../../utils/helpers/shared/redis-mock.helper.js';
|
|
3
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
4
|
+
import { makeEventQueueEvent } from '../../utils/helpers/event/event-queue-event.helper.js';
|
|
5
|
+
import { ServiceType } from '@volontariapp/shared';
|
|
6
|
+
import { EventQueuePusher } from '../../../pushers/event-queue.pusher.js';
|
|
7
|
+
describe('EventQueuePusher (Unit)', () => {
|
|
8
|
+
let pusher;
|
|
9
|
+
const loggerMock = makeLoggerMock();
|
|
10
|
+
const redisMock = makeRedisMock();
|
|
11
|
+
let pipelineSpy;
|
|
12
|
+
let loggerErrorSpy;
|
|
13
|
+
beforeEach(() => {
|
|
14
|
+
jest.clearAllMocks();
|
|
15
|
+
pipelineSpy = jest.spyOn(redisMock, 'pipeline');
|
|
16
|
+
loggerErrorSpy = jest.spyOn(loggerMock, 'error');
|
|
17
|
+
pusher = new EventQueuePusher(loggerMock, redisMock);
|
|
18
|
+
});
|
|
19
|
+
it('should be defined', () => {
|
|
20
|
+
expect(pusher).toBeDefined();
|
|
21
|
+
});
|
|
22
|
+
describe('pushElement', () => {
|
|
23
|
+
it('should push an event to all target service streams', async () => {
|
|
24
|
+
const entity = makeEventQueueEvent({
|
|
25
|
+
id: '1',
|
|
26
|
+
type: 'test.event',
|
|
27
|
+
emitter: ServiceType.SOCIAL,
|
|
28
|
+
targetServices: [ServiceType.POST, ServiceType.USER],
|
|
29
|
+
});
|
|
30
|
+
const mockPipeline = makePipelineMock();
|
|
31
|
+
mockPipeline.exec.mockResolvedValue([]);
|
|
32
|
+
pipelineSpy.mockReturnValue(mockPipeline);
|
|
33
|
+
const xaddSpy = jest.spyOn(mockPipeline, 'xadd');
|
|
34
|
+
const execSpy = jest.spyOn(mockPipeline, 'exec');
|
|
35
|
+
await pusher.pushElement(entity);
|
|
36
|
+
expect(pipelineSpy).toHaveBeenCalled();
|
|
37
|
+
expect(xaddSpy).toHaveBeenCalledTimes(2);
|
|
38
|
+
expect(xaddSpy).toHaveBeenCalledWith('stream:post', 'MAXLEN', '~', 10000, '*', 'event', expect.any(String));
|
|
39
|
+
expect(xaddSpy).toHaveBeenCalledWith('stream:user', 'MAXLEN', '~', 10000, '*', 'event', expect.any(String));
|
|
40
|
+
expect(execSpy).toHaveBeenCalled();
|
|
41
|
+
});
|
|
42
|
+
it('should throw and log error if pipeline fails', async () => {
|
|
43
|
+
const entity = makeEventQueueEvent({ id: '1', targetServices: [ServiceType.POST] });
|
|
44
|
+
const error = new Error('Redis error');
|
|
45
|
+
const mockPipeline = makePipelineMock();
|
|
46
|
+
mockPipeline.exec.mockRejectedValueOnce(error);
|
|
47
|
+
pipelineSpy.mockReturnValue(mockPipeline);
|
|
48
|
+
const execSpy = jest.spyOn(mockPipeline, 'exec');
|
|
49
|
+
await expect(pusher.pushElement(entity)).rejects.toThrow('Redis error');
|
|
50
|
+
expect(loggerErrorSpy).toHaveBeenCalledWith(expect.stringContaining('Failed to push event queue item 1'), expect.objectContaining({ error }));
|
|
51
|
+
expect(execSpy).toHaveBeenCalled();
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
describe('pushBulkElement', () => {
|
|
55
|
+
it('should push multiple events in a single pipeline', async () => {
|
|
56
|
+
const entities = [
|
|
57
|
+
makeEventQueueEvent({ id: '1', targetServices: [ServiceType.POST] }),
|
|
58
|
+
makeEventQueueEvent({ id: '2', targetServices: [ServiceType.USER] }),
|
|
59
|
+
];
|
|
60
|
+
const mockPipeline = makePipelineMock();
|
|
61
|
+
mockPipeline.exec.mockResolvedValue([]);
|
|
62
|
+
pipelineSpy.mockReturnValue(mockPipeline);
|
|
63
|
+
const xaddSpy = jest.spyOn(mockPipeline, 'xadd');
|
|
64
|
+
const execSpy = jest.spyOn(mockPipeline, 'exec');
|
|
65
|
+
await pusher.pushBulkElement(entities);
|
|
66
|
+
expect(xaddSpy).toHaveBeenCalledTimes(2);
|
|
67
|
+
expect(execSpy).toHaveBeenCalled();
|
|
68
|
+
});
|
|
69
|
+
it('should throw and log error if pipeline fails during bulk push', async () => {
|
|
70
|
+
const entities = [makeEventQueueEvent({ id: '1', targetServices: [ServiceType.POST] })];
|
|
71
|
+
const error = new Error('Bulk Redis error');
|
|
72
|
+
const mockPipeline = makePipelineMock();
|
|
73
|
+
mockPipeline.exec.mockRejectedValueOnce(error);
|
|
74
|
+
pipelineSpy.mockReturnValue(mockPipeline);
|
|
75
|
+
await expect(pusher.pushBulkElement(entities)).rejects.toThrow('Bulk Redis error');
|
|
76
|
+
expect(loggerErrorSpy).toHaveBeenCalledWith(expect.stringContaining('Failed to push bulk event queue items'), expect.objectContaining({ error }));
|
|
77
|
+
});
|
|
78
|
+
it('should call exec once even with many entities across multiple target services', async () => {
|
|
79
|
+
const entities = [
|
|
80
|
+
makeEventQueueEvent({
|
|
81
|
+
id: '1',
|
|
82
|
+
targetServices: [ServiceType.POST, ServiceType.USER, ServiceType.SOCIAL],
|
|
83
|
+
}),
|
|
84
|
+
makeEventQueueEvent({ id: '2', targetServices: [ServiceType.EVENT] }),
|
|
85
|
+
];
|
|
86
|
+
const mockPipeline = makePipelineMock();
|
|
87
|
+
mockPipeline.exec.mockResolvedValue([]);
|
|
88
|
+
pipelineSpy.mockReturnValue(mockPipeline);
|
|
89
|
+
const xaddSpy = jest.spyOn(mockPipeline, 'xadd');
|
|
90
|
+
const execSpy = jest.spyOn(mockPipeline, 'exec');
|
|
91
|
+
await pusher.pushBulkElement(entities);
|
|
92
|
+
expect(pipelineSpy).toHaveBeenCalledTimes(1);
|
|
93
|
+
expect(xaddSpy).toHaveBeenCalledTimes(4);
|
|
94
|
+
expect(execSpy).toHaveBeenCalledTimes(1);
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
describe('serialization', () => {
|
|
98
|
+
it('should serialize all required RedisEventMessage fields into the xadd payload', async () => {
|
|
99
|
+
const now = new Date('2025-01-01T12:00:00.000Z');
|
|
100
|
+
const entity = makeEventQueueEvent({
|
|
101
|
+
id: 'evt-serial-1',
|
|
102
|
+
type: 'user.created',
|
|
103
|
+
emitter: 'ms-user',
|
|
104
|
+
version: 2,
|
|
105
|
+
traceId: 'trace-abc',
|
|
106
|
+
targetServices: [ServiceType.POST],
|
|
107
|
+
payload: { after: { userId: '42' } },
|
|
108
|
+
createdAt: now,
|
|
109
|
+
});
|
|
110
|
+
const mockPipeline = makePipelineMock();
|
|
111
|
+
mockPipeline.exec.mockResolvedValue([]);
|
|
112
|
+
pipelineSpy.mockReturnValue(mockPipeline);
|
|
113
|
+
const xaddSpy = jest.spyOn(mockPipeline, 'xadd');
|
|
114
|
+
await pusher.pushElement(entity);
|
|
115
|
+
expect(xaddSpy).toHaveBeenCalledTimes(1);
|
|
116
|
+
const rawPayload = xaddSpy.mock.calls[0][6];
|
|
117
|
+
const parsed = JSON.parse(rawPayload);
|
|
118
|
+
expect(parsed.id).toBe('evt-serial-1');
|
|
119
|
+
expect(parsed.type).toBe('user.created');
|
|
120
|
+
expect(parsed.emitter).toBe('ms-user');
|
|
121
|
+
expect(parsed.traceId).toBe('trace-abc');
|
|
122
|
+
expect(parsed.version).toBe(2);
|
|
123
|
+
expect(parsed.createdAt).toBe('2025-01-01T12:00:00.000Z');
|
|
124
|
+
expect(parsed.payload).toEqual({ after: { userId: '42' } });
|
|
125
|
+
});
|
|
126
|
+
it('should omit traceId from serialized message when not set on entity', async () => {
|
|
127
|
+
const entity = makeEventQueueEvent({
|
|
128
|
+
id: 'evt-no-trace',
|
|
129
|
+
targetServices: [ServiceType.USER],
|
|
130
|
+
traceId: undefined,
|
|
131
|
+
});
|
|
132
|
+
const mockPipeline = makePipelineMock();
|
|
133
|
+
mockPipeline.exec.mockResolvedValue([]);
|
|
134
|
+
pipelineSpy.mockReturnValue(mockPipeline);
|
|
135
|
+
const xaddSpy = jest.spyOn(mockPipeline, 'xadd');
|
|
136
|
+
await pusher.pushElement(entity);
|
|
137
|
+
const rawPayload = xaddSpy.mock.calls[0][6];
|
|
138
|
+
const parsed = JSON.parse(rawPayload);
|
|
139
|
+
expect(parsed.traceId).toBeUndefined();
|
|
140
|
+
});
|
|
141
|
+
});
|
|
142
|
+
describe('edge cases', () => {
|
|
143
|
+
it('should return early and not call exec when targetServices is empty', async () => {
|
|
144
|
+
const entity = makeEventQueueEvent({ id: '1', targetServices: [] });
|
|
145
|
+
const mockPipeline = makePipelineMock();
|
|
146
|
+
pipelineSpy.mockReturnValue(mockPipeline);
|
|
147
|
+
const xaddSpy = jest.spyOn(mockPipeline, 'xadd');
|
|
148
|
+
const execSpy = jest.spyOn(mockPipeline, 'exec');
|
|
149
|
+
await pusher.pushElement(entity);
|
|
150
|
+
expect(xaddSpy).not.toHaveBeenCalled();
|
|
151
|
+
expect(execSpy).not.toHaveBeenCalled();
|
|
152
|
+
});
|
|
153
|
+
it('should throw and log error when pipeline returns partial errors', async () => {
|
|
154
|
+
const entity = makeEventQueueEvent({
|
|
155
|
+
id: '1',
|
|
156
|
+
targetServices: [ServiceType.POST, ServiceType.USER],
|
|
157
|
+
});
|
|
158
|
+
const partialError = new Error('MAXLEN overflow');
|
|
159
|
+
const mockPipeline = makePipelineMock();
|
|
160
|
+
mockPipeline.exec.mockResolvedValue([
|
|
161
|
+
[null, 'stream:post-id'],
|
|
162
|
+
[partialError, null],
|
|
163
|
+
]);
|
|
164
|
+
pipelineSpy.mockReturnValue(mockPipeline);
|
|
165
|
+
await expect(pusher.pushElement(entity)).rejects.toThrow('MAXLEN overflow');
|
|
166
|
+
expect(loggerErrorSpy).toHaveBeenCalled();
|
|
167
|
+
});
|
|
168
|
+
});
|
|
169
|
+
});
|
|
170
|
+
//# sourceMappingURL=event-queue.pusher.unit.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event-queue.pusher.unit.spec.js","sourceRoot":"","sources":["../../../../src/test/pushers/event/event-queue.pusher.unit.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobs-outbox.pusher.int.spec.d.ts","sourceRoot":"","sources":["../../../../src/test/pushers/jobs/jobs-outbox.pusher.int.spec.ts"],"names":[],"mappings":""}
|
package/dist/test/pushers/{jobs-outbox.pusher.int.spec.js → jobs/jobs-outbox.pusher.int.spec.js}
RENAMED
|
@@ -1,18 +1,23 @@
|
|
|
1
1
|
import { describe, expect, it, beforeEach, afterAll, afterEach } from '@jest/globals';
|
|
2
|
-
import { JobsOutboxPusher } from '
|
|
3
|
-
import { makeLoggerMock } from '
|
|
4
|
-
import { makeJobsOutboxEvent } from '
|
|
5
|
-
import {
|
|
2
|
+
import { JobsOutboxPusher } from '../../../pushers/jobs-outbox.pusher.js';
|
|
3
|
+
import { makeLoggerMock } from '../../utils/helpers/shared/logger-mock.helper.js';
|
|
4
|
+
import { makeJobsOutboxEvent } from '../../utils/helpers/job/jobs-outbox-event.helper.js';
|
|
5
|
+
import { createTestRedisConnection, testRedisOptions, clearTestRedis } from '../../redis-config.js';
|
|
6
6
|
import { Queue } from 'bullmq';
|
|
7
7
|
describe('JobsOutboxPusher (Integration)', () => {
|
|
8
8
|
let pusher;
|
|
9
|
+
let redis;
|
|
9
10
|
const logger = makeLoggerMock();
|
|
10
11
|
beforeEach(async () => {
|
|
11
12
|
await clearTestRedis();
|
|
12
|
-
|
|
13
|
+
redis = createTestRedisConnection();
|
|
14
|
+
pusher = new JobsOutboxPusher(logger, redis);
|
|
13
15
|
});
|
|
14
16
|
afterEach(async () => {
|
|
15
17
|
await pusher.close();
|
|
18
|
+
if (redis.status !== 'end') {
|
|
19
|
+
await redis.quit();
|
|
20
|
+
}
|
|
16
21
|
});
|
|
17
22
|
afterAll(async () => {
|
|
18
23
|
await clearTestRedis();
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobs-outbox.pusher.int.spec.js","sourceRoot":"","sources":["../../../../src/test/pushers/jobs/jobs-outbox.pusher.int.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobs-outbox.pusher.unit.spec.d.ts","sourceRoot":"","sources":["../../../../src/test/pushers/jobs/jobs-outbox.pusher.unit.spec.ts"],"names":[],"mappings":""}
|