@talkpilot/core-db 1.1.19 → 1.2.0
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/.cursor/rules/development.mdc +65 -65
- package/DEVELOPMENT.md +98 -98
- package/README.md +160 -160
- package/dist/talkpilot/calls/calls.getters.d.ts +2 -1
- package/dist/talkpilot/calls/calls.getters.d.ts.map +1 -1
- package/dist/talkpilot/calls/calls.getters.js +176 -0
- package/dist/talkpilot/calls/calls.getters.js.map +1 -1
- package/dist/talkpilot/calls/calls.types.d.ts +48 -0
- package/dist/talkpilot/calls/calls.types.d.ts.map +1 -1
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.d.ts +1 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.d.ts.map +1 -1
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.js +13 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.js.map +1 -1
- package/jest.config.js +19 -19
- package/package.json +45 -45
- package/src/__tests__/setup.ts +20 -20
- package/src/connection.ts +42 -42
- package/src/index.ts +16 -16
- package/src/municipal/__tests__/validation.spec.ts +62 -62
- package/src/municipal/cities/cities.getters.ts +50 -50
- package/src/municipal/cities/cities.types.ts +11 -11
- package/src/municipal/cities/index.ts +2 -2
- package/src/municipal/departmentsSubjects/departmentsSubjects.getters.ts +282 -282
- package/src/municipal/departmentsSubjects/departmentsSubjects.types.ts +72 -72
- package/src/municipal/departmentsSubjects/index.ts +9 -9
- package/src/municipal/index.ts +21 -21
- package/src/municipal/mongodb-client.ts +61 -61
- package/src/municipal/streets/index.ts +2 -2
- package/src/municipal/streets/streets.getters.ts +125 -125
- package/src/municipal/streets/streets.types.ts +18 -18
- package/src/municipal/systemInstructions/__tests__/getters.spec.ts +113 -113
- package/src/municipal/systemInstructions/__tests__/setters.spec.ts +274 -274
- package/src/municipal/systemInstructions/index.ts +7 -7
- package/src/municipal/systemInstructions/instructions.getters.ts +57 -57
- package/src/municipal/systemInstructions/instructions.setters.ts +119 -119
- package/src/municipal/systemInstructions/instructions.types.ts +30 -30
- package/src/municipal/tickets/__tests__/tickets.getters.spec.ts +66 -66
- package/src/municipal/tickets/index.ts +2 -2
- package/src/municipal/tickets/tickets.getters.ts +261 -261
- package/src/municipal/tickets/tickets.types.ts +43 -43
- package/src/municipal/utils/types.ts +11 -11
- package/src/talkpilot/__tests__/db.spec.ts +38 -38
- package/src/talkpilot/__tests__/mongodb-client.spec.ts +18 -18
- package/src/talkpilot/__tests__/validation.spec.ts +68 -68
- package/src/talkpilot/agents/__tests__/agents.getters.spec.ts +29 -29
- package/src/talkpilot/agents/agents.getters.ts +34 -34
- package/src/talkpilot/agents/agents.types.ts +14 -14
- package/src/talkpilot/agents/index.ts +2 -2
- package/src/talkpilot/backgroundToolResults/__tests__/backgroundToolResults.getters.spec.ts +147 -147
- package/src/talkpilot/backgroundToolResults/backgroundToolResults.getters.ts +65 -65
- package/src/talkpilot/backgroundToolResults/backgroundToolResults.types.ts +23 -23
- package/src/talkpilot/backgroundToolResults/index.ts +2 -2
- package/src/talkpilot/calls/__tests__/callStats.utils.spec.ts +128 -128
- package/src/talkpilot/calls/__tests__/calls.spec.ts +252 -252
- package/src/talkpilot/calls/calls.getters.ts +446 -248
- package/src/talkpilot/calls/calls.types.ts +171 -115
- package/src/talkpilot/calls/index.ts +2 -2
- package/src/talkpilot/clientAudioBuffers/__tests__/clientAudioBuffer.getters.spec.ts +160 -160
- package/src/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.ts +117 -117
- package/src/talkpilot/clientAudioBuffers/clientsAudioBuffers.types.ts +25 -25
- package/src/talkpilot/clientAudioBuffers/index.ts +2 -2
- package/src/talkpilot/clients/clients.getters.ts +16 -16
- package/src/talkpilot/clients/clients.types.ts +14 -14
- package/src/talkpilot/clients/index.ts +2 -2
- package/src/talkpilot/clientsConfig/__tests__/clientsConfig.spec.ts +106 -106
- package/src/talkpilot/clientsConfig/clientsConfig.getters.ts +44 -22
- package/src/talkpilot/clientsConfig/clientsConfig.types.ts +94 -94
- package/src/talkpilot/clientsConfig/index.ts +2 -2
- package/src/talkpilot/flows/__tests__/flows.schema.spec.ts +67 -67
- package/src/talkpilot/flows/flows.getter.ts +14 -14
- package/src/talkpilot/flows/flows.schema.ts +153 -153
- package/src/talkpilot/flows/flows.types.ts +184 -184
- package/src/talkpilot/flows/index.ts +2 -2
- package/src/talkpilot/groups/__tests__/groups.spec.ts +90 -90
- package/src/talkpilot/groups/__tests__/phone.utils.spec.ts +32 -32
- package/src/talkpilot/groups/groups.getters.ts +30 -30
- package/src/talkpilot/groups/groups.types.ts +29 -29
- package/src/talkpilot/groups/index.ts +3 -3
- package/src/talkpilot/groups/phone.utils.ts +46 -46
- package/src/talkpilot/index.ts +29 -29
- package/src/talkpilot/leads/index.ts +2 -2
- package/src/talkpilot/leads/leads.getter.ts +6 -6
- package/src/talkpilot/leads/leads.schema.ts +33 -33
- package/src/talkpilot/leads/leads.types.ts +20 -20
- package/src/talkpilot/mongodb-client.ts +78 -78
- package/src/talkpilot/phone_numbers/__tests__/phone_numbers.spec.ts +247 -247
- package/src/talkpilot/phone_numbers/index.ts +2 -2
- package/src/talkpilot/phone_numbers/phone_numbers.getter.ts +154 -154
- package/src/talkpilot/phone_numbers/phone_numbers.schema.ts +17 -17
- package/src/talkpilot/phone_numbers/phone_numbers.types.ts +30 -30
- package/src/talkpilot/plans/__tests__/plans.spec.ts +70 -70
- package/src/talkpilot/plans/index.ts +2 -2
- package/src/talkpilot/plans/plans.getters.ts +132 -132
- package/src/talkpilot/plans/plans.types.ts +89 -89
- package/src/talkpilot/results/index.ts +7 -7
- package/src/talkpilot/results/results.getter.ts +35 -35
- package/src/talkpilot/results/results.schema.ts +25 -25
- package/src/talkpilot/results/results.types.ts +34 -34
- package/src/talkpilot/retry_analyze/__tests__/retryAnalyze.getters.spec.ts +156 -156
- package/src/talkpilot/retry_analyze/index.ts +2 -2
- package/src/talkpilot/retry_analyze/retryAnalyze.getters.ts +75 -75
- package/src/talkpilot/retry_analyze/retryAnalyze.types.ts +13 -13
- package/src/talkpilot/sessions/__tests__/sessions.spec.ts +147 -147
- package/src/talkpilot/sessions/index.ts +2 -2
- package/src/talkpilot/sessions/sessions.getter.ts +92 -92
- package/src/talkpilot/sessions/sessions.schema.ts +34 -34
- package/src/talkpilot/sessions/sessions.types.ts +30 -30
- package/src/talkpilot/subscriptions/__tests__/subscriptions.getters.utils.spec.ts +45 -45
- package/src/talkpilot/subscriptions/index.ts +3 -3
- package/src/talkpilot/subscriptions/subscriptions.getters.ts +146 -146
- package/src/talkpilot/subscriptions/subscriptions.getters.utils.ts +33 -33
- package/src/talkpilot/subscriptions/subscriptions.types.ts +66 -66
- package/src/talkpilot/utils/__tests__/query.utils.spec.ts +49 -49
- package/src/talkpilot/utils/query.utils.ts +21 -21
- package/src/test-utils/db-utils.ts +24 -24
- package/src/test-utils/factories/index.ts +12 -12
- package/src/test-utils/factories/municipal/cities.ts +16 -16
- package/src/test-utils/factories/municipal/departmentsSubjects.ts +37 -37
- package/src/test-utils/factories/municipal/streets.ts +22 -22
- package/src/test-utils/factories/municipal/tickets.ts +39 -39
- package/src/test-utils/factories/talkpilot/agents.ts +19 -19
- package/src/test-utils/factories/talkpilot/calls.ts +37 -37
- package/src/test-utils/factories/talkpilot/clientAudioBuffers.ts +20 -20
- package/src/test-utils/factories/talkpilot/clientsConfig.ts +18 -18
- package/src/test-utils/factories/talkpilot/flows.ts +33 -33
- package/src/test-utils/factories/talkpilot/groups.ts +33 -33
- package/src/test-utils/factories/talkpilot/phone_numbers.ts +22 -22
- package/src/test-utils/factories/talkpilot/sessions.ts +35 -35
- package/src/utils/validation.ts +23 -23
- package/tsconfig.json +23 -23
|
@@ -1,156 +1,156 @@
|
|
|
1
|
-
import { describe, it, expect, beforeEach, jest } from "@jest/globals";
|
|
2
|
-
import { ObjectId } from "mongodb";
|
|
3
|
-
import {
|
|
4
|
-
getAllRetryAnalyzeDocs,
|
|
5
|
-
upsertRetryAnalyzeDoc,
|
|
6
|
-
insertRetryAnalyzeDoc,
|
|
7
|
-
updateRetryAnalyzeErrorLog,
|
|
8
|
-
} from "../retryAnalyze.getters";
|
|
9
|
-
import { setDb } from "../../index";
|
|
10
|
-
import { RetryAnalyzeDoc } from "../retryAnalyze.types";
|
|
11
|
-
|
|
12
|
-
describe("retryAnalyze.getters", () => {
|
|
13
|
-
let mockCollection: any;
|
|
14
|
-
let mockDb: any;
|
|
15
|
-
|
|
16
|
-
beforeEach(() => {
|
|
17
|
-
mockCollection = {
|
|
18
|
-
find: jest.fn().mockReturnThis(),
|
|
19
|
-
toArray: jest.fn(),
|
|
20
|
-
insertOne: jest.fn(),
|
|
21
|
-
updateOne: jest.fn(),
|
|
22
|
-
deleteOne: jest.fn(),
|
|
23
|
-
};
|
|
24
|
-
mockDb = {
|
|
25
|
-
collection: jest.fn().mockReturnValue(mockCollection),
|
|
26
|
-
};
|
|
27
|
-
setDb(mockDb as any);
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
describe("getAllRetryAnalyzeDocs", () => {
|
|
31
|
-
it("should filter documents with retry >= 5 and include old format docs", async () => {
|
|
32
|
-
const mockDocs = [
|
|
33
|
-
{ _id: new ObjectId(), callSid: "old-doc", errorLog: "{}" },
|
|
34
|
-
{ _id: new ObjectId(), callSid: "retry-1", errorLog: "{}", retry: 1 },
|
|
35
|
-
{ _id: new ObjectId(), callSid: "retry-5", errorLog: "{}", retry: 5 },
|
|
36
|
-
];
|
|
37
|
-
|
|
38
|
-
mockCollection.toArray.mockResolvedValue(mockDocs);
|
|
39
|
-
|
|
40
|
-
await getAllRetryAnalyzeDocs();
|
|
41
|
-
|
|
42
|
-
expect(mockCollection.find).toHaveBeenCalledWith({
|
|
43
|
-
$or: [{ retry: { $lt: 5 } }, { retry: { $exists: false } }],
|
|
44
|
-
});
|
|
45
|
-
});
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
describe("upsertRetryAnalyzeDoc", () => {
|
|
49
|
-
const error429 = JSON.stringify({
|
|
50
|
-
error: {
|
|
51
|
-
code: 429,
|
|
52
|
-
message: "Resource exhausted. Please try again later.",
|
|
53
|
-
status: "RESOURCE_EXHAUSTED",
|
|
54
|
-
},
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
it("should upsert document correctly with $setOnInsert for clientId and createdAt", async () => {
|
|
58
|
-
const doc = {
|
|
59
|
-
callSid: "call-123",
|
|
60
|
-
errorLog: error429,
|
|
61
|
-
clientId: "client-1",
|
|
62
|
-
};
|
|
63
|
-
|
|
64
|
-
mockCollection.updateOne.mockResolvedValue({
|
|
65
|
-
upsertedId: new ObjectId(),
|
|
66
|
-
matchedCount: 0,
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
await upsertRetryAnalyzeDoc(doc);
|
|
70
|
-
|
|
71
|
-
expect(mockCollection.updateOne).toHaveBeenCalledWith(
|
|
72
|
-
{ callSid: doc.callSid },
|
|
73
|
-
expect.objectContaining({
|
|
74
|
-
$set: expect.objectContaining({
|
|
75
|
-
errorLog: doc.errorLog,
|
|
76
|
-
updatedAt: expect.any(Date),
|
|
77
|
-
}),
|
|
78
|
-
$setOnInsert: expect.objectContaining({
|
|
79
|
-
createdAt: expect.any(Date),
|
|
80
|
-
clientId: doc.clientId,
|
|
81
|
-
retry: 0,
|
|
82
|
-
}),
|
|
83
|
-
}),
|
|
84
|
-
{ upsert: true },
|
|
85
|
-
);
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
it("should ensure only one document exists for the same callSid even on multiple failures", async () => {
|
|
89
|
-
const doc = {
|
|
90
|
-
callSid: "CA_SINGLE_DOC",
|
|
91
|
-
errorLog: error429,
|
|
92
|
-
clientId: "client-1",
|
|
93
|
-
};
|
|
94
|
-
|
|
95
|
-
mockCollection.updateOne
|
|
96
|
-
.mockResolvedValueOnce({ upsertedId: new ObjectId(), matchedCount: 0 })
|
|
97
|
-
.mockResolvedValueOnce({ upsertedId: null, matchedCount: 1 });
|
|
98
|
-
|
|
99
|
-
await upsertRetryAnalyzeDoc(doc);
|
|
100
|
-
await upsertRetryAnalyzeDoc(doc);
|
|
101
|
-
|
|
102
|
-
expect(mockCollection.updateOne).toHaveBeenCalledWith(
|
|
103
|
-
{ callSid: doc.callSid },
|
|
104
|
-
expect.objectContaining({
|
|
105
|
-
$setOnInsert: expect.objectContaining({ retry: 0 }),
|
|
106
|
-
}),
|
|
107
|
-
{ upsert: true },
|
|
108
|
-
);
|
|
109
|
-
|
|
110
|
-
expect(mockCollection.updateOne).toHaveBeenLastCalledWith(
|
|
111
|
-
{ callSid: doc.callSid },
|
|
112
|
-
{ $inc: { retry: 1 } },
|
|
113
|
-
);
|
|
114
|
-
});
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
describe("insertRetryAnalyzeDoc", () => {
|
|
118
|
-
it("should perform a simple insert", async () => {
|
|
119
|
-
const doc: Omit<RetryAnalyzeDoc, "_id"> = {
|
|
120
|
-
callSid: "call-456",
|
|
121
|
-
retry: 0,
|
|
122
|
-
clientId: "client-2",
|
|
123
|
-
errorLog: "err",
|
|
124
|
-
updatedAt: new Date(),
|
|
125
|
-
createdAt: new Date(),
|
|
126
|
-
};
|
|
127
|
-
|
|
128
|
-
mockCollection.insertOne.mockResolvedValue({
|
|
129
|
-
insertedId: new ObjectId(),
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
await insertRetryAnalyzeDoc(doc);
|
|
133
|
-
|
|
134
|
-
expect(mockCollection.insertOne).toHaveBeenCalledWith(doc);
|
|
135
|
-
});
|
|
136
|
-
});
|
|
137
|
-
|
|
138
|
-
describe("updateRetryAnalyzeErrorLog", () => {
|
|
139
|
-
it("should update errorLog, updatedAt and increment retry", async () => {
|
|
140
|
-
const id = new ObjectId();
|
|
141
|
-
const errorLog = "new retry error";
|
|
142
|
-
|
|
143
|
-
mockCollection.updateOne.mockResolvedValue({ modifiedCount: 1 });
|
|
144
|
-
|
|
145
|
-
await updateRetryAnalyzeErrorLog(id, errorLog);
|
|
146
|
-
|
|
147
|
-
expect(mockCollection.updateOne).toHaveBeenCalledWith(
|
|
148
|
-
{ _id: id },
|
|
149
|
-
{
|
|
150
|
-
$set: { errorLog, updatedAt: expect.any(Date) },
|
|
151
|
-
$inc: { retry: 1 },
|
|
152
|
-
},
|
|
153
|
-
);
|
|
154
|
-
});
|
|
155
|
-
});
|
|
156
|
-
});
|
|
1
|
+
import { describe, it, expect, beforeEach, jest } from "@jest/globals";
|
|
2
|
+
import { ObjectId } from "mongodb";
|
|
3
|
+
import {
|
|
4
|
+
getAllRetryAnalyzeDocs,
|
|
5
|
+
upsertRetryAnalyzeDoc,
|
|
6
|
+
insertRetryAnalyzeDoc,
|
|
7
|
+
updateRetryAnalyzeErrorLog,
|
|
8
|
+
} from "../retryAnalyze.getters";
|
|
9
|
+
import { setDb } from "../../index";
|
|
10
|
+
import { RetryAnalyzeDoc } from "../retryAnalyze.types";
|
|
11
|
+
|
|
12
|
+
describe("retryAnalyze.getters", () => {
|
|
13
|
+
let mockCollection: any;
|
|
14
|
+
let mockDb: any;
|
|
15
|
+
|
|
16
|
+
beforeEach(() => {
|
|
17
|
+
mockCollection = {
|
|
18
|
+
find: jest.fn().mockReturnThis(),
|
|
19
|
+
toArray: jest.fn(),
|
|
20
|
+
insertOne: jest.fn(),
|
|
21
|
+
updateOne: jest.fn(),
|
|
22
|
+
deleteOne: jest.fn(),
|
|
23
|
+
};
|
|
24
|
+
mockDb = {
|
|
25
|
+
collection: jest.fn().mockReturnValue(mockCollection),
|
|
26
|
+
};
|
|
27
|
+
setDb(mockDb as any);
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
describe("getAllRetryAnalyzeDocs", () => {
|
|
31
|
+
it("should filter documents with retry >= 5 and include old format docs", async () => {
|
|
32
|
+
const mockDocs = [
|
|
33
|
+
{ _id: new ObjectId(), callSid: "old-doc", errorLog: "{}" },
|
|
34
|
+
{ _id: new ObjectId(), callSid: "retry-1", errorLog: "{}", retry: 1 },
|
|
35
|
+
{ _id: new ObjectId(), callSid: "retry-5", errorLog: "{}", retry: 5 },
|
|
36
|
+
];
|
|
37
|
+
|
|
38
|
+
mockCollection.toArray.mockResolvedValue(mockDocs);
|
|
39
|
+
|
|
40
|
+
await getAllRetryAnalyzeDocs();
|
|
41
|
+
|
|
42
|
+
expect(mockCollection.find).toHaveBeenCalledWith({
|
|
43
|
+
$or: [{ retry: { $lt: 5 } }, { retry: { $exists: false } }],
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
describe("upsertRetryAnalyzeDoc", () => {
|
|
49
|
+
const error429 = JSON.stringify({
|
|
50
|
+
error: {
|
|
51
|
+
code: 429,
|
|
52
|
+
message: "Resource exhausted. Please try again later.",
|
|
53
|
+
status: "RESOURCE_EXHAUSTED",
|
|
54
|
+
},
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
it("should upsert document correctly with $setOnInsert for clientId and createdAt", async () => {
|
|
58
|
+
const doc = {
|
|
59
|
+
callSid: "call-123",
|
|
60
|
+
errorLog: error429,
|
|
61
|
+
clientId: "client-1",
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
mockCollection.updateOne.mockResolvedValue({
|
|
65
|
+
upsertedId: new ObjectId(),
|
|
66
|
+
matchedCount: 0,
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
await upsertRetryAnalyzeDoc(doc);
|
|
70
|
+
|
|
71
|
+
expect(mockCollection.updateOne).toHaveBeenCalledWith(
|
|
72
|
+
{ callSid: doc.callSid },
|
|
73
|
+
expect.objectContaining({
|
|
74
|
+
$set: expect.objectContaining({
|
|
75
|
+
errorLog: doc.errorLog,
|
|
76
|
+
updatedAt: expect.any(Date),
|
|
77
|
+
}),
|
|
78
|
+
$setOnInsert: expect.objectContaining({
|
|
79
|
+
createdAt: expect.any(Date),
|
|
80
|
+
clientId: doc.clientId,
|
|
81
|
+
retry: 0,
|
|
82
|
+
}),
|
|
83
|
+
}),
|
|
84
|
+
{ upsert: true },
|
|
85
|
+
);
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
it("should ensure only one document exists for the same callSid even on multiple failures", async () => {
|
|
89
|
+
const doc = {
|
|
90
|
+
callSid: "CA_SINGLE_DOC",
|
|
91
|
+
errorLog: error429,
|
|
92
|
+
clientId: "client-1",
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
mockCollection.updateOne
|
|
96
|
+
.mockResolvedValueOnce({ upsertedId: new ObjectId(), matchedCount: 0 })
|
|
97
|
+
.mockResolvedValueOnce({ upsertedId: null, matchedCount: 1 });
|
|
98
|
+
|
|
99
|
+
await upsertRetryAnalyzeDoc(doc);
|
|
100
|
+
await upsertRetryAnalyzeDoc(doc);
|
|
101
|
+
|
|
102
|
+
expect(mockCollection.updateOne).toHaveBeenCalledWith(
|
|
103
|
+
{ callSid: doc.callSid },
|
|
104
|
+
expect.objectContaining({
|
|
105
|
+
$setOnInsert: expect.objectContaining({ retry: 0 }),
|
|
106
|
+
}),
|
|
107
|
+
{ upsert: true },
|
|
108
|
+
);
|
|
109
|
+
|
|
110
|
+
expect(mockCollection.updateOne).toHaveBeenLastCalledWith(
|
|
111
|
+
{ callSid: doc.callSid },
|
|
112
|
+
{ $inc: { retry: 1 } },
|
|
113
|
+
);
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
describe("insertRetryAnalyzeDoc", () => {
|
|
118
|
+
it("should perform a simple insert", async () => {
|
|
119
|
+
const doc: Omit<RetryAnalyzeDoc, "_id"> = {
|
|
120
|
+
callSid: "call-456",
|
|
121
|
+
retry: 0,
|
|
122
|
+
clientId: "client-2",
|
|
123
|
+
errorLog: "err",
|
|
124
|
+
updatedAt: new Date(),
|
|
125
|
+
createdAt: new Date(),
|
|
126
|
+
};
|
|
127
|
+
|
|
128
|
+
mockCollection.insertOne.mockResolvedValue({
|
|
129
|
+
insertedId: new ObjectId(),
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
await insertRetryAnalyzeDoc(doc);
|
|
133
|
+
|
|
134
|
+
expect(mockCollection.insertOne).toHaveBeenCalledWith(doc);
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
|
|
138
|
+
describe("updateRetryAnalyzeErrorLog", () => {
|
|
139
|
+
it("should update errorLog, updatedAt and increment retry", async () => {
|
|
140
|
+
const id = new ObjectId();
|
|
141
|
+
const errorLog = "new retry error";
|
|
142
|
+
|
|
143
|
+
mockCollection.updateOne.mockResolvedValue({ modifiedCount: 1 });
|
|
144
|
+
|
|
145
|
+
await updateRetryAnalyzeErrorLog(id, errorLog);
|
|
146
|
+
|
|
147
|
+
expect(mockCollection.updateOne).toHaveBeenCalledWith(
|
|
148
|
+
{ _id: id },
|
|
149
|
+
{
|
|
150
|
+
$set: { errorLog, updatedAt: expect.any(Date) },
|
|
151
|
+
$inc: { retry: 1 },
|
|
152
|
+
},
|
|
153
|
+
);
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
});
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from "./retryAnalyze.types";
|
|
2
|
-
export * from "./retryAnalyze.getters";
|
|
1
|
+
export * from "./retryAnalyze.types";
|
|
2
|
+
export * from "./retryAnalyze.getters";
|
|
@@ -1,75 +1,75 @@
|
|
|
1
|
-
import { Collection, ObjectId } from "mongodb";
|
|
2
|
-
import { getDb } from "../index";
|
|
3
|
-
import type { RetryAnalyzeDoc, RetryAnalyzeWithId } from "./retryAnalyze.types";
|
|
4
|
-
|
|
5
|
-
const COLLECTION_NAME = "retryAnalyze";
|
|
6
|
-
|
|
7
|
-
export const getRetryAnalyzeCollection = (): Collection<RetryAnalyzeDoc> => {
|
|
8
|
-
return getDb().collection<RetryAnalyzeDoc>(COLLECTION_NAME);
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
export const getAllRetryAnalyzeDocs = async (): Promise<RetryAnalyzeWithId[]> => {
|
|
12
|
-
return getRetryAnalyzeCollection()
|
|
13
|
-
.find({
|
|
14
|
-
$or: [{ retry: { $lt: 5 } }, { retry: { $exists: false } }],
|
|
15
|
-
})
|
|
16
|
-
.toArray();
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
export const insertRetryAnalyzeDoc = async (
|
|
20
|
-
doc: Omit<RetryAnalyzeDoc, "_id">,
|
|
21
|
-
): Promise<ObjectId> => {
|
|
22
|
-
const result = await getRetryAnalyzeCollection().insertOne(doc);
|
|
23
|
-
return result.insertedId;
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
export const upsertRetryAnalyzeDoc = async (
|
|
27
|
-
doc: Pick<RetryAnalyzeDoc, "callSid" | "errorLog" | "clientId">,
|
|
28
|
-
): Promise<ObjectId | null> => {
|
|
29
|
-
const now = new Date();
|
|
30
|
-
const result = await getRetryAnalyzeCollection().updateOne(
|
|
31
|
-
{ callSid: doc.callSid },
|
|
32
|
-
{
|
|
33
|
-
$set: {
|
|
34
|
-
errorLog: doc.errorLog,
|
|
35
|
-
updatedAt: now,
|
|
36
|
-
},
|
|
37
|
-
$setOnInsert: {
|
|
38
|
-
createdAt: now,
|
|
39
|
-
clientId: doc.clientId,
|
|
40
|
-
retry: 0,
|
|
41
|
-
},
|
|
42
|
-
},
|
|
43
|
-
{ upsert: true },
|
|
44
|
-
);
|
|
45
|
-
|
|
46
|
-
if (result.matchedCount > 0) {
|
|
47
|
-
await getRetryAnalyzeCollection().updateOne({ callSid: doc.callSid }, { $inc: { retry: 1 } });
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
return result.upsertedId || null;
|
|
51
|
-
};
|
|
52
|
-
|
|
53
|
-
export const deleteRetryAnalyzeDocById = async (id: ObjectId): Promise<boolean> => {
|
|
54
|
-
const result = await getRetryAnalyzeCollection().deleteOne({ _id: id });
|
|
55
|
-
return result.deletedCount === 1;
|
|
56
|
-
};
|
|
57
|
-
|
|
58
|
-
export const deleteRetryAnalyzeDocByCallSid = async (callSid: string): Promise<boolean> => {
|
|
59
|
-
const result = await getRetryAnalyzeCollection().deleteOne({ callSid });
|
|
60
|
-
return result.deletedCount === 1;
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
export const updateRetryAnalyzeErrorLog = async (
|
|
64
|
-
id: ObjectId,
|
|
65
|
-
errorLog: string,
|
|
66
|
-
): Promise<boolean> => {
|
|
67
|
-
const result = await getRetryAnalyzeCollection().updateOne(
|
|
68
|
-
{ _id: id },
|
|
69
|
-
{
|
|
70
|
-
$set: { errorLog, updatedAt: new Date() },
|
|
71
|
-
$inc: { retry: 1 },
|
|
72
|
-
},
|
|
73
|
-
);
|
|
74
|
-
return result.modifiedCount === 1;
|
|
75
|
-
};
|
|
1
|
+
import { Collection, ObjectId } from "mongodb";
|
|
2
|
+
import { getDb } from "../index";
|
|
3
|
+
import type { RetryAnalyzeDoc, RetryAnalyzeWithId } from "./retryAnalyze.types";
|
|
4
|
+
|
|
5
|
+
const COLLECTION_NAME = "retryAnalyze";
|
|
6
|
+
|
|
7
|
+
export const getRetryAnalyzeCollection = (): Collection<RetryAnalyzeDoc> => {
|
|
8
|
+
return getDb().collection<RetryAnalyzeDoc>(COLLECTION_NAME);
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export const getAllRetryAnalyzeDocs = async (): Promise<RetryAnalyzeWithId[]> => {
|
|
12
|
+
return getRetryAnalyzeCollection()
|
|
13
|
+
.find({
|
|
14
|
+
$or: [{ retry: { $lt: 5 } }, { retry: { $exists: false } }],
|
|
15
|
+
})
|
|
16
|
+
.toArray();
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
export const insertRetryAnalyzeDoc = async (
|
|
20
|
+
doc: Omit<RetryAnalyzeDoc, "_id">,
|
|
21
|
+
): Promise<ObjectId> => {
|
|
22
|
+
const result = await getRetryAnalyzeCollection().insertOne(doc);
|
|
23
|
+
return result.insertedId;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
export const upsertRetryAnalyzeDoc = async (
|
|
27
|
+
doc: Pick<RetryAnalyzeDoc, "callSid" | "errorLog" | "clientId">,
|
|
28
|
+
): Promise<ObjectId | null> => {
|
|
29
|
+
const now = new Date();
|
|
30
|
+
const result = await getRetryAnalyzeCollection().updateOne(
|
|
31
|
+
{ callSid: doc.callSid },
|
|
32
|
+
{
|
|
33
|
+
$set: {
|
|
34
|
+
errorLog: doc.errorLog,
|
|
35
|
+
updatedAt: now,
|
|
36
|
+
},
|
|
37
|
+
$setOnInsert: {
|
|
38
|
+
createdAt: now,
|
|
39
|
+
clientId: doc.clientId,
|
|
40
|
+
retry: 0,
|
|
41
|
+
},
|
|
42
|
+
},
|
|
43
|
+
{ upsert: true },
|
|
44
|
+
);
|
|
45
|
+
|
|
46
|
+
if (result.matchedCount > 0) {
|
|
47
|
+
await getRetryAnalyzeCollection().updateOne({ callSid: doc.callSid }, { $inc: { retry: 1 } });
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
return result.upsertedId || null;
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
export const deleteRetryAnalyzeDocById = async (id: ObjectId): Promise<boolean> => {
|
|
54
|
+
const result = await getRetryAnalyzeCollection().deleteOne({ _id: id });
|
|
55
|
+
return result.deletedCount === 1;
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
export const deleteRetryAnalyzeDocByCallSid = async (callSid: string): Promise<boolean> => {
|
|
59
|
+
const result = await getRetryAnalyzeCollection().deleteOne({ callSid });
|
|
60
|
+
return result.deletedCount === 1;
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
export const updateRetryAnalyzeErrorLog = async (
|
|
64
|
+
id: ObjectId,
|
|
65
|
+
errorLog: string,
|
|
66
|
+
): Promise<boolean> => {
|
|
67
|
+
const result = await getRetryAnalyzeCollection().updateOne(
|
|
68
|
+
{ _id: id },
|
|
69
|
+
{
|
|
70
|
+
$set: { errorLog, updatedAt: new Date() },
|
|
71
|
+
$inc: { retry: 1 },
|
|
72
|
+
},
|
|
73
|
+
);
|
|
74
|
+
return result.modifiedCount === 1;
|
|
75
|
+
};
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { ObjectId, WithId } from "mongodb";
|
|
2
|
-
|
|
3
|
-
export type RetryAnalyzeDoc = {
|
|
4
|
-
_id?: ObjectId;
|
|
5
|
-
callSid: string;
|
|
6
|
-
retry: number;
|
|
7
|
-
clientId: string;
|
|
8
|
-
errorLog: string;
|
|
9
|
-
updatedAt: Date;
|
|
10
|
-
createdAt: Date;
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
export type RetryAnalyzeWithId = WithId<RetryAnalyzeDoc>;
|
|
1
|
+
import { ObjectId, WithId } from "mongodb";
|
|
2
|
+
|
|
3
|
+
export type RetryAnalyzeDoc = {
|
|
4
|
+
_id?: ObjectId;
|
|
5
|
+
callSid: string;
|
|
6
|
+
retry: number;
|
|
7
|
+
clientId: string;
|
|
8
|
+
errorLog: string;
|
|
9
|
+
updatedAt: Date;
|
|
10
|
+
createdAt: Date;
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export type RetryAnalyzeWithId = WithId<RetryAnalyzeDoc>;
|