@volontariapp/workers 0.1.0-snap-9f9da07 → 0.1.0-snap-104d75a

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.
@@ -10,6 +10,7 @@ export declare abstract class BaseWorker<K extends JobMessagingType> extends Wor
10
10
  constructor(auditRepo?: JobAuditRepository | undefined);
11
11
  process(job: Job<JobRegistry[K], void, K>, _token?: string): Promise<void>;
12
12
  protected abstract processJob(job: Job<JobRegistry[K], void, K>): Promise<void>;
13
+ private isJobAlreadyCompleted;
13
14
  private recordAuditStart;
14
15
  private recordAuditSuccess;
15
16
  private recordAuditFailure;
@@ -1 +1 @@
1
- {"version":3,"file":"base.worker.d.ts","sourceRoot":"","sources":["../../src/core/base.worker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAE9C,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,KAAK,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAC7E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAG3D,8BAAsB,UAAU,CAAC,CAAC,SAAS,gBAAgB,CAAE,SAAQ,UAAU;IAIjE,SAAS,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,kBAAkB;IAH7D,SAAS,CAAC,QAAQ,CAAC,MAAM,SAAkD;IAC3E,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAc;gBAElB,SAAS,CAAC,EAAE,kBAAkB,YAAA;IAIvD,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IA+BhF,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;YAEjE,gBAAgB;YA0BhB,kBAAkB;YAuBlB,kBAAkB;CA+BjC"}
1
+ {"version":3,"file":"base.worker.d.ts","sourceRoot":"","sources":["../../src/core/base.worker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAE9C,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,KAAK,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAC7E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAG3D,8BAAsB,UAAU,CAAC,CAAC,SAAS,gBAAgB,CAAE,SAAQ,UAAU;IAIjE,SAAS,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,kBAAkB;IAH7D,SAAS,CAAC,QAAQ,CAAC,MAAM,SAAkD;IAC3E,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAc;gBAElB,SAAS,CAAC,EAAE,kBAAkB,YAAA;IAIvD,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwChF,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;YAEjE,qBAAqB;YAerB,gBAAgB;YA0BhB,kBAAkB;YAsBlB,kBAAkB;CA8BjC"}
@@ -17,6 +17,14 @@ export class BaseWorker extends WorkerHost {
17
17
  workerId: this.workerId,
18
18
  });
19
19
  const startedAt = new Date();
20
+ const alreadyCompleted = await this.isJobAlreadyCompleted(job);
21
+ if (alreadyCompleted) {
22
+ this.logger.warn('Job already processed, skipping', {
23
+ jobId: job.id,
24
+ type: job.name,
25
+ });
26
+ return;
27
+ }
20
28
  await this.recordAuditStart(job, startedAt);
21
29
  try {
22
30
  await this.processJob(job);
@@ -38,6 +46,21 @@ export class BaseWorker extends WorkerHost {
38
46
  throw error;
39
47
  }
40
48
  }
49
+ async isJobAlreadyCompleted(job) {
50
+ if (!this.auditRepo || !job.id)
51
+ return false;
52
+ try {
53
+ const audit = await this.auditRepo.findByJobId(job.id);
54
+ return audit?.status === JobAuditStatus.COMPLETED;
55
+ }
56
+ catch (error) {
57
+ this.logger.error('Failed to check job completion status', {
58
+ jobId: job.id,
59
+ error,
60
+ });
61
+ return false;
62
+ }
63
+ }
41
64
  async recordAuditStart(job, startedAt) {
42
65
  if (!this.auditRepo || !job.id)
43
66
  return;
@@ -63,21 +86,17 @@ export class BaseWorker extends WorkerHost {
63
86
  return;
64
87
  }
65
88
  try {
66
- await this.auditRepo
67
- .createQueryBuilder()
68
- .update()
69
- .set({
89
+ await this.auditRepo.updateWhere({ jobId: job.id }, {
70
90
  status: JobAuditStatus.COMPLETED,
71
91
  finishedAt: new Date(),
72
- })
73
- .where('jobId = :jobId', { jobId: job.id })
74
- .execute();
92
+ });
75
93
  }
76
94
  catch (error) {
77
95
  this.logger.error('Failed to record audit success', {
78
96
  jobId: job.id,
79
97
  error,
80
98
  });
99
+ throw error;
81
100
  }
82
101
  }
83
102
  async recordAuditFailure(job, error) {
@@ -87,24 +106,20 @@ export class BaseWorker extends WorkerHost {
87
106
  try {
88
107
  const errorMessage = error instanceof Error ? error.message : String(error);
89
108
  const errorStack = error instanceof Error ? error.stack : undefined;
90
- await this.auditRepo
91
- .createQueryBuilder()
92
- .update()
93
- .set({
109
+ await this.auditRepo.updateWhere({ jobId: job.id }, {
94
110
  status: JobAuditStatus.FAILED,
95
111
  errorMessage,
96
112
  errorStack,
97
113
  finishedAt: new Date(),
98
114
  currentAttempt: job.attemptsMade + 1,
99
- })
100
- .where('jobId = :jobId', { jobId: job.id })
101
- .execute();
115
+ });
102
116
  }
103
117
  catch (auditError) {
104
118
  this.logger.error('Failed to record audit failure', {
105
119
  jobId: job.id,
106
120
  error: auditError,
107
121
  });
122
+ throw auditError;
108
123
  }
109
124
  }
110
125
  }
@@ -1 +1 @@
1
- {"version":3,"file":"base.worker.js","sourceRoot":"","sources":["../../src/core/base.worker.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"base.worker.js","sourceRoot":"","sources":["../../src/core/base.worker.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import type { Job } from 'bullmq';
2
+ import type { TestWorker } from '../../utils/index.js';
3
+ export interface TestJobPayload {
4
+ email?: string;
5
+ }
6
+ export declare function getFirstJob<JobData, JobReturn, JobName extends string>(jobs: Job<JobData, JobReturn, JobName>[]): Job<JobData, JobReturn, JobName>;
7
+ export declare function processJob<JobData, JobReturn, JobName extends string>(worker: TestWorker, job: Job<JobData, JobReturn, JobName>): Promise<void>;
8
+ export declare function processJobExpectError<JobData, JobReturn, JobName extends string>(worker: TestWorker, job: Job<JobData, JobReturn, JobName>, error: Error): Promise<void>;
9
+ //# sourceMappingURL=base.worker.int.helper.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.worker.int.helper.d.ts","sourceRoot":"","sources":["../../../../src/test/specs/base-worker/base.worker.int.helper.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAIvD,MAAM,WAAW,cAAc;IAC7B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAMD,wBAAgB,WAAW,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,SAAS,MAAM,EACpE,IAAI,EAAE,GAAG,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,GACvC,GAAG,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,CAKlC;AAMD,wBAAsB,UAAU,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,SAAS,MAAM,EACzE,MAAM,EAAE,UAAU,EAClB,GAAG,EAAE,GAAG,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,GACpC,OAAO,CAAC,IAAI,CAAC,CAEf;AAMD,wBAAsB,qBAAqB,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,SAAS,MAAM,EACpF,MAAM,EAAE,UAAU,EAClB,GAAG,EAAE,GAAG,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,EACrC,KAAK,EAAE,KAAK,GACX,OAAO,CAAC,IAAI,CAAC,CAEf"}
@@ -0,0 +1,14 @@
1
+ import { expect } from '@jest/globals';
2
+ export function getFirstJob(jobs) {
3
+ if (jobs.length === 0) {
4
+ throw new Error('No jobs in queue');
5
+ }
6
+ return jobs[0];
7
+ }
8
+ export async function processJob(worker, job) {
9
+ return worker.process(job);
10
+ }
11
+ export async function processJobExpectError(worker, job, error) {
12
+ return expect(worker.process(job)).rejects.toThrow(error);
13
+ }
14
+ //# sourceMappingURL=base.worker.int.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.worker.int.helper.js","sourceRoot":"","sources":["../../../../src/test/specs/base-worker/base.worker.int.helper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAcvC,MAAM,UAAU,WAAW,CACzB,IAAwC;IAExC,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACtB,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;IACtC,CAAC;IACD,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC;AACjB,CAAC;AAMD,MAAM,CAAC,KAAK,UAAU,UAAU,CAC9B,MAAkB,EAClB,GAAqC;IAErC,OAAO,MAAM,CAAC,OAAO,CAAC,GAAc,CAAC,CAAC;AACxC,CAAC;AAMD,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,MAAkB,EAClB,GAAqC,EACrC,KAAY;IAEZ,OAAO,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,GAAc,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;AACvE,CAAC"}
@@ -1,12 +1,16 @@
1
- import { describe, it, expect, beforeAll, afterAll, beforeEach, afterEach } from '@jest/globals';
1
+ import { describe, it, expect, beforeAll, afterAll, beforeEach, afterEach, jest, } from '@jest/globals';
2
+ import { Queue } from 'bullmq';
2
3
  import { databaseMapper } from '@volontariapp/database';
4
+ import { createMock } from '@volontariapp/testing';
3
5
  import { testDataSource, initializeTestDb, closeTestDb } from '../../data-source.js';
4
6
  import { clearTestDatabase, clearTestRedis } from '../../utils/index.js';
5
7
  import { JobAuditModel } from '../../../data/models/job-audit.model.js';
6
8
  import { JobAuditEntity } from '../../../data/entities/job-audit.entity.js';
7
9
  import { JobAuditStatus } from '../../../data/types/job-audit.status.js';
8
10
  import { JobAuditRepository } from '../../../data/repositories/job-audit.repository.js';
9
- import { TestWorker, makeTestJob } from '../../utils/index.js';
11
+ import { TestWorker } from '../../utils/index.js';
12
+ import { testRedisOptions } from '../../redis-config.js';
13
+ import { getFirstJob, processJob, processJobExpectError, } from './base.worker.int.helper.js';
10
14
  describe('BaseWorker — Integration', () => {
11
15
  let modelRepo;
12
16
  let auditRepo;
@@ -21,148 +25,473 @@ describe('BaseWorker — Integration', () => {
21
25
  });
22
26
  beforeEach(async () => {
23
27
  await clearTestDatabase(modelRepo);
28
+ jest.clearAllMocks();
24
29
  });
25
30
  afterEach(async () => {
26
31
  await clearTestRedis();
32
+ jest.restoreAllMocks();
27
33
  });
28
- describe('Succès — PROCESSING → COMPLETED', () => {
29
- it('devrait enregistrer audit avec statut COMPLETED', async () => {
30
- const jobId = 'int-success-001';
31
- const mockJob = makeTestJob({ id: jobId });
34
+ describe('Succès — PROCESSING → COMPLETED (Redis)', () => {
35
+ it('enregistre audit COMPLETED avec timestamps depuis Redis', async () => {
36
+ const jobId = 'int-redis-success-001';
37
+ const queue = new Queue('test-success-queue', {
38
+ connection: testRedisOptions,
39
+ });
32
40
  const worker = new TestWorker(auditRepo);
33
- mockJob.attemptsMade = 0;
34
41
  worker.processJob.mockResolvedValue(undefined);
35
- await worker.process(mockJob);
36
- const audit = await auditRepo.findByJobId(jobId);
37
- expect(audit).not.toBeNull();
38
- if (!audit)
39
- return;
40
- expect(audit.status).toBe(JobAuditStatus.COMPLETED);
41
- expect(audit.startedAt).toBeDefined();
42
- expect(audit.finishedAt).toBeDefined();
43
- if (audit.startedAt && audit.finishedAt) {
44
- expect(audit.startedAt.getTime()).toBeLessThanOrEqual(audit.finishedAt.getTime());
42
+ try {
43
+ await queue.add('SEND_WELCOME_EMAIL', { email: 'test@example.com' }, { jobId });
44
+ const jobs = await queue.getJobs(['waiting']);
45
+ const job = getFirstJob(jobs);
46
+ job.attemptsMade = 0;
47
+ const beforeProcess = new Date();
48
+ await processJob(worker, job);
49
+ const afterProcess = new Date();
50
+ const audit = await auditRepo.findByJobId(jobId);
51
+ expect(audit).not.toBeNull();
52
+ if (audit) {
53
+ expect(audit.status).toBe(JobAuditStatus.COMPLETED);
54
+ expect(audit.startedAt).toBeDefined();
55
+ expect(audit.finishedAt).toBeDefined();
56
+ if (audit.startedAt && audit.finishedAt) {
57
+ expect(audit.startedAt.getTime()).toBeGreaterThanOrEqual(beforeProcess.getTime());
58
+ expect(audit.finishedAt.getTime()).toBeLessThanOrEqual(afterProcess.getTime());
59
+ expect(audit.startedAt.getTime()).toBeLessThanOrEqual(audit.finishedAt.getTime());
60
+ }
61
+ }
62
+ }
63
+ finally {
64
+ await queue.close();
45
65
  }
46
66
  });
47
- it('devrait enregistrer jobType et workerId', async () => {
48
- const jobId = 'int-meta-001';
49
- const mockJob = makeTestJob({ id: jobId });
67
+ it('enregistre jobType, workerId, currentAttempt depuis Redis', async () => {
68
+ const jobId = 'int-redis-meta-001';
69
+ const queue = new Queue('test-meta-queue', {
70
+ connection: testRedisOptions,
71
+ });
50
72
  const worker = new TestWorker(auditRepo);
51
- mockJob.attemptsMade = 0;
52
73
  worker.processJob.mockResolvedValue(undefined);
53
- await worker.process(mockJob);
54
- const audit = await auditRepo.findByJobId(jobId);
55
- expect(audit).not.toBeNull();
56
- if (!audit)
57
- return;
58
- expect(audit.jobType).toBe(mockJob.name);
59
- expect(audit.workerId).toBeDefined();
60
- expect(typeof audit.workerId).toBe('string');
61
- expect(audit.currentAttempt).toBe(1);
74
+ try {
75
+ await queue.add('SEND_WELCOME_EMAIL', { email: 'user@test.com' }, { jobId });
76
+ const jobs = await queue.getJobs(['waiting']);
77
+ expect(jobs).toHaveLength(1);
78
+ const job = jobs[0];
79
+ job.attemptsMade = 0;
80
+ await processJob(worker, job);
81
+ const audit = await auditRepo.findByJobId(jobId);
82
+ expect(audit).not.toBeNull();
83
+ if (audit) {
84
+ expect(audit.jobType).toBe('SEND_WELCOME_EMAIL');
85
+ expect(audit.workerId).toBeDefined();
86
+ expect(typeof audit.workerId).toBe('string');
87
+ expect(audit.currentAttempt).toBe(1);
88
+ }
89
+ }
90
+ finally {
91
+ await queue.close();
92
+ }
62
93
  });
63
94
  });
64
- describe('Échec — PROCESSING → FAILED', () => {
65
- it('devrait enregistrer error_message et error_stack', async () => {
66
- const jobId = 'int-fail-001';
67
- const mockJob = makeTestJob({ id: jobId });
95
+ describe('Échec — PROCESSING → FAILED (Redis)', () => {
96
+ it('enregistre error_message et error_stack depuis Redis', async () => {
97
+ const jobId = 'int-redis-fail-001';
98
+ const queue = new Queue('test-fail-queue', {
99
+ connection: testRedisOptions,
100
+ });
68
101
  const worker = new TestWorker(auditRepo);
69
- const error = new Error('Processing failed');
70
- mockJob.attemptsMade = 0;
71
- worker.processJob.mockRejectedValue(error);
72
- await expect(worker.process(mockJob)).rejects.toThrow(error);
73
- const audit = await auditRepo.findByJobId(jobId);
74
- expect(audit).not.toBeNull();
75
- if (!audit)
76
- return;
77
- expect(audit.status).toBe(JobAuditStatus.FAILED);
78
- expect(audit.errorMessage).toBe('Processing failed');
79
- expect(audit.errorStack).toContain('Error: Processing failed');
80
- expect(audit.finishedAt).toBeDefined();
102
+ const jobError = new Error('Redis job processing error');
103
+ worker.processJob.mockRejectedValue(jobError);
104
+ try {
105
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
106
+ const jobs = await queue.getJobs(['waiting']);
107
+ const job = jobs[0];
108
+ job.attemptsMade = 0;
109
+ await processJobExpectError(worker, job, jobError);
110
+ const audit = await auditRepo.findByJobId(jobId);
111
+ expect(audit).not.toBeNull();
112
+ if (audit) {
113
+ expect(audit.status).toBe(JobAuditStatus.FAILED);
114
+ expect(audit.errorMessage).toBe('Redis job processing error');
115
+ expect(audit.errorStack).toContain('Error: Redis job processing error');
116
+ expect(audit.finishedAt).toBeDefined();
117
+ }
118
+ }
119
+ finally {
120
+ await queue.close();
121
+ }
81
122
  });
82
- it('devrait gérer non-Error thrown values', async () => {
83
- const jobId = 'int-fail-string-001';
84
- const mockJob = makeTestJob({ id: jobId });
123
+ it('gère string-error (non-Error thrown) depuis Redis', async () => {
124
+ const jobId = 'int-redis-fail-string-001';
125
+ const queue = new Queue('test-fail-string-queue', {
126
+ connection: testRedisOptions,
127
+ });
85
128
  const worker = new TestWorker(auditRepo);
86
- mockJob.attemptsMade = 0;
87
- worker.processJob.mockRejectedValue('string-error');
88
- await expect(worker.process(mockJob)).rejects.toBe('string-error');
89
- const audit = await auditRepo.findByJobId(jobId);
90
- expect(audit).not.toBeNull();
91
- if (!audit)
92
- return;
93
- expect(audit.status).toBe(JobAuditStatus.FAILED);
94
- expect(audit.errorMessage).toBe('string-error');
95
- expect(audit.errorStack).toBeNull();
129
+ worker.processJob.mockRejectedValue('custom-error-string');
130
+ try {
131
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
132
+ const jobs = await queue.getJobs(['waiting']);
133
+ const job = jobs[0];
134
+ job.attemptsMade = 0;
135
+ await expect(processJob(worker, job)).rejects.toBe('custom-error-string');
136
+ const audit = await auditRepo.findByJobId(jobId);
137
+ expect(audit).not.toBeNull();
138
+ if (audit) {
139
+ expect(audit.status).toBe(JobAuditStatus.FAILED);
140
+ expect(audit.errorMessage).toBe('custom-error-string');
141
+ expect(audit.errorStack).toBeNull();
142
+ }
143
+ }
144
+ finally {
145
+ await queue.close();
146
+ }
147
+ });
148
+ it('enregistre error lors de audit failure (DB failure)', async () => {
149
+ const jobId = 'int-redis-audit-fail-001';
150
+ const queue = new Queue('test-audit-fail-queue', {
151
+ connection: testRedisOptions,
152
+ });
153
+ const mockAuditRepo = createMock();
154
+ mockAuditRepo.findByJobId.mockResolvedValue(null);
155
+ mockAuditRepo.upsert.mockResolvedValue({
156
+ jobId,
157
+ status: JobAuditStatus.PROCESSING,
158
+ });
159
+ mockAuditRepo.updateWhere.mockRejectedValue(new Error('DB connection lost'));
160
+ const worker = new TestWorker(mockAuditRepo);
161
+ const jobError = new Error('Job processing failed');
162
+ worker.processJob.mockRejectedValue(jobError);
163
+ const upsertSpy = jest.spyOn(mockAuditRepo, 'upsert');
164
+ const updateWhereSpy = jest.spyOn(mockAuditRepo, 'updateWhere');
165
+ try {
166
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
167
+ const jobs = await queue.getJobs(['waiting']);
168
+ const job = getFirstJob(jobs);
169
+ job.attemptsMade = 0;
170
+ await expect(processJob(worker, job)).rejects.toThrow('DB connection lost');
171
+ expect(upsertSpy).toHaveBeenCalled();
172
+ expect(updateWhereSpy).toHaveBeenCalled();
173
+ }
174
+ finally {
175
+ await queue.close();
176
+ }
96
177
  });
97
178
  });
98
- describe('Retry — Upsert & Increment', () => {
99
- it('devrait incrémenter currentAttempt sur 2e tentative', async () => {
100
- const jobId = 'int-retry-001';
101
- const mockJob = makeTestJob({ id: jobId });
179
+ describe('Retry — Upsert & Increment (Redis)', () => {
180
+ it('crée une seule row audit (Redis idempotent COMPLETED)', async () => {
181
+ const jobId = 'int-redis-single-row-001';
182
+ const queue = new Queue('test-single-row-queue', {
183
+ connection: testRedisOptions,
184
+ });
102
185
  const worker = new TestWorker(auditRepo);
103
- mockJob.attemptsMade = 0;
104
186
  worker.processJob.mockResolvedValue(undefined);
105
- await worker.process(mockJob);
106
- let audit = await auditRepo.findByJobId(jobId);
107
- expect(audit).not.toBeNull();
108
- if (!audit)
109
- return;
110
- expect(audit.currentAttempt).toBe(1);
111
- mockJob.attemptsMade = 1;
112
- await worker.process(mockJob);
113
- audit = await auditRepo.findByJobId(jobId);
114
- expect(audit).not.toBeNull();
115
- if (!audit)
116
- return;
117
- expect(audit.currentAttempt).toBe(2);
118
- expect(audit.status).toBe(JobAuditStatus.COMPLETED);
187
+ const processJobSpy = jest.spyOn(worker, 'processJob');
188
+ try {
189
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
190
+ let jobs = await queue.getJobs(['waiting']);
191
+ let job = jobs[0];
192
+ job.attemptsMade = 0;
193
+ await processJob(worker, job);
194
+ const allAudits = await modelRepo.find({ where: { jobId } });
195
+ expect(allAudits).toHaveLength(1);
196
+ expect(allAudits[0].status).toBe(JobAuditStatus.COMPLETED);
197
+ processJobSpy.mockClear();
198
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
199
+ jobs = await queue.getJobs(['waiting']);
200
+ job = getFirstJob(jobs);
201
+ job.attemptsMade = 1;
202
+ await processJob(worker, job);
203
+ const finalAudits = await modelRepo.find({ where: { jobId } });
204
+ expect(finalAudits).toHaveLength(1);
205
+ expect(finalAudits[0].status).toBe(JobAuditStatus.COMPLETED);
206
+ expect(processJobSpy).not.toHaveBeenCalled();
207
+ }
208
+ finally {
209
+ await queue.close();
210
+ }
119
211
  });
120
- it('devrait faire upsert sur retry (une seule row en DB)', async () => {
121
- const jobId = 'int-upsert-001';
122
- const mockJob = makeTestJob({ id: jobId });
212
+ it('incrémente currentAttempt basé sur job.attemptsMade depuis Redis', async () => {
213
+ const jobId = 'int-redis-attempt-increment-001';
214
+ const queue = new Queue('test-attempt-queue', {
215
+ connection: testRedisOptions,
216
+ });
123
217
  const worker = new TestWorker(auditRepo);
124
- mockJob.attemptsMade = 0;
125
218
  worker.processJob.mockResolvedValue(undefined);
126
- await worker.process(mockJob);
127
- mockJob.attemptsMade = 1;
128
- await worker.process(mockJob);
129
- const allAudits = await modelRepo.find({ where: { jobId } });
130
- expect(allAudits).toHaveLength(1);
131
- expect(allAudits[0].currentAttempt).toBe(2);
219
+ const processJobSpy = jest.spyOn(worker, 'processJob');
220
+ try {
221
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
222
+ let jobs = await queue.getJobs(['waiting']);
223
+ let job = jobs[0];
224
+ job.attemptsMade = 0;
225
+ await processJob(worker, job);
226
+ let audit = await auditRepo.findByJobId(jobId);
227
+ expect(audit?.currentAttempt).toBe(1);
228
+ expect(audit?.status).toBe(JobAuditStatus.COMPLETED);
229
+ processJobSpy.mockClear();
230
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
231
+ jobs = await queue.getJobs(['waiting']);
232
+ job = getFirstJob(jobs);
233
+ job.attemptsMade = 1;
234
+ await processJob(worker, job);
235
+ audit = await auditRepo.findByJobId(jobId);
236
+ expect(audit?.currentAttempt).toBe(1);
237
+ expect(audit?.status).toBe(JobAuditStatus.COMPLETED);
238
+ expect(processJobSpy).not.toHaveBeenCalled();
239
+ }
240
+ finally {
241
+ await queue.close();
242
+ }
132
243
  });
133
244
  });
134
245
  describe('Graceful Degradation', () => {
135
- it('devrait fonctionner sans auditRepo', async () => {
136
- const jobId = 'int-no-audit-001';
137
- const mockJob = makeTestJob({ id: jobId });
246
+ it("fonctionne sans auditRepo (pas d'audit créé)", async () => {
247
+ const jobId = 'int-redis-no-audit-001';
248
+ const queue = new Queue('test-no-audit-queue', {
249
+ connection: testRedisOptions,
250
+ });
138
251
  const worker = new TestWorker();
139
- mockJob.attemptsMade = 0;
140
252
  worker.processJob.mockResolvedValue(undefined);
141
- await expect(worker.process(mockJob)).resolves.toBeUndefined();
142
- const allAudits = await modelRepo.find({ where: { jobId } });
143
- expect(allAudits).toHaveLength(0);
253
+ const processJobSpy = jest.spyOn(worker, 'processJob');
254
+ try {
255
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
256
+ const jobs = await queue.getJobs(['waiting']);
257
+ const job = jobs[0];
258
+ job.attemptsMade = 0;
259
+ await expect(worker.process(job)).resolves.toBeUndefined();
260
+ const allAudits = await modelRepo.find({ where: { jobId } });
261
+ expect(allAudits).toHaveLength(0);
262
+ expect(processJobSpy).toHaveBeenCalledTimes(1);
263
+ }
264
+ finally {
265
+ await queue.close();
266
+ }
267
+ });
268
+ it('fonctionne sans job.id (graceful skip)', async () => {
269
+ const jobId = 'int-redis-no-id-001';
270
+ const queue = new Queue('test-no-id-queue', {
271
+ connection: testRedisOptions,
272
+ });
273
+ const worker = new TestWorker(auditRepo);
274
+ worker.processJob.mockResolvedValue(undefined);
275
+ const processJobSpy = jest.spyOn(worker, 'processJob');
276
+ try {
277
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
278
+ const jobs = await queue.getJobs(['waiting']);
279
+ const job = jobs[0];
280
+ job.attemptsMade = 0;
281
+ job.id = undefined;
282
+ await expect(worker.process(job)).resolves.toBeUndefined();
283
+ const allAudits = await modelRepo.find({ where: { jobId } });
284
+ expect(allAudits).toHaveLength(0);
285
+ expect(processJobSpy).toHaveBeenCalledTimes(1);
286
+ }
287
+ finally {
288
+ await queue.close();
289
+ }
144
290
  });
145
291
  });
146
- describe('Timestamp Consistency', () => {
147
- it('devrait avoir timestamps cohérents', async () => {
148
- const jobId = 'int-ts-001';
149
- const mockJob = makeTestJob({ id: jobId });
292
+ describe('Timestamp Consistency (Redis)', () => {
293
+ it('timestamps cohérents depuis Redis', async () => {
294
+ const jobId = 'int-redis-ts-001';
295
+ const queue = new Queue('test-ts-queue', {
296
+ connection: testRedisOptions,
297
+ });
150
298
  const worker = new TestWorker(auditRepo);
151
- const beforeStart = new Date();
152
- mockJob.attemptsMade = 0;
153
299
  worker.processJob.mockResolvedValue(undefined);
154
- await worker.process(mockJob);
155
- const afterEnd = new Date();
156
- const audit = await auditRepo.findByJobId(jobId);
157
- expect(audit).not.toBeNull();
158
- if (!audit)
159
- return;
160
- expect(audit.startedAt).toBeDefined();
161
- expect(audit.finishedAt).toBeDefined();
162
- if (audit.startedAt && audit.finishedAt) {
163
- expect(audit.startedAt.getTime()).toBeGreaterThanOrEqual(beforeStart.getTime());
164
- expect(audit.finishedAt.getTime()).toBeLessThanOrEqual(afterEnd.getTime());
165
- expect(audit.startedAt.getTime()).toBeLessThanOrEqual(audit.finishedAt.getTime());
300
+ try {
301
+ const beforeStart = new Date();
302
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
303
+ const jobs = await queue.getJobs(['waiting']);
304
+ const job = jobs[0];
305
+ job.attemptsMade = 0;
306
+ await processJob(worker, job);
307
+ const afterEnd = new Date();
308
+ const audit = await auditRepo.findByJobId(jobId);
309
+ expect(audit).not.toBeNull();
310
+ if (audit) {
311
+ expect(audit.startedAt).toBeDefined();
312
+ expect(audit.finishedAt).toBeDefined();
313
+ if (audit.startedAt && audit.finishedAt) {
314
+ expect(audit.startedAt.getTime()).toBeGreaterThanOrEqual(beforeStart.getTime());
315
+ expect(audit.finishedAt.getTime()).toBeLessThanOrEqual(afterEnd.getTime());
316
+ expect(audit.startedAt.getTime()).toBeLessThanOrEqual(audit.finishedAt.getTime());
317
+ }
318
+ }
319
+ }
320
+ finally {
321
+ await queue.close();
322
+ }
323
+ });
324
+ });
325
+ describe('Idempotence — Job déjà COMPLETED (Redis)', () => {
326
+ it('ignore processJob si statut COMPLETED depuis Redis', async () => {
327
+ const jobId = 'int-redis-idempotent-001';
328
+ const queue = new Queue('test-idempotent-queue', {
329
+ connection: testRedisOptions,
330
+ });
331
+ const worker = new TestWorker(auditRepo);
332
+ worker.processJob.mockResolvedValue(undefined);
333
+ const processJobSpy = jest.spyOn(worker, 'processJob');
334
+ try {
335
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
336
+ let jobs = await queue.getJobs(['waiting']);
337
+ let job = jobs[0];
338
+ job.attemptsMade = 0;
339
+ await processJob(worker, job);
340
+ let audit = await auditRepo.findByJobId(jobId);
341
+ expect(audit?.status).toBe(JobAuditStatus.COMPLETED);
342
+ processJobSpy.mockClear();
343
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
344
+ jobs = await queue.getJobs(['waiting']);
345
+ job = getFirstJob(jobs);
346
+ job.attemptsMade = 1;
347
+ await processJob(worker, job);
348
+ expect(processJobSpy).not.toHaveBeenCalled();
349
+ audit = await auditRepo.findByJobId(jobId);
350
+ expect(audit?.status).toBe(JobAuditStatus.COMPLETED);
351
+ const allAudits = await modelRepo.find({ where: { jobId } });
352
+ expect(allAudits).toHaveLength(1);
353
+ }
354
+ finally {
355
+ await queue.close();
356
+ }
357
+ });
358
+ it('log warning quand job déjà complété depuis Redis', async () => {
359
+ const jobId = 'int-redis-idempotent-warn-001';
360
+ const queue = new Queue('test-idempotent-warn-queue', {
361
+ connection: testRedisOptions,
362
+ });
363
+ const worker = new TestWorker(auditRepo);
364
+ worker.processJob.mockResolvedValue(undefined);
365
+ const warnSpy = jest.spyOn(worker.logger, 'warn');
366
+ try {
367
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
368
+ let jobs = await queue.getJobs(['waiting']);
369
+ let job = jobs[0];
370
+ job.attemptsMade = 0;
371
+ await processJob(worker, job);
372
+ warnSpy.mockClear();
373
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
374
+ jobs = await queue.getJobs(['waiting']);
375
+ job = getFirstJob(jobs);
376
+ job.attemptsMade = 1;
377
+ await processJob(worker, job);
378
+ expect(warnSpy).toHaveBeenCalledWith('Job already processed, skipping', {
379
+ jobId,
380
+ type: 'SEND_WELCOME_EMAIL',
381
+ });
382
+ }
383
+ finally {
384
+ await queue.close();
385
+ }
386
+ });
387
+ });
388
+ describe('Audit failure resilience (Redis)', () => {
389
+ it('rejette si updateWhere échoue après succès depuis Redis', async () => {
390
+ const jobId = 'int-redis-audit-fail-success-001';
391
+ const queue = new Queue('test-audit-fail-success-queue', {
392
+ connection: testRedisOptions,
393
+ });
394
+ const mockAuditRepo = createMock();
395
+ mockAuditRepo.findByJobId.mockResolvedValue(null);
396
+ mockAuditRepo.upsert.mockResolvedValue({
397
+ jobId,
398
+ status: JobAuditStatus.PROCESSING,
399
+ });
400
+ mockAuditRepo.updateWhere.mockImplementation((_where, data) => {
401
+ if (data.status === JobAuditStatus.COMPLETED) {
402
+ throw new Error('DB failure on COMPLETED update');
403
+ }
404
+ return Promise.resolve({});
405
+ });
406
+ const worker = new TestWorker(mockAuditRepo);
407
+ worker.processJob.mockResolvedValue(undefined);
408
+ const upsertSpy = jest.spyOn(mockAuditRepo, 'upsert');
409
+ const updateWhereSpy = jest.spyOn(mockAuditRepo, 'updateWhere');
410
+ const processJobSpy = jest.spyOn(worker, 'processJob');
411
+ try {
412
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
413
+ const jobs = await queue.getJobs(['waiting']);
414
+ const job = jobs[0];
415
+ job.attemptsMade = 0;
416
+ await expect(worker.process(job)).rejects.toThrow('DB failure on COMPLETED update');
417
+ expect(upsertSpy).toHaveBeenCalled();
418
+ expect(updateWhereSpy).toHaveBeenCalled();
419
+ expect(processJobSpy).toHaveBeenCalledTimes(1);
420
+ }
421
+ finally {
422
+ await queue.close();
423
+ }
424
+ });
425
+ it('rejette si updateWhere échoue lors de failure depuis Redis', async () => {
426
+ const jobId = 'int-redis-audit-fail-failure-001';
427
+ const queue = new Queue('test-audit-fail-failure-queue', {
428
+ connection: testRedisOptions,
429
+ });
430
+ const jobError = new Error('Job processing failed');
431
+ const mockAuditRepo = createMock();
432
+ mockAuditRepo.findByJobId.mockResolvedValue(null);
433
+ mockAuditRepo.upsert.mockResolvedValue({
434
+ jobId,
435
+ status: JobAuditStatus.PROCESSING,
436
+ });
437
+ mockAuditRepo.updateWhere.mockImplementation((_where, data) => {
438
+ if (data.status === JobAuditStatus.FAILED) {
439
+ throw new Error('DB failure on FAILED update');
440
+ }
441
+ return Promise.resolve({});
442
+ });
443
+ const worker = new TestWorker(mockAuditRepo);
444
+ worker.processJob.mockRejectedValue(jobError);
445
+ const upsertSpy = jest.spyOn(mockAuditRepo, 'upsert');
446
+ const updateWhereSpy = jest.spyOn(mockAuditRepo, 'updateWhere');
447
+ const processJobSpy = jest.spyOn(worker, 'processJob');
448
+ try {
449
+ await queue.add('SEND_WELCOME_EMAIL', {}, { jobId });
450
+ const jobs = await queue.getJobs(['waiting']);
451
+ const job = jobs[0];
452
+ job.attemptsMade = 0;
453
+ let thrown;
454
+ try {
455
+ await worker.process(job);
456
+ }
457
+ catch (error) {
458
+ thrown = error;
459
+ }
460
+ expect(thrown instanceof Error && thrown.message).toBe('DB failure on FAILED update');
461
+ expect(upsertSpy).toHaveBeenCalled();
462
+ expect(updateWhereSpy).toHaveBeenCalled();
463
+ expect(processJobSpy).toHaveBeenCalledTimes(1);
464
+ }
465
+ finally {
466
+ await queue.close();
467
+ }
468
+ });
469
+ });
470
+ describe('Type de Job Invalide (Redis)', () => {
471
+ it("traite job de type différent sans corrompre l'audit depuis Redis", async () => {
472
+ const jobId = 'int-redis-wrong-type-001';
473
+ const queue = new Queue('test-wrong-type-queue', {
474
+ connection: testRedisOptions,
475
+ });
476
+ const worker = new TestWorker(auditRepo);
477
+ worker.processJob.mockResolvedValue(undefined);
478
+ const processJobSpy = jest.spyOn(worker, 'processJob');
479
+ try {
480
+ await queue.add('DIFFERENT_JOB_TYPE', {}, { jobId });
481
+ const jobs = await queue.getJobs(['waiting']);
482
+ const job = jobs[0];
483
+ job.attemptsMade = 0;
484
+ await processJob(worker, job);
485
+ const audit = await auditRepo.findByJobId(jobId);
486
+ expect(audit).not.toBeNull();
487
+ if (audit) {
488
+ expect(audit.status).toBe(JobAuditStatus.COMPLETED);
489
+ expect(audit.jobType).toBe('DIFFERENT_JOB_TYPE');
490
+ }
491
+ expect(processJobSpy).toHaveBeenCalledTimes(1);
492
+ }
493
+ finally {
494
+ await queue.close();
166
495
  }
167
496
  });
168
497
  });
@@ -1 +1 @@
1
- {"version":3,"file":"base.worker.int.spec.js","sourceRoot":"","sources":["../../../../src/test/specs/base-worker/base.worker.int.spec.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"base.worker.int.spec.js","sourceRoot":"","sources":["../../../../src/test/specs/base-worker/base.worker.int.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EACR,EAAE,EACF,MAAM,EACN,SAAS,EACT,QAAQ,EACR,UAAU,EACV,SAAS,EACT,IAAI,GACL,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,KAAK,EAAE,MAAM,QAAQ,CAAC;AAC/B,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACrF,OAAO,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACzE,OAAO,EAAE,aAAa,EAAE,MAAM,yCAAyC,CAAC;AACxE,OAAO,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AAC5E,OAAO,EAAE,cAAc,EAAE,MAAM,yCAAyC,CAAC;AACzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AACxF,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAElD,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,EACL,WAAW,EACX,UAAU,EACV,qBAAqB,GAEtB,MAAM,6BAA6B,CAAC;AAErC,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;IACxC,IAAI,SAAoC,CAAC;IACzC,IAAI,SAA6B,CAAC;IAElC,SAAS,CAAC,KAAK,IAAI,EAAE;QACnB,cAAc,CAAC,qBAAqB,CAAC,aAAa,EAAE,cAAc,CAAC,CAAC;QACpE,MAAM,gBAAgB,EAAE,CAAC;QACzB,SAAS,GAAG,cAAc,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;QACxD,SAAS,GAAG,IAAI,kBAAkB,CAAC,SAAS,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,KAAK,IAAI,EAAE;QAClB,MAAM,WAAW,EAAE,CAAC;IACtB,CAAC,CAAC,CAAC;IAEH,UAAU,CAAC,KAAK,IAAI,EAAE;QACpB,MAAM,iBAAiB,CAAC,SAAS,CAAC,CAAC;QACnC,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,KAAK,IAAI,EAAE;QACnB,MAAM,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACvD,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;YACvE,MAAM,KAAK,GAAG,uBAAuB,CAAC;YACtC,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,oBAAoB,EAAE;gBAC1E,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;YACzC,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAE/C,IAAI,CAAC;gBAEH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,KAAK,EAAE,kBAAkB,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBAChF,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;gBAE9B,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,aAAa,GAAG,IAAI,IAAI,EAAE,CAAC;gBACjC,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAC9B,MAAM,YAAY,GAAG,IAAI,IAAI,EAAE,CAAC;gBAGhC,MAAM,KAAK,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBACjD,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;gBAC7B,IAAI,KAAK,EAAE,CAAC;oBACV,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;oBACpD,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;oBACtC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC;oBACvC,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,UAAU,EAAE,CAAC;wBACxC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC,sBAAsB,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC;wBAClF,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC,mBAAmB,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,CAAC;wBAC/E,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC,mBAAmB,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC;oBACpF,CAAC;gBACH,CAAC;YACH,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,2DAA2D,EAAE,KAAK,IAAI,EAAE;YACzE,MAAM,KAAK,GAAG,oBAAoB,CAAC;YACnC,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,iBAAiB,EAAE;gBACvE,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;YACzC,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAE/C,IAAI,CAAC;gBAEH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,KAAK,EAAE,eAAe,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBAC7E,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAC9C,MAAM,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;gBAE7B,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACpB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAE9B,MAAM,KAAK,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBACjD,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;gBAC7B,IAAI,KAAK,EAAE,CAAC;oBACV,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;oBACjD,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;oBACrC,MAAM,CAAC,OAAO,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;oBAC7C,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACvC,CAAC;YACH,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,qCAAqC,EAAE,GAAG,EAAE;QACnD,EAAE,CAAC,sDAAsD,EAAE,KAAK,IAAI,EAAE;YACpE,MAAM,KAAK,GAAG,oBAAoB,CAAC;YACnC,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,iBAAiB,EAAE;gBACvE,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;YACzC,MAAM,QAAQ,GAAG,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;YACzD,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;YAE9C,IAAI,CAAC;gBACH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACpB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,qBAAqB,CAAC,MAAM,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC;gBAEnD,MAAM,KAAK,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBACjD,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;gBAC7B,IAAI,KAAK,EAAE,CAAC;oBACV,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;oBACjD,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;oBAC9D,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,mCAAmC,CAAC,CAAC;oBACxE,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC;gBACzC,CAAC;YACH,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mDAAmD,EAAE,KAAK,IAAI,EAAE;YACjE,MAAM,KAAK,GAAG,2BAA2B,CAAC;YAC1C,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,wBAAwB,EAAE;gBAC9E,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;YAEzC,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,qBAAqB,CAAC,CAAC;YAE3D,IAAI,CAAC;gBACH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACpB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;gBAE1E,MAAM,KAAK,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBACjD,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;gBAC7B,IAAI,KAAK,EAAE,CAAC;oBACV,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;oBACjD,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;oBACvD,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC;gBACtC,CAAC;YACH,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,qDAAqD,EAAE,KAAK,IAAI,EAAE;YACnE,MAAM,KAAK,GAAG,0BAA0B,CAAC;YACzC,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,uBAAuB,EAAE;gBAC7E,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YAEH,MAAM,aAAa,GAAG,UAAU,EAAsB,CAAC;YACvD,aAAa,CAAC,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;YAClD,aAAa,CAAC,MAAM,CAAC,iBAAiB,CAAC;gBACrC,KAAK;gBACL,MAAM,EAAE,cAAc,CAAC,UAAU;aAChB,CAAC,CAAC;YACrB,aAAa,CAAC,WAAW,CAAC,iBAAiB,CAAC,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC,CAAC;YAE7E,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,aAAa,CAAC,CAAC;YAC7C,MAAM,QAAQ,GAAG,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;YACpD,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;YAE9C,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;YACtD,MAAM,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;YAEhE,IAAI,CAAC;gBACH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;gBAE9B,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC;gBAE5E,MAAM,CAAC,SAAS,CAAC,CAAC,gBAAgB,EAAE,CAAC;gBACrC,MAAM,CAAC,cAAc,CAAC,CAAC,gBAAgB,EAAE,CAAC;YAC5C,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAClD,EAAE,CAAC,uDAAuD,EAAE,KAAK,IAAI,EAAE;YACrE,MAAM,KAAK,GAAG,0BAA0B,CAAC;YACzC,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,uBAAuB,EAAE;gBAC7E,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;YACzC,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;YAEvD,IAAI,CAAC;gBAEH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,IAAI,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE5C,IAAI,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAE9B,MAAM,SAAS,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;gBAC7D,MAAM,CAAC,SAAS,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;gBAClC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;gBAG3D,aAAa,CAAC,SAAS,EAAE,CAAC;gBAC1B,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBACxC,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;gBACxB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAG9B,MAAM,WAAW,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;gBAC/D,MAAM,CAAC,WAAW,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;gBACpC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;gBAC7D,MAAM,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YAC/C,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,kEAAkE,EAAE,KAAK,IAAI,EAAE;YAChF,MAAM,KAAK,GAAG,iCAAiC,CAAC;YAChD,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,oBAAoB,EAAE;gBAC1E,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;YAEzC,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;YAEvD,IAAI,CAAC;gBAGH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,IAAI,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE5C,IAAI,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAE9B,IAAI,KAAK,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBAC/C,MAAM,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACtC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;gBAIrD,aAAa,CAAC,SAAS,EAAE,CAAC;gBAC1B,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBACxC,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;gBACxB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAGrB,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAE9B,KAAK,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBAE3C,MAAM,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACtC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;gBACrD,MAAM,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YAC/C,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;QACpC,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;YAC5D,MAAM,KAAK,GAAG,wBAAwB,CAAC;YACvC,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,qBAAqB,EAAE;gBAC3E,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAEhC,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;YAEvD,IAAI,CAAC;gBACH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACpB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,GAAc,CAAC,CAAC,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;gBAGtE,MAAM,SAAS,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;gBAC7D,MAAM,CAAC,SAAS,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;gBAClC,MAAM,CAAC,aAAa,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;YACjD,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;YACtD,MAAM,KAAK,GAAG,qBAAqB,CAAC;YACpC,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,kBAAkB,EAAE;gBACxE,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;YAEzC,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;YAEvD,IAAI,CAAC;gBACH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACpB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBACrB,GAAG,CAAC,EAAE,GAAG,SAAS,CAAC;gBAEnB,MAAM,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,GAAc,CAAC,CAAC,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;gBAGtE,MAAM,SAAS,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;gBAC7D,MAAM,CAAC,SAAS,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;gBAClC,MAAM,CAAC,aAAa,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;YACjD,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,+BAA+B,EAAE,GAAG,EAAE;QAC7C,EAAE,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;YACjD,MAAM,KAAK,GAAG,kBAAkB,CAAC;YACjC,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,eAAe,EAAE;gBACrE,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;YAEzC,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAE/C,IAAI,CAAC;gBACH,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC;gBAC/B,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACpB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAC9B,MAAM,QAAQ,GAAG,IAAI,IAAI,EAAE,CAAC;gBAE5B,MAAM,KAAK,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBACjD,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;gBAC7B,IAAI,KAAK,EAAE,CAAC;oBACV,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;oBACtC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC;oBACvC,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,UAAU,EAAE,CAAC;wBACxC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC,sBAAsB,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC;wBAChF,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC,mBAAmB,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC;wBAC3E,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC,mBAAmB,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC;oBACpF,CAAC;gBACH,CAAC;YACH,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,0CAA0C,EAAE,GAAG,EAAE;QACxD,EAAE,CAAC,oDAAoD,EAAE,KAAK,IAAI,EAAE;YAClE,MAAM,KAAK,GAAG,0BAA0B,CAAC;YACzC,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,uBAAuB,EAAE;gBAC7E,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;YAEzC,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;YAEvD,IAAI,CAAC;gBAEH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,IAAI,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE5C,IAAI,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAE9B,IAAI,KAAK,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBAC/C,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;gBAGrD,aAAa,CAAC,SAAS,EAAE,CAAC;gBAC1B,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBACxC,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;gBACxB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAG9B,MAAM,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;gBAE7C,KAAK,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBAC3C,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;gBAGrD,MAAM,SAAS,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;gBAC7D,MAAM,CAAC,SAAS,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACpC,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,kDAAkD,EAAE,KAAK,IAAI,EAAE;YAChE,MAAM,KAAK,GAAG,+BAA+B,CAAC;YAC9C,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,4BAA4B,EAAE;gBAClF,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;YAEzC,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAC/C,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;YAElD,IAAI,CAAC;gBAEH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,IAAI,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE5C,IAAI,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAG9B,OAAO,CAAC,SAAS,EAAE,CAAC;gBACpB,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBACxC,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;gBACxB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAI9B,MAAM,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,iCAAiC,EAAE;oBACtE,KAAK;oBACL,IAAI,EAAE,oBAAoB;iBAC3B,CAAC,CAAC;YACL,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAChD,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;YACvE,MAAM,KAAK,GAAG,kCAAkC,CAAC;YACjD,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,+BAA+B,EAAE;gBACrF,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YAGH,MAAM,aAAa,GAAG,UAAU,EAAsB,CAAC;YACvD,aAAa,CAAC,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;YAClD,aAAa,CAAC,MAAM,CAAC,iBAAiB,CAAC;gBACrC,KAAK;gBACL,MAAM,EAAE,cAAc,CAAC,UAAU;aAChB,CAAC,CAAC;YACrB,aAAa,CAAC,WAAW,CAAC,kBAAkB,CAAC,CAAC,MAAM,EAAE,IAAI,EAAE,EAAE;gBAC5D,IAAI,IAAI,CAAC,MAAM,KAAK,cAAc,CAAC,SAAS,EAAE,CAAC;oBAC7C,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;gBACpD,CAAC;gBACD,OAAO,OAAO,CAAC,OAAO,CAAC,EAAkB,CAAC,CAAC;YAC7C,CAAC,CAAC,CAAC;YAEH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,aAAa,CAAC,CAAC;YAC7C,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAC/C,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;YACtD,MAAM,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;YAChE,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;YAEvD,IAAI,CAAC;gBACH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACpB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,GAAc,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAC1D,gCAAgC,CACjC,CAAC;gBAGF,MAAM,CAAC,SAAS,CAAC,CAAC,gBAAgB,EAAE,CAAC;gBAGrC,MAAM,CAAC,cAAc,CAAC,CAAC,gBAAgB,EAAE,CAAC;gBAG1C,MAAM,CAAC,aAAa,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;YACjD,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4DAA4D,EAAE,KAAK,IAAI,EAAE;YAC1E,MAAM,KAAK,GAAG,kCAAkC,CAAC;YACjD,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,+BAA+B,EAAE;gBACrF,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,QAAQ,GAAG,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;YAGpD,MAAM,aAAa,GAAG,UAAU,EAAsB,CAAC;YACvD,aAAa,CAAC,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;YAClD,aAAa,CAAC,MAAM,CAAC,iBAAiB,CAAC;gBACrC,KAAK;gBACL,MAAM,EAAE,cAAc,CAAC,UAAU;aAChB,CAAC,CAAC;YACrB,aAAa,CAAC,WAAW,CAAC,kBAAkB,CAAC,CAAC,MAAM,EAAE,IAAI,EAAE,EAAE;gBAC5D,IAAI,IAAI,CAAC,MAAM,KAAK,cAAc,CAAC,MAAM,EAAE,CAAC;oBAC1C,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAC;gBACjD,CAAC;gBACD,OAAO,OAAO,CAAC,OAAO,CAAC,EAAkB,CAAC,CAAC;YAC7C,CAAC,CAAC,CAAC;YAEH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,aAAa,CAAC,CAAC;YAC7C,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;YAC9C,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;YACtD,MAAM,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;YAChE,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;YAEvD,IAAI,CAAC;gBACH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACpB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,IAAI,MAAyB,CAAC;gBAC9B,IAAI,CAAC;oBACH,MAAM,MAAM,CAAC,OAAO,CAAC,GAAc,CAAC,CAAC;gBACvC,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,MAAM,GAAG,KAAc,CAAC;gBAC1B,CAAC;gBACD,MAAM,CAAC,MAAM,YAAY,KAAK,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;gBAGtF,MAAM,CAAC,SAAS,CAAC,CAAC,gBAAgB,EAAE,CAAC;gBAGrC,MAAM,CAAC,cAAc,CAAC,CAAC,gBAAgB,EAAE,CAAC;gBAG1C,MAAM,CAAC,aAAa,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;YACjD,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,8BAA8B,EAAE,GAAG,EAAE;QAC5C,EAAE,CAAC,kEAAkE,EAAE,KAAK,IAAI,EAAE;YAChF,MAAM,KAAK,GAAG,0BAA0B,CAAC;YACzC,MAAM,KAAK,GAAG,IAAI,KAAK,CAA+B,uBAAuB,EAAE;gBAC7E,UAAU,EAAE,gBAAgB;aAC7B,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;YAEzC,MAAM,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;YAEvD,IAAI,CAAC;gBAEH,MAAM,KAAK,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrD,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACpB,GAAG,CAAC,YAAY,GAAG,CAAC,CAAC;gBAErB,MAAM,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAE9B,MAAM,KAAK,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBACjD,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;gBAC7B,IAAI,KAAK,EAAE,CAAC;oBACV,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;oBACpD,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;gBACnD,CAAC;gBAED,MAAM,CAAC,aAAa,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;YACjD,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1,63 +1,72 @@
1
1
  import { describe, it, expect, beforeEach, jest } from '@jest/globals';
2
2
  import { JobMessagingType } from '@volontariapp/messaging';
3
- import { TestWorker, makeTestJob } from '../../utils/index.js';
3
+ import { TestWorker, makeTestJob, createAuditRepositoryMock, } from '../../utils/index.js';
4
+ import { JobAuditStatus } from '../../../data/types/job-audit.status.js';
4
5
  describe('BaseWorker', () => {
5
6
  let worker;
6
7
  let mockJob;
8
+ let processJobSpy;
9
+ let loggerInfoSpy;
10
+ let loggerErrorSpy;
11
+ let loggerWarnSpy;
7
12
  beforeEach(() => {
8
13
  jest.clearAllMocks();
9
14
  worker = new TestWorker();
10
15
  mockJob = makeTestJob();
16
+ processJobSpy = jest.spyOn(worker, 'processJob');
17
+ loggerInfoSpy = jest.spyOn(worker.logger, 'info');
18
+ loggerErrorSpy = jest.spyOn(worker.logger, 'error');
19
+ loggerWarnSpy = jest.spyOn(worker.logger, 'warn');
11
20
  });
12
21
  describe('process — success', () => {
13
22
  it('should call processJob with the job', async () => {
14
- worker.processJob.mockResolvedValue(undefined);
23
+ processJobSpy.mockResolvedValue(undefined);
15
24
  await worker.process(mockJob);
16
- expect(worker.processJob).toHaveBeenCalledTimes(1);
17
- expect(worker.processJob).toHaveBeenCalledWith(mockJob);
25
+ expect(processJobSpy).toHaveBeenCalledTimes(1);
26
+ expect(processJobSpy).toHaveBeenCalledWith(mockJob);
18
27
  });
19
28
  it('should log "Processing job" before execution', async () => {
20
- worker.processJob.mockResolvedValue(undefined);
29
+ processJobSpy.mockResolvedValue(undefined);
21
30
  await worker.process(mockJob);
22
- expect(worker.logger.info).toHaveBeenNthCalledWith(1, 'Processing job', {
31
+ expect(loggerInfoSpy).toHaveBeenNthCalledWith(1, 'Processing job', {
23
32
  jobId: 'job-123',
24
33
  type: JobMessagingType.SEND_WELCOME_EMAIL,
25
34
  workerId: expect.any(String),
26
35
  });
27
36
  });
28
37
  it('should log "Job completed" after execution', async () => {
29
- worker.processJob.mockResolvedValue(undefined);
38
+ processJobSpy.mockResolvedValue(undefined);
30
39
  await worker.process(mockJob);
31
- expect(worker.logger.info).toHaveBeenCalledTimes(2);
32
- expect(worker.logger.info).toHaveBeenNthCalledWith(2, 'Job completed', {
40
+ expect(loggerInfoSpy).toHaveBeenCalledTimes(2);
41
+ expect(loggerInfoSpy).toHaveBeenNthCalledWith(2, 'Job completed', {
33
42
  jobId: 'job-123',
34
43
  type: JobMessagingType.SEND_WELCOME_EMAIL,
35
44
  workerId: expect.any(String),
36
45
  });
37
46
  });
38
47
  it('should not call logger.error on success', async () => {
39
- worker.processJob.mockResolvedValue(undefined);
48
+ processJobSpy.mockResolvedValue(undefined);
40
49
  await worker.process(mockJob);
41
- expect(worker.logger.error).not.toHaveBeenCalled();
50
+ expect(loggerErrorSpy).not.toHaveBeenCalled();
42
51
  });
43
52
  it('should ignore the optional token parameter', async () => {
44
- worker.processJob.mockResolvedValue(undefined);
53
+ processJobSpy.mockResolvedValue(undefined);
45
54
  await worker.process(mockJob, 'some-bullmq-token');
46
- expect(worker.processJob).toHaveBeenCalledWith(mockJob);
55
+ expect(processJobSpy).toHaveBeenCalledWith(mockJob);
47
56
  });
48
57
  });
49
58
  describe('process — failure', () => {
50
59
  it('should re-throw the error thrown by processJob', async () => {
51
60
  const error = new Error('Processing failed');
52
- worker.processJob.mockRejectedValue(error);
61
+ processJobSpy.mockRejectedValue(error);
53
62
  await expect(worker.process(mockJob)).rejects.toThrow(error);
54
63
  });
55
64
  it('should call logger.error with job metadata and the error', async () => {
56
65
  const error = new Error('Processing failed');
57
- worker.processJob.mockRejectedValue(error);
66
+ processJobSpy.mockRejectedValue(error);
58
67
  await expect(worker.process(mockJob)).rejects.toThrow();
59
- expect(worker.logger.error).toHaveBeenCalledTimes(1);
60
- expect(worker.logger.error).toHaveBeenCalledWith('Job failed', {
68
+ expect(loggerErrorSpy).toHaveBeenCalledTimes(1);
69
+ expect(loggerErrorSpy).toHaveBeenCalledWith('Job failed', {
61
70
  jobId: 'job-123',
62
71
  type: JobMessagingType.SEND_WELCOME_EMAIL,
63
72
  workerId: expect.any(String),
@@ -65,24 +74,191 @@ describe('BaseWorker', () => {
65
74
  });
66
75
  });
67
76
  it('should log "Processing job" but NOT "Job completed" on failure', async () => {
68
- worker.processJob.mockRejectedValue(new Error('fail'));
77
+ processJobSpy.mockRejectedValue(new Error('fail'));
69
78
  await expect(worker.process(mockJob)).rejects.toThrow();
70
- expect(worker.logger.info).toHaveBeenCalledTimes(1);
71
- expect(worker.logger.info).toHaveBeenCalledWith('Processing job', expect.any(Object));
79
+ expect(loggerInfoSpy).toHaveBeenCalledTimes(1);
80
+ expect(loggerInfoSpy).toHaveBeenCalledWith('Processing job', expect.any(Object));
72
81
  });
73
82
  it('should propagate non-Error thrown values', async () => {
74
83
  const thrown = 'string-error';
75
- worker.processJob.mockRejectedValue(thrown);
84
+ processJobSpy.mockRejectedValue(thrown);
76
85
  await expect(worker.process(mockJob)).rejects.toBe(thrown);
77
- expect(worker.logger.error).toHaveBeenCalledWith('Job failed', expect.objectContaining({ error: thrown }));
86
+ expect(loggerErrorSpy).toHaveBeenCalledWith('Job failed', expect.objectContaining({ error: thrown }));
78
87
  });
79
88
  });
80
89
  describe('typing', () => {
81
90
  it('should pass Job typed with correct payload to processJob', async () => {
82
91
  const typedJob = makeTestJob({ id: 'typed-job' });
83
- worker.processJob.mockResolvedValue(undefined);
92
+ processJobSpy.mockResolvedValue(undefined);
84
93
  await worker.process(typedJob);
85
- expect(worker.processJob).toHaveBeenCalledWith(typedJob);
94
+ expect(processJobSpy).toHaveBeenCalledWith(typedJob);
95
+ });
96
+ });
97
+ describe('audit — with auditRepo', () => {
98
+ let mockAuditRepo;
99
+ let upsertSpy;
100
+ let updateWhereSpy;
101
+ beforeEach(() => {
102
+ mockAuditRepo = createAuditRepositoryMock();
103
+ worker = new TestWorker(mockAuditRepo);
104
+ processJobSpy = jest.spyOn(worker, 'processJob');
105
+ loggerInfoSpy = jest.spyOn(worker.logger, 'info');
106
+ loggerErrorSpy = jest.spyOn(worker.logger, 'error');
107
+ loggerWarnSpy = jest.spyOn(worker.logger, 'warn');
108
+ upsertSpy = jest.spyOn(mockAuditRepo, 'upsert');
109
+ updateWhereSpy = jest.spyOn(mockAuditRepo, 'updateWhere');
110
+ });
111
+ it('should call auditRepo.upsert on process start with PROCESSING status', async () => {
112
+ mockJob.attemptsMade = 0;
113
+ processJobSpy.mockResolvedValue(undefined);
114
+ await worker.process(mockJob);
115
+ expect(upsertSpy).toHaveBeenCalledWith(expect.objectContaining({
116
+ jobId: mockJob.id,
117
+ jobType: mockJob.name,
118
+ status: 'PROCESSING',
119
+ workerId: expect.any(String),
120
+ currentAttempt: 1,
121
+ startedAt: expect.any(Date),
122
+ }), ['jobId']);
123
+ });
124
+ it('should call auditRepo.updateWhere with COMPLETED on success', async () => {
125
+ mockJob.attemptsMade = 0;
126
+ processJobSpy.mockResolvedValue(undefined);
127
+ await worker.process(mockJob);
128
+ expect(updateWhereSpy).toHaveBeenCalledWith({ jobId: mockJob.id }, expect.objectContaining({
129
+ status: 'COMPLETED',
130
+ finishedAt: expect.any(Date),
131
+ }));
132
+ });
133
+ it('should call auditRepo.updateWhere with FAILED on error', async () => {
134
+ const error = new Error('Job failed');
135
+ mockJob.attemptsMade = 0;
136
+ processJobSpy.mockRejectedValue(error);
137
+ await expect(worker.process(mockJob)).rejects.toThrow(error);
138
+ expect(updateWhereSpy).toHaveBeenCalledWith({ jobId: mockJob.id }, expect.objectContaining({
139
+ status: 'FAILED',
140
+ errorMessage: 'Job failed',
141
+ errorStack: expect.stringContaining('Error: Job failed'),
142
+ currentAttempt: 1,
143
+ finishedAt: expect.any(Date),
144
+ }));
145
+ });
146
+ it('should not call audit if job.id is undefined', async () => {
147
+ const noIdJob = makeTestJob({ id: undefined });
148
+ processJobSpy.mockResolvedValue(undefined);
149
+ await worker.process(noIdJob);
150
+ expect(upsertSpy).not.toHaveBeenCalled();
151
+ expect(updateWhereSpy).not.toHaveBeenCalled();
152
+ });
153
+ });
154
+ describe('idempotence — COMPLETED guard', () => {
155
+ let mockAuditRepo;
156
+ let findByJobIdSpy;
157
+ let upsertSpy;
158
+ let updateWhereSpy;
159
+ beforeEach(() => {
160
+ mockAuditRepo = createAuditRepositoryMock();
161
+ worker = new TestWorker(mockAuditRepo);
162
+ processJobSpy = jest.spyOn(worker, 'processJob');
163
+ loggerInfoSpy = jest.spyOn(worker.logger, 'info');
164
+ loggerErrorSpy = jest.spyOn(worker.logger, 'error');
165
+ loggerWarnSpy = jest.spyOn(worker.logger, 'warn');
166
+ findByJobIdSpy = jest.spyOn(mockAuditRepo, 'findByJobId');
167
+ upsertSpy = jest.spyOn(mockAuditRepo, 'upsert');
168
+ updateWhereSpy = jest.spyOn(mockAuditRepo, 'updateWhere');
169
+ });
170
+ it('should skip processJob if job already COMPLETED', async () => {
171
+ mockJob.attemptsMade = 1;
172
+ const completedAudit = {
173
+ jobId: mockJob.id,
174
+ status: JobAuditStatus.COMPLETED,
175
+ };
176
+ findByJobIdSpy.mockResolvedValue(completedAudit);
177
+ await worker.process(mockJob);
178
+ expect(processJobSpy).not.toHaveBeenCalled();
179
+ expect(upsertSpy).not.toHaveBeenCalled();
180
+ expect(updateWhereSpy).not.toHaveBeenCalled();
181
+ });
182
+ it('should log warning when job already COMPLETED', async () => {
183
+ mockJob.attemptsMade = 1;
184
+ const completedAudit = {
185
+ jobId: mockJob.id,
186
+ status: JobAuditStatus.COMPLETED,
187
+ };
188
+ findByJobIdSpy.mockResolvedValue(completedAudit);
189
+ await worker.process(mockJob);
190
+ expect(loggerWarnSpy).toHaveBeenCalledWith('Job already processed, skipping', {
191
+ jobId: mockJob.id,
192
+ type: mockJob.name,
193
+ });
194
+ });
195
+ it('should process job if audit check throws', async () => {
196
+ mockJob.attemptsMade = 0;
197
+ findByJobIdSpy.mockRejectedValue(new Error('DB error'));
198
+ processJobSpy.mockResolvedValue(undefined);
199
+ await worker.process(mockJob);
200
+ expect(processJobSpy).toHaveBeenCalled();
201
+ expect(loggerErrorSpy).toHaveBeenCalledWith('Failed to check job completion status', expect.objectContaining({ jobId: mockJob.id }));
202
+ });
203
+ it('should process job if audit returns non-COMPLETED status', async () => {
204
+ mockJob.attemptsMade = 0;
205
+ const processingAudit = {
206
+ jobId: mockJob.id,
207
+ status: JobAuditStatus.PROCESSING,
208
+ };
209
+ findByJobIdSpy.mockResolvedValue(processingAudit);
210
+ processJobSpy.mockResolvedValue(undefined);
211
+ await worker.process(mockJob);
212
+ expect(processJobSpy).toHaveBeenCalled();
213
+ });
214
+ });
215
+ describe('audit resilience', () => {
216
+ let mockAuditRepo;
217
+ let upsertSpy;
218
+ let updateWhereSpy;
219
+ beforeEach(() => {
220
+ mockAuditRepo = createAuditRepositoryMock();
221
+ mockAuditRepo.findByJobId.mockResolvedValue(null);
222
+ worker = new TestWorker(mockAuditRepo);
223
+ processJobSpy = jest.spyOn(worker, 'processJob');
224
+ loggerInfoSpy = jest.spyOn(worker.logger, 'info');
225
+ loggerErrorSpy = jest.spyOn(worker.logger, 'error');
226
+ loggerWarnSpy = jest.spyOn(worker.logger, 'warn');
227
+ upsertSpy = jest.spyOn(mockAuditRepo, 'upsert');
228
+ updateWhereSpy = jest.spyOn(mockAuditRepo, 'updateWhere');
229
+ });
230
+ it('should continue if upsert throws', async () => {
231
+ mockJob.attemptsMade = 0;
232
+ upsertSpy.mockRejectedValue(new Error('Upsert failed'));
233
+ processJobSpy.mockResolvedValue(undefined);
234
+ await worker.process(mockJob);
235
+ expect(processJobSpy).toHaveBeenCalled();
236
+ expect(loggerErrorSpy).toHaveBeenCalledWith('Failed to record audit start', expect.any(Object));
237
+ });
238
+ it('should re-throw if updateWhere throws on success', async () => {
239
+ mockJob.attemptsMade = 0;
240
+ updateWhereSpy.mockRejectedValue(new Error('Update failed'));
241
+ processJobSpy.mockResolvedValue(undefined);
242
+ await expect(worker.process(mockJob)).rejects.toThrow('Update failed');
243
+ expect(processJobSpy).toHaveBeenCalled();
244
+ expect(loggerErrorSpy).toHaveBeenCalledWith('Failed to record audit success', expect.any(Object));
245
+ });
246
+ it('should re-throw if updateWhere throws on failure', async () => {
247
+ mockJob.attemptsMade = 0;
248
+ const originalError = new Error('Job logic failed');
249
+ updateWhereSpy.mockRejectedValue(new Error('Audit update failed'));
250
+ processJobSpy.mockRejectedValue(originalError);
251
+ let thrown;
252
+ try {
253
+ await worker.process(mockJob);
254
+ }
255
+ catch (err) {
256
+ if (err instanceof Error) {
257
+ thrown = err;
258
+ }
259
+ }
260
+ expect(thrown instanceof Error && thrown.message).toBe('Audit update failed');
261
+ expect(processJobSpy).toHaveBeenCalled();
86
262
  });
87
263
  });
88
264
  });
@@ -1 +1 @@
1
- {"version":3,"file":"base.worker.unit.spec.js","sourceRoot":"","sources":["../../../../src/test/specs/base-worker/base.worker.unit.spec.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"base.worker.unit.spec.js","sourceRoot":"","sources":["../../../../src/test/specs/base-worker/base.worker.unit.spec.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"test-worker.utils.d.ts","sourceRoot":"","sources":["../../../../../src/test/utils/helpers/job/test-worker.utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAErC,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAChE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,uDAAuD,CAAC;AAEhG,MAAM,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;AAO7C,qBAAa,UAAW,SAAQ,UAAU,CAAC,WAAW,CAAC;IACrC,MAAM,EAAE,UAAU,CAAsB;IACjD,UAAU,EAAgB,IAAI,CAAC,cAAc,CAAC,CAAC,GAAG,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;gBAG1E,SAAS,CAAC,EAAE,kBAAkB;CAG3C"}
1
+ {"version":3,"file":"test-worker.utils.d.ts","sourceRoot":"","sources":["../../../../../src/test/utils/helpers/job/test-worker.utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAErC,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAChE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,uDAAuD,CAAC;AAEhG,MAAM,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;AAM7C,qBAAa,UAAW,SAAQ,UAAU,CAAC,WAAW,CAAC;IACrC,MAAM,EAAE,UAAU,CAAsB;IACjD,UAAU,EAAgB,IAAI,CAAC,cAAc,CAAC,CAAC,GAAG,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;gBAG1E,SAAS,CAAC,EAAE,kBAAkB;CAG3C"}
@@ -1 +1 @@
1
- {"version":3,"file":"test-worker.utils.js","sourceRoot":"","sources":["../../../../../src/test/utils/helpers/job/test-worker.utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AACrC,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAEzD,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAM7D,SAAS,gBAAgB;IAEvB,OAAO,gBAAgB,EAAiC,CAAC;AAC3D,CAAC;AAED,MAAM,OAAO,UAAW,SAAQ,UAAuB;IACrC,MAAM,GAAe,gBAAgB,EAAE,CAAC;IACjD,UAAU,GAAG,IAAI,CAAC,EAAE,EAA0D,CAAC;IAGtF,YAAY,SAA8B;QACxC,KAAK,CAAC,SAAS,CAAC,CAAC;IACnB,CAAC;CACF"}
1
+ {"version":3,"file":"test-worker.utils.js","sourceRoot":"","sources":["../../../../../src/test/utils/helpers/job/test-worker.utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AACrC,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAEzD,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAM7D,SAAS,gBAAgB;IACvB,OAAO,gBAAgB,EAAU,CAAC;AACpC,CAAC;AAED,MAAM,OAAO,UAAW,SAAQ,UAAuB;IACrC,MAAM,GAAe,gBAAgB,EAAE,CAAC;IACjD,UAAU,GAAG,IAAI,CAAC,EAAE,EAA0D,CAAC;IAGtF,YAAY,SAA8B;QACxC,KAAK,CAAC,SAAS,CAAC,CAAC;IACnB,CAAC;CACF"}
@@ -0,0 +1,4 @@
1
+ import type { JobAuditRepository } from '../../../../data/repositories/job-audit.repository.js';
2
+ import type { jest } from '@jest/globals';
3
+ export declare function createAuditRepositoryMock(): jest.Mocked<JobAuditRepository>;
4
+ //# sourceMappingURL=audit-repository.mock.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"audit-repository.mock.d.ts","sourceRoot":"","sources":["../../../../../src/test/utils/helpers/shared/audit-repository.mock.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,uDAAuD,CAAC;AAChG,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAM1C,wBAAgB,yBAAyB,IAAI,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAE3E"}
@@ -0,0 +1,5 @@
1
+ import { createMock } from '@volontariapp/testing';
2
+ export function createAuditRepositoryMock() {
3
+ return createMock();
4
+ }
5
+ //# sourceMappingURL=audit-repository.mock.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"audit-repository.mock.js","sourceRoot":"","sources":["../../../../../src/test/utils/helpers/shared/audit-repository.mock.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAQnD,MAAM,UAAU,yBAAyB;IACvC,OAAO,UAAU,EAAsB,CAAC;AAC1C,CAAC"}
@@ -1,3 +1,4 @@
1
1
  export * from './database-cleanup.helper.js';
2
2
  export * from './redis-cleanup.helper.js';
3
+ export * from './audit-repository.mock.js';
3
4
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/test/utils/helpers/shared/index.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,2BAA2B,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/test/utils/helpers/shared/index.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,4BAA4B,CAAC"}
@@ -1,3 +1,4 @@
1
1
  export * from './database-cleanup.helper.js';
2
2
  export * from './redis-cleanup.helper.js';
3
+ export * from './audit-repository.mock.js';
3
4
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/test/utils/helpers/shared/index.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,2BAA2B,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/test/utils/helpers/shared/index.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,4BAA4B,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@volontariapp/workers",
3
- "version": "0.1.0-snap-9f9da07",
3
+ "version": "0.1.0-snap-104d75a",
4
4
  "publishConfig": {
5
5
  "access": "public",
6
6
  "provenance": true