@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.
- package/dist/core/base.worker.d.ts +1 -0
- package/dist/core/base.worker.d.ts.map +1 -1
- package/dist/core/base.worker.js +29 -14
- package/dist/core/base.worker.js.map +1 -1
- package/dist/test/specs/base-worker/base.worker.int.helper.d.ts +9 -0
- package/dist/test/specs/base-worker/base.worker.int.helper.d.ts.map +1 -0
- package/dist/test/specs/base-worker/base.worker.int.helper.js +14 -0
- package/dist/test/specs/base-worker/base.worker.int.helper.js.map +1 -0
- package/dist/test/specs/base-worker/base.worker.int.spec.js +442 -113
- package/dist/test/specs/base-worker/base.worker.int.spec.js.map +1 -1
- package/dist/test/specs/base-worker/base.worker.unit.spec.js +200 -24
- package/dist/test/specs/base-worker/base.worker.unit.spec.js.map +1 -1
- package/dist/test/utils/helpers/job/test-worker.utils.d.ts.map +1 -1
- package/dist/test/utils/helpers/job/test-worker.utils.js.map +1 -1
- package/dist/test/utils/helpers/shared/audit-repository.mock.d.ts +4 -0
- package/dist/test/utils/helpers/shared/audit-repository.mock.d.ts.map +1 -0
- package/dist/test/utils/helpers/shared/audit-repository.mock.js +5 -0
- package/dist/test/utils/helpers/shared/audit-repository.mock.js.map +1 -0
- package/dist/test/utils/helpers/shared/index.d.ts +1 -0
- package/dist/test/utils/helpers/shared/index.d.ts.map +1 -1
- package/dist/test/utils/helpers/shared/index.js +1 -0
- package/dist/test/utils/helpers/shared/index.js.map +1 -1
- package/package.json +1 -1
|
@@ -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;
|
|
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"}
|
package/dist/core/base.worker.js
CHANGED
|
@@ -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":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAInC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,MAAM,OAAgB,UAAuC,SAAQ,UAAU;IAI9C;IAHZ,MAAM,GAAG,IAAI,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC;IACxD,QAAQ,GAAW,QAAQ,EAAE,CAAC;IAEjD,YAA+B,SAA8B;QAC3D,KAAK,EAAE,CAAC;QADqB,cAAS,GAAT,SAAS,CAAqB;IAE7D,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,GAAiC,EAAE,MAAe;QAC9D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE;YACjC,KAAK,EAAE,GAAG,CAAC,EAAE;YACb,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACxB,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC;QAE7B,MAAM,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAE5C,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;YAC3B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE;gBAChC,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,IAAI,EAAE,GAAG,CAAC,IAAI;gBACd,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACxB,CAAC,CAAC;YACH,MAAM,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;QACrC,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,EAAE;gBAC9B,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,IAAI,EAAE,GAAG,CAAC,IAAI;gBACd,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,KAAK;aACN,CAAC,CAAC;YACH,MAAM,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;YAC1C,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAIO,KAAK,CAAC,gBAAgB,CAC5B,GAAiC,EACjC,SAAe;QAEf,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,GAAG,CAAC,EAAE;YAAE,OAAO;QAEvC,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,CACzB;gBACE,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,OAAO,EAAE,GAAG,CAAC,IAAI;gBACjB,MAAM,EAAE,cAAc,CAAC,UAAU;gBACjC,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,cAAc,EAAE,GAAG,CAAC,YAAY,GAAG,CAAC;gBACpC,SAAS;aACV,EACD,CAAC,OAAO,CAAC,CACV,CAAC;QACJ,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,8BAA8B,EAAE;gBAChD,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,KAAK;aACN,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,kBAAkB,CAAC,GAAiC;QAChE,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YAC/B,OAAO;QACT,CAAC;QAED,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,SAAS
|
|
1
|
+
{"version":3,"file":"base.worker.js","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;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAInC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,MAAM,OAAgB,UAAuC,SAAQ,UAAU;IAI9C;IAHZ,MAAM,GAAG,IAAI,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC;IACxD,QAAQ,GAAW,QAAQ,EAAE,CAAC;IAEjD,YAA+B,SAA8B;QAC3D,KAAK,EAAE,CAAC;QADqB,cAAS,GAAT,SAAS,CAAqB;IAE7D,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,GAAiC,EAAE,MAAe;QAC9D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE;YACjC,KAAK,EAAE,GAAG,CAAC,EAAE;YACb,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACxB,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC;QAE7B,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC;QAC/D,IAAI,gBAAgB,EAAE,CAAC;YACrB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,iCAAiC,EAAE;gBAClD,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,IAAI,EAAE,GAAG,CAAC,IAAI;aACf,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAED,MAAM,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAE5C,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;YAC3B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE;gBAChC,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,IAAI,EAAE,GAAG,CAAC,IAAI;gBACd,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACxB,CAAC,CAAC;YACH,MAAM,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;QACrC,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,EAAE;gBAC9B,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,IAAI,EAAE,GAAG,CAAC,IAAI;gBACd,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,KAAK;aACN,CAAC,CAAC;YACH,MAAM,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;YAC1C,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAIO,KAAK,CAAC,qBAAqB,CAAC,GAAiC;QACnE,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,GAAG,CAAC,EAAE;YAAE,OAAO,KAAK,CAAC;QAE7C,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACvD,OAAO,KAAK,EAAE,MAAM,KAAK,cAAc,CAAC,SAAS,CAAC;QACpD,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,uCAAuC,EAAE;gBACzD,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,KAAK;aACN,CAAC,CAAC;YACH,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,gBAAgB,CAC5B,GAAiC,EACjC,SAAe;QAEf,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,GAAG,CAAC,EAAE;YAAE,OAAO;QAEvC,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,CACzB;gBACE,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,OAAO,EAAE,GAAG,CAAC,IAAI;gBACjB,MAAM,EAAE,cAAc,CAAC,UAAU;gBACjC,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,cAAc,EAAE,GAAG,CAAC,YAAY,GAAG,CAAC;gBACpC,SAAS;aACV,EACD,CAAC,OAAO,CAAC,CACV,CAAC;QACJ,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,8BAA8B,EAAE;gBAChD,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,KAAK;aACN,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,kBAAkB,CAAC,GAAiC;QAChE,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YAC/B,OAAO;QACT,CAAC;QAED,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,SAAS,CAAC,WAAW,CAC9B,EAAE,KAAK,EAAE,GAAG,CAAC,EAAE,EAAE,EACjB;gBACE,MAAM,EAAE,cAAc,CAAC,SAAS;gBAChC,UAAU,EAAE,IAAI,IAAI,EAAE;aACvB,CACF,CAAC;QACJ,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,gCAAgC,EAAE;gBAClD,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,KAAK;aACN,CAAC,CAAC;YACH,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,kBAAkB,CAC9B,GAAiC,EACjC,KAAc;QAEd,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YAC/B,OAAO;QACT,CAAC;QAED,IAAI,CAAC;YACH,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAC5E,MAAM,UAAU,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;YAEpE,MAAM,IAAI,CAAC,SAAS,CAAC,WAAW,CAC9B,EAAE,KAAK,EAAE,GAAG,CAAC,EAAE,EAAE,EACjB;gBACE,MAAM,EAAE,cAAc,CAAC,MAAM;gBAC7B,YAAY;gBACZ,UAAU;gBACV,UAAU,EAAE,IAAI,IAAI,EAAE;gBACtB,cAAc,EAAE,GAAG,CAAC,YAAY,GAAG,CAAC;aACrC,CACF,CAAC;QACJ,CAAC;QAAC,OAAO,UAAmB,EAAE,CAAC;YAC7B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,gCAAgC,EAAE;gBAClD,KAAK,EAAE,GAAG,CAAC,EAAE;gBACb,KAAK,EAAE,UAAU;aAClB,CAAC,CAAC;YACH,MAAM,UAAU,CAAC;QACnB,CAAC;IACH,CAAC;CACF"}
|
|
@@ -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
|
|
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('
|
|
30
|
-
const jobId = 'int-success-001';
|
|
31
|
-
const
|
|
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
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
expect(audit
|
|
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('
|
|
48
|
-
const jobId = 'int-meta-001';
|
|
49
|
-
const
|
|
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
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
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('
|
|
66
|
-
const jobId = 'int-fail-001';
|
|
67
|
-
const
|
|
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
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
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('
|
|
83
|
-
const jobId = 'int-fail-string-001';
|
|
84
|
-
const
|
|
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
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
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('
|
|
100
|
-
const jobId = 'int-
|
|
101
|
-
const
|
|
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
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
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('
|
|
121
|
-
const jobId = 'int-
|
|
122
|
-
const
|
|
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
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
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(
|
|
136
|
-
const jobId = 'int-no-audit-001';
|
|
137
|
-
const
|
|
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
|
-
|
|
142
|
-
|
|
143
|
-
|
|
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('
|
|
148
|
-
const jobId = 'int-ts-001';
|
|
149
|
-
const
|
|
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
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
expect(audit
|
|
164
|
-
|
|
165
|
-
|
|
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":"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"}
|
|
@@ -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
|
-
|
|
23
|
+
processJobSpy.mockResolvedValue(undefined);
|
|
15
24
|
await worker.process(mockJob);
|
|
16
|
-
expect(
|
|
17
|
-
expect(
|
|
25
|
+
expect(processJobSpy).toHaveBeenCalledTimes(1);
|
|
26
|
+
expect(processJobSpy).toHaveBeenCalledWith(mockJob);
|
|
18
27
|
});
|
|
19
28
|
it('should log "Processing job" before execution', async () => {
|
|
20
|
-
|
|
29
|
+
processJobSpy.mockResolvedValue(undefined);
|
|
21
30
|
await worker.process(mockJob);
|
|
22
|
-
expect(
|
|
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
|
-
|
|
38
|
+
processJobSpy.mockResolvedValue(undefined);
|
|
30
39
|
await worker.process(mockJob);
|
|
31
|
-
expect(
|
|
32
|
-
expect(
|
|
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
|
-
|
|
48
|
+
processJobSpy.mockResolvedValue(undefined);
|
|
40
49
|
await worker.process(mockJob);
|
|
41
|
-
expect(
|
|
50
|
+
expect(loggerErrorSpy).not.toHaveBeenCalled();
|
|
42
51
|
});
|
|
43
52
|
it('should ignore the optional token parameter', async () => {
|
|
44
|
-
|
|
53
|
+
processJobSpy.mockResolvedValue(undefined);
|
|
45
54
|
await worker.process(mockJob, 'some-bullmq-token');
|
|
46
|
-
expect(
|
|
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
|
-
|
|
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
|
-
|
|
66
|
+
processJobSpy.mockRejectedValue(error);
|
|
58
67
|
await expect(worker.process(mockJob)).rejects.toThrow();
|
|
59
|
-
expect(
|
|
60
|
-
expect(
|
|
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
|
-
|
|
77
|
+
processJobSpy.mockRejectedValue(new Error('fail'));
|
|
69
78
|
await expect(worker.process(mockJob)).rejects.toThrow();
|
|
70
|
-
expect(
|
|
71
|
-
expect(
|
|
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
|
-
|
|
84
|
+
processJobSpy.mockRejectedValue(thrown);
|
|
76
85
|
await expect(worker.process(mockJob)).rejects.toBe(thrown);
|
|
77
|
-
expect(
|
|
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
|
-
|
|
92
|
+
processJobSpy.mockResolvedValue(undefined);
|
|
84
93
|
await worker.process(typedJob);
|
|
85
|
-
expect(
|
|
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;
|
|
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;
|
|
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 @@
|
|
|
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 +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 +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"}
|