@agentica/core 0.19.0 → 0.20.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.
Files changed (59) hide show
  1. package/lib/context/AgenticaOperation.d.ts +3 -4
  2. package/lib/context/internal/AgenticaOperationComposer.js +8 -1
  3. package/lib/context/internal/AgenticaOperationComposer.js.map +1 -1
  4. package/lib/context/internal/AgenticaOperationComposer.spec.js +39 -10
  5. package/lib/context/internal/AgenticaOperationComposer.spec.js.map +1 -1
  6. package/lib/functional/assertHttpLlmApplication.js +168 -168
  7. package/lib/functional/assertMcpController.d.ts +24 -0
  8. package/lib/functional/assertMcpController.js +1701 -0
  9. package/lib/functional/assertMcpController.js.map +1 -0
  10. package/lib/functional/validateHttpLlmApplication.js +148 -148
  11. package/lib/index.d.ts +1 -1
  12. package/lib/index.js +1 -1
  13. package/lib/index.js.map +1 -1
  14. package/lib/index.mjs +2013 -404
  15. package/lib/index.mjs.map +1 -1
  16. package/lib/orchestrate/call.js +11 -1
  17. package/lib/orchestrate/call.js.map +1 -1
  18. package/lib/orchestrate/initialize.js +60 -60
  19. package/lib/structures/IAgenticaController.d.ts +8 -4
  20. package/lib/structures/mcp/index.d.ts +0 -2
  21. package/lib/structures/mcp/index.js +0 -2
  22. package/lib/structures/mcp/index.js.map +1 -1
  23. package/lib/utils/AsyncQueue.d.ts +10 -0
  24. package/lib/utils/AsyncQueue.js +33 -9
  25. package/lib/utils/AsyncQueue.js.map +1 -1
  26. package/lib/utils/AsyncQueue.spec.d.ts +1 -0
  27. package/lib/utils/AsyncQueue.spec.js +280 -0
  28. package/lib/utils/AsyncQueue.spec.js.map +1 -0
  29. package/lib/utils/MPSC.spec.d.ts +1 -0
  30. package/lib/utils/MPSC.spec.js +222 -0
  31. package/lib/utils/MPSC.spec.js.map +1 -0
  32. package/lib/utils/StreamUtil.spec.d.ts +1 -0
  33. package/lib/utils/StreamUtil.spec.js +471 -0
  34. package/lib/utils/StreamUtil.spec.js.map +1 -0
  35. package/package.json +3 -3
  36. package/src/context/AgenticaOperation.ts +5 -6
  37. package/src/context/internal/AgenticaOperationComposer.spec.ts +45 -14
  38. package/src/context/internal/AgenticaOperationComposer.ts +10 -2
  39. package/src/functional/assertMcpController.ts +49 -0
  40. package/src/index.ts +1 -1
  41. package/src/orchestrate/call.ts +14 -4
  42. package/src/structures/IAgenticaController.ts +9 -4
  43. package/src/structures/mcp/index.ts +0 -2
  44. package/src/utils/AsyncQueue.spec.ts +355 -0
  45. package/src/utils/AsyncQueue.ts +36 -8
  46. package/src/utils/MPSC.spec.ts +276 -0
  47. package/src/utils/StreamUtil.spec.ts +520 -0
  48. package/lib/functional/assertMcpLlmApplication.d.ts +0 -18
  49. package/lib/functional/assertMcpLlmApplication.js +0 -74
  50. package/lib/functional/assertMcpLlmApplication.js.map +0 -1
  51. package/lib/structures/mcp/IMcpLlmApplication.d.ts +0 -9
  52. package/lib/structures/mcp/IMcpLlmApplication.js +0 -3
  53. package/lib/structures/mcp/IMcpLlmApplication.js.map +0 -1
  54. package/lib/structures/mcp/IMcpLlmFunction.d.ts +0 -17
  55. package/lib/structures/mcp/IMcpLlmFunction.js +0 -3
  56. package/lib/structures/mcp/IMcpLlmFunction.js.map +0 -1
  57. package/src/functional/assertMcpLlmApplication.ts +0 -32
  58. package/src/structures/mcp/IMcpLlmApplication.ts +0 -10
  59. package/src/structures/mcp/IMcpLlmFunction.ts +0 -19
@@ -0,0 +1,276 @@
1
+ import { MPSC } from "./MPSC";
2
+
3
+ describe("the MPSC", () => {
4
+ describe("basic functionality", () => {
5
+ it("basic MPSC functionality test", async () => {
6
+ const mpsc = new MPSC<number>();
7
+ const reader = mpsc.consumer.getReader();
8
+
9
+ // Produce values
10
+ mpsc.produce(10);
11
+ mpsc.produce(20);
12
+ mpsc.produce(30);
13
+
14
+ const read1 = await reader.read();
15
+ const read2 = await reader.read();
16
+ const read3 = await reader.read();
17
+
18
+ expect(read1.value).toBe(10);
19
+ expect(read1.done).toBe(false);
20
+ expect(read2.value).toBe(20);
21
+ expect(read2.done).toBe(false);
22
+ expect(read3.value).toBe(30);
23
+ expect(read3.done).toBe(false);
24
+ });
25
+
26
+ it("close functionality test", async () => {
27
+ const mpsc = new MPSC<number>();
28
+ const reader = mpsc.consumer.getReader();
29
+
30
+ mpsc.produce(10);
31
+ mpsc.close();
32
+
33
+ await reader.read();
34
+
35
+ expect(mpsc.done()).toBe(true);
36
+ });
37
+
38
+ it("multiple producers scenario test", async () => {
39
+ const multiMpsc = new MPSC<string>();
40
+ const multiReader = multiMpsc.consumer.getReader();
41
+
42
+ // Simulate multiple producers
43
+ for (let i = 1; i <= 5; i++) {
44
+ multiMpsc.produce(`producer-${i}`);
45
+ }
46
+
47
+ // Read all values
48
+ const multiResults: string[] = [];
49
+ for (let i = 0; i < 5; i++) {
50
+ const { value } = await multiReader.read();
51
+ if (value != null) {
52
+ multiResults.push(value);
53
+ }
54
+ }
55
+
56
+ expect(multiResults.length).toBe(5);
57
+ expect(multiResults).toContain("producer-1");
58
+ expect(multiResults).toContain("producer-2");
59
+ expect(multiResults).toContain("producer-3");
60
+ expect(multiResults).toContain("producer-4");
61
+ expect(multiResults).toContain("producer-5");
62
+
63
+ multiMpsc.close();
64
+
65
+ const multiAfterClose = await multiReader.read();
66
+ expect(multiAfterClose.done).toBe(true);
67
+ });
68
+
69
+ it("reading before producing test", async () => {
70
+ const delayMpsc = new MPSC<number>();
71
+ const delayReader = delayMpsc.consumer.getReader();
72
+
73
+ // Start reading before producing
74
+ const readPromise = delayReader.read();
75
+
76
+ // Produce after a small delay
77
+ setTimeout(() => {
78
+ delayMpsc.produce(42);
79
+ }, 10);
80
+
81
+ const delayResult = await readPromise;
82
+ expect(delayResult.value).toBe(42);
83
+ expect(delayResult.done).toBe(false);
84
+
85
+ delayMpsc.close();
86
+ });
87
+
88
+ it("producer-first, then consumer test", async () => {
89
+ const laterMpsc = new MPSC<string>();
90
+
91
+ // Produce values first
92
+ laterMpsc.produce("first");
93
+ laterMpsc.produce("second");
94
+ laterMpsc.produce("third");
95
+
96
+ // Then get reader and read
97
+ const laterReader = laterMpsc.consumer.getReader();
98
+ const laterResult1 = await laterReader.read();
99
+ const laterResult2 = await laterReader.read();
100
+ const laterResult3 = await laterReader.read();
101
+
102
+ expect(laterResult1.value).toBe("first");
103
+ expect(laterResult1.done).toBe(false);
104
+ expect(laterResult2.value).toBe("second");
105
+ expect(laterResult2.done).toBe(false);
106
+ expect(laterResult3.value).toBe("third");
107
+ expect(laterResult3.done).toBe(false);
108
+
109
+ laterMpsc.close();
110
+ });
111
+ });
112
+
113
+ describe("waitClosed functionality", () => {
114
+ it("basic waitClosed functionality test", async () => {
115
+ const mpsc = new MPSC<string>();
116
+ const reader = mpsc.consumer.getReader();
117
+
118
+ mpsc.produce("message");
119
+ const readResult = await reader.read();
120
+
121
+ expect(readResult.value).toBe("message");
122
+ expect(readResult.done).toBe(false);
123
+
124
+ // Call waitClose then execute close
125
+ const closePromise = mpsc.waitClosed();
126
+ mpsc.close();
127
+ await closePromise; // Should resolve when closed
128
+
129
+ const afterClose = await reader.read();
130
+ expect(afterClose.done).toBe(true);
131
+ });
132
+
133
+ it("call waitClose on already closed queue test", async () => {
134
+ const mpsc2 = new MPSC<number>();
135
+
136
+ mpsc2.close(); // Close first
137
+ const alreadyClosedPromise = mpsc2.waitClosed();
138
+ // Should resolve immediately since already closed
139
+ await alreadyClosedPromise;
140
+ });
141
+
142
+ it("multiple waitClose calls test", async () => {
143
+ const mpsc3 = new MPSC<number>();
144
+
145
+ // Create multiple waitClose promises
146
+ const waitPromises = [mpsc3.waitClosed(), mpsc3.waitClosed(), mpsc3.waitClosed()];
147
+
148
+ // All promises should resolve
149
+ mpsc3.close();
150
+ await Promise.all(waitPromises);
151
+ });
152
+
153
+ it("verify waitClose doesn't block other operations", async () => {
154
+ const mpsc4 = new MPSC<string>();
155
+ const reader4 = mpsc4.consumer.getReader();
156
+
157
+ // Call waitClose
158
+ const waitPromise4 = mpsc4.waitClosed();
159
+
160
+ // Check if value production and consumption still work
161
+ mpsc4.produce("first");
162
+ mpsc4.produce("second");
163
+
164
+ const read1 = await reader4.read();
165
+ const read2 = await reader4.read();
166
+
167
+ expect(read1.value).toBe("first");
168
+ expect(read1.done).toBe(false);
169
+ expect(read2.value).toBe("second");
170
+ expect(read2.done).toBe(false);
171
+
172
+ mpsc4.close();
173
+ await waitPromise4;
174
+
175
+ const afterClose4 = await reader4.read();
176
+ expect(afterClose4.done).toBe(true);
177
+ });
178
+
179
+ it("waitClose resolution after async close test", async () => {
180
+ const mpsc5 = new MPSC<number>();
181
+ const reader5 = mpsc5.consumer.getReader();
182
+
183
+ mpsc5.produce(100);
184
+
185
+ // Call waitClose
186
+ const waitPromise5 = mpsc5.waitClosed();
187
+
188
+ // Perform async close
189
+ setTimeout(() => {
190
+ mpsc5.close();
191
+ }, 50);
192
+
193
+ // Wait for waitClose to resolve
194
+ await waitPromise5;
195
+ await reader5.read();
196
+
197
+ const afterClose5 = await reader5.read();
198
+ expect(afterClose5.done).toBe(true);
199
+ });
200
+ });
201
+
202
+ describe("waitUntilEmpty functionality", () => {
203
+ it("waitUntilEmpty test when queue is empty", async () => {
204
+ const mpsc = new MPSC<number>();
205
+ const reader = mpsc.consumer.getReader();
206
+
207
+ // Should resolve immediately since queue is empty
208
+ await mpsc.waitUntilEmpty();
209
+
210
+ mpsc.produce(1);
211
+ const readResult = await reader.read();
212
+ expect(readResult.value).toBe(1);
213
+ expect(readResult.done).toBe(false);
214
+
215
+ mpsc.close();
216
+ });
217
+
218
+ it("waitUntilEmpty test when queue is not empty", async () => {
219
+ const mpsc = new MPSC<number>();
220
+ const reader = mpsc.consumer.getReader();
221
+
222
+ mpsc.produce(1);
223
+ mpsc.produce(2);
224
+
225
+ // waitUntilEmpty should not resolve since queue is not empty
226
+ const waitPromise = mpsc.waitUntilEmpty();
227
+
228
+ // Read first value
229
+ const read1 = await reader.read();
230
+ expect(read1.value).toBe(1);
231
+
232
+ // Read second value
233
+ const read2 = await reader.read();
234
+ expect(read2.value).toBe(2);
235
+ mpsc.close();
236
+
237
+ const read3 = await reader.read();
238
+ expect(read3.done).toBe(true);
239
+
240
+ // Now queue is empty, waitUntilEmpty should resolve
241
+ await waitPromise;
242
+ });
243
+
244
+ it("waitUntilEmpty test on closed queue", async () => {
245
+ const mpsc = new MPSC<number>();
246
+ const reader = mpsc.consumer.getReader();
247
+
248
+ mpsc.produce(1);
249
+ mpsc.close();
250
+
251
+ // waitUntilEmpty should resolve since queue is closed
252
+ await mpsc.waitUntilEmpty();
253
+
254
+ const readResult = await reader.read();
255
+ expect(readResult.value).toBe(1);
256
+ expect(readResult.done).toBe(false);
257
+
258
+ const afterClose = await reader.read();
259
+ expect(afterClose.done).toBe(true);
260
+ });
261
+ });
262
+
263
+ describe("done functionality", () => {
264
+ it("done test on unclosed queue", async () => {
265
+ const mpsc = new MPSC<number>();
266
+ expect(mpsc.done()).toBe(false);
267
+
268
+ mpsc.produce(1);
269
+ expect(mpsc.done()).toBe(false);
270
+
271
+ mpsc.close();
272
+ await mpsc.consumer.getReader().read();
273
+ expect(mpsc.done()).toBe(true);
274
+ });
275
+ });
276
+ });