@omaikit/agents 0.1.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 (186) hide show
  1. package/README.md +31 -0
  2. package/dist/agent.d.ts +31 -0
  3. package/dist/agent.d.ts.map +1 -0
  4. package/dist/agent.js +30 -0
  5. package/dist/agent.js.map +1 -0
  6. package/dist/ai-provider/anthropic.d.ts +13 -0
  7. package/dist/ai-provider/anthropic.d.ts.map +1 -0
  8. package/dist/ai-provider/anthropic.js +85 -0
  9. package/dist/ai-provider/anthropic.js.map +1 -0
  10. package/dist/ai-provider/factory.d.ts +3 -0
  11. package/dist/ai-provider/factory.d.ts.map +1 -0
  12. package/dist/ai-provider/factory.js +22 -0
  13. package/dist/ai-provider/factory.js.map +1 -0
  14. package/dist/ai-provider/openai.d.ts +16 -0
  15. package/dist/ai-provider/openai.d.ts.map +1 -0
  16. package/dist/ai-provider/openai.js +252 -0
  17. package/dist/ai-provider/openai.js.map +1 -0
  18. package/dist/ai-provider/provider.d.ts +25 -0
  19. package/dist/ai-provider/provider.d.ts.map +1 -0
  20. package/dist/ai-provider/provider.js +2 -0
  21. package/dist/ai-provider/provider.js.map +1 -0
  22. package/dist/ai-provider/token-manager.d.ts +12 -0
  23. package/dist/ai-provider/token-manager.d.ts.map +1 -0
  24. package/dist/ai-provider/token-manager.js +63 -0
  25. package/dist/ai-provider/token-manager.js.map +1 -0
  26. package/dist/coder/code-parser.d.ts +23 -0
  27. package/dist/coder/code-parser.d.ts.map +1 -0
  28. package/dist/coder/code-parser.js +184 -0
  29. package/dist/coder/code-parser.js.map +1 -0
  30. package/dist/coder/coder.d.ts +79 -0
  31. package/dist/coder/coder.d.ts.map +1 -0
  32. package/dist/coder/coder.js +476 -0
  33. package/dist/coder/coder.js.map +1 -0
  34. package/dist/coder/dependency-resolver.d.ts +23 -0
  35. package/dist/coder/dependency-resolver.d.ts.map +1 -0
  36. package/dist/coder/dependency-resolver.js +94 -0
  37. package/dist/coder/dependency-resolver.js.map +1 -0
  38. package/dist/coder/language-handlers.d.ts +38 -0
  39. package/dist/coder/language-handlers.d.ts.map +1 -0
  40. package/dist/coder/language-handlers.js +264 -0
  41. package/dist/coder/language-handlers.js.map +1 -0
  42. package/dist/coder/linter-integration.d.ts +37 -0
  43. package/dist/coder/linter-integration.d.ts.map +1 -0
  44. package/dist/coder/linter-integration.js +200 -0
  45. package/dist/coder/linter-integration.js.map +1 -0
  46. package/dist/coder/prompt-templates.d.ts +13 -0
  47. package/dist/coder/prompt-templates.d.ts.map +1 -0
  48. package/dist/coder/prompt-templates.js +78 -0
  49. package/dist/coder/prompt-templates.js.map +1 -0
  50. package/dist/coder/quality-checker.d.ts +31 -0
  51. package/dist/coder/quality-checker.d.ts.map +1 -0
  52. package/dist/coder/quality-checker.js +264 -0
  53. package/dist/coder/quality-checker.js.map +1 -0
  54. package/dist/coder/syntax-validator.d.ts +21 -0
  55. package/dist/coder/syntax-validator.d.ts.map +1 -0
  56. package/dist/coder/syntax-validator.js +169 -0
  57. package/dist/coder/syntax-validator.js.map +1 -0
  58. package/dist/coder.d.ts +2 -0
  59. package/dist/coder.d.ts.map +1 -0
  60. package/dist/coder.js +2 -0
  61. package/dist/coder.js.map +1 -0
  62. package/dist/errors.d.ts +11 -0
  63. package/dist/errors.d.ts.map +1 -0
  64. package/dist/errors.js +16 -0
  65. package/dist/errors.js.map +1 -0
  66. package/dist/index.d.ts +18 -0
  67. package/dist/index.d.ts.map +1 -0
  68. package/dist/index.js +18 -0
  69. package/dist/index.js.map +1 -0
  70. package/dist/logger.d.ts +6 -0
  71. package/dist/logger.d.ts.map +1 -0
  72. package/dist/logger.js +12 -0
  73. package/dist/logger.js.map +1 -0
  74. package/dist/manager/manager.d.ts +31 -0
  75. package/dist/manager/manager.d.ts.map +1 -0
  76. package/dist/manager/manager.js +162 -0
  77. package/dist/manager/manager.js.map +1 -0
  78. package/dist/memory/memory-store.d.ts +20 -0
  79. package/dist/memory/memory-store.d.ts.map +1 -0
  80. package/dist/memory/memory-store.js +68 -0
  81. package/dist/memory/memory-store.js.map +1 -0
  82. package/dist/planner/clarification-handler.d.ts +11 -0
  83. package/dist/planner/clarification-handler.d.ts.map +1 -0
  84. package/dist/planner/clarification-handler.js +60 -0
  85. package/dist/planner/clarification-handler.js.map +1 -0
  86. package/dist/planner/plan-parser.d.ts +11 -0
  87. package/dist/planner/plan-parser.d.ts.map +1 -0
  88. package/dist/planner/plan-parser.js +136 -0
  89. package/dist/planner/plan-parser.js.map +1 -0
  90. package/dist/planner/plan-validator.d.ts +29 -0
  91. package/dist/planner/plan-validator.d.ts.map +1 -0
  92. package/dist/planner/plan-validator.js +123 -0
  93. package/dist/planner/plan-validator.js.map +1 -0
  94. package/dist/planner/planner.d.ts +25 -0
  95. package/dist/planner/planner.d.ts.map +1 -0
  96. package/dist/planner/planner.js +334 -0
  97. package/dist/planner/planner.js.map +1 -0
  98. package/dist/planner/prompt-templates.d.ts +9 -0
  99. package/dist/planner/prompt-templates.d.ts.map +1 -0
  100. package/dist/planner/prompt-templates.js +168 -0
  101. package/dist/planner/prompt-templates.js.map +1 -0
  102. package/dist/planner.d.ts +2 -0
  103. package/dist/planner.d.ts.map +1 -0
  104. package/dist/planner.js +2 -0
  105. package/dist/planner.js.map +1 -0
  106. package/dist/reviewer/reviewer.d.ts +29 -0
  107. package/dist/reviewer/reviewer.d.ts.map +1 -0
  108. package/dist/reviewer/reviewer.js +40 -0
  109. package/dist/reviewer/reviewer.js.map +1 -0
  110. package/dist/reviewer.d.ts +2 -0
  111. package/dist/reviewer.d.ts.map +1 -0
  112. package/dist/reviewer.js +2 -0
  113. package/dist/reviewer.js.map +1 -0
  114. package/dist/tester/coverage-analyzer.d.ts +9 -0
  115. package/dist/tester/coverage-analyzer.d.ts.map +1 -0
  116. package/dist/tester/coverage-analyzer.js +18 -0
  117. package/dist/tester/coverage-analyzer.js.map +1 -0
  118. package/dist/tester/coverage-validator.d.ts +10 -0
  119. package/dist/tester/coverage-validator.d.ts.map +1 -0
  120. package/dist/tester/coverage-validator.js +14 -0
  121. package/dist/tester/coverage-validator.js.map +1 -0
  122. package/dist/tester/framework-detector.d.ts +4 -0
  123. package/dist/tester/framework-detector.d.ts.map +1 -0
  124. package/dist/tester/framework-detector.js +26 -0
  125. package/dist/tester/framework-detector.js.map +1 -0
  126. package/dist/tester/prompt-templates.d.ts +6 -0
  127. package/dist/tester/prompt-templates.d.ts.map +1 -0
  128. package/dist/tester/prompt-templates.js +30 -0
  129. package/dist/tester/prompt-templates.js.map +1 -0
  130. package/dist/tester/test-executor.d.ts +11 -0
  131. package/dist/tester/test-executor.d.ts.map +1 -0
  132. package/dist/tester/test-executor.js +24 -0
  133. package/dist/tester/test-executor.js.map +1 -0
  134. package/dist/tester/test-parser.d.ts +10 -0
  135. package/dist/tester/test-parser.d.ts.map +1 -0
  136. package/dist/tester/test-parser.js +83 -0
  137. package/dist/tester/test-parser.js.map +1 -0
  138. package/dist/tester/test-patterns.d.ts +10 -0
  139. package/dist/tester/test-patterns.d.ts.map +1 -0
  140. package/dist/tester/test-patterns.js +65 -0
  141. package/dist/tester/test-patterns.js.map +1 -0
  142. package/dist/tester/tester.d.ts +56 -0
  143. package/dist/tester/tester.d.ts.map +1 -0
  144. package/dist/tester/tester.js +246 -0
  145. package/dist/tester/tester.js.map +1 -0
  146. package/dist/tester.d.ts +3 -0
  147. package/dist/tester.d.ts.map +1 -0
  148. package/dist/tester.js +2 -0
  149. package/dist/tester.js.map +1 -0
  150. package/dist/tools/default-registry.d.ts +3 -0
  151. package/dist/tools/default-registry.d.ts.map +1 -0
  152. package/dist/tools/default-registry.js +12 -0
  153. package/dist/tools/default-registry.js.map +1 -0
  154. package/dist/tools/edit.d.ts +4 -0
  155. package/dist/tools/edit.d.ts.map +1 -0
  156. package/dist/tools/edit.js +95 -0
  157. package/dist/tools/edit.js.map +1 -0
  158. package/dist/tools/index.d.ts +6 -0
  159. package/dist/tools/index.d.ts.map +1 -0
  160. package/dist/tools/index.js +6 -0
  161. package/dist/tools/index.js.map +1 -0
  162. package/dist/tools/read.d.ts +4 -0
  163. package/dist/tools/read.d.ts.map +1 -0
  164. package/dist/tools/read.js +39 -0
  165. package/dist/tools/read.js.map +1 -0
  166. package/dist/tools/registry.d.ts +11 -0
  167. package/dist/tools/registry.d.ts.map +1 -0
  168. package/dist/tools/registry.js +31 -0
  169. package/dist/tools/registry.js.map +1 -0
  170. package/dist/tools/search.d.ts +4 -0
  171. package/dist/tools/search.d.ts.map +1 -0
  172. package/dist/tools/search.js +52 -0
  173. package/dist/tools/search.js.map +1 -0
  174. package/dist/tools/types.d.ts +37 -0
  175. package/dist/tools/types.d.ts.map +1 -0
  176. package/dist/tools/types.js +2 -0
  177. package/dist/tools/types.js.map +1 -0
  178. package/dist/tools/utils.d.ts +10 -0
  179. package/dist/tools/utils.d.ts.map +1 -0
  180. package/dist/tools/utils.js +76 -0
  181. package/dist/tools/utils.js.map +1 -0
  182. package/dist/types.d.ts +16 -0
  183. package/dist/types.d.ts.map +1 -0
  184. package/dist/types.js +2 -0
  185. package/dist/types.js.map +1 -0
  186. package/package.json +38 -0
@@ -0,0 +1,65 @@
1
+ export class TestPatterns {
2
+ getPatterns(language, framework) {
3
+ const normalized = language.toLowerCase();
4
+ const fw = framework.toLowerCase();
5
+ if (normalized === 'python') {
6
+ return [
7
+ {
8
+ name: 'unit-test',
9
+ description: 'Basic unit test with pytest-style assertions',
10
+ example: 'def test_adds_numbers():\n assert add(1, 2) == 3',
11
+ type: 'unit',
12
+ },
13
+ {
14
+ name: 'integration-test',
15
+ description: 'Integration test with fixture setup',
16
+ example: 'def test_api_returns_200(client):\n response = client.get("/health")\n assert response.status_code == 200',
17
+ type: 'integration',
18
+ },
19
+ {
20
+ name: 'edge-case',
21
+ description: 'Edge case for invalid inputs',
22
+ example: 'def test_rejects_empty_payload():\n with pytest.raises(ValueError):\n create_user({})',
23
+ type: 'edge',
24
+ },
25
+ ];
26
+ }
27
+ if (fw.includes('vitest') || fw.includes('jest') || normalized === 'typescript') {
28
+ return [
29
+ {
30
+ name: 'unit-test',
31
+ description: 'Unit test with describe/it',
32
+ example: 'describe("add", () => {\n it("adds numbers", () => {\n expect(add(1, 2)).toBe(3);\n });\n});',
33
+ type: 'unit',
34
+ },
35
+ {
36
+ name: 'integration-test',
37
+ description: 'Integration test with setup/teardown',
38
+ example: 'describe("health", () => {\n it("returns ok", async () => {\n const res = await api.get("/health");\n expect(res.status).toBe(200);\n });\n});',
39
+ type: 'integration',
40
+ },
41
+ {
42
+ name: 'edge-case',
43
+ description: 'Edge case for invalid inputs',
44
+ example: 'it("rejects empty payload", () => {\n expect(() => createUser({})).toThrow();\n});',
45
+ type: 'edge',
46
+ },
47
+ ];
48
+ }
49
+ return [
50
+ {
51
+ name: 'unit-test',
52
+ description: 'Basic unit test pattern',
53
+ example: 'assert add(1, 2) == 3',
54
+ type: 'unit',
55
+ },
56
+ {
57
+ name: 'edge-case',
58
+ description: 'Basic edge case test pattern',
59
+ example: 'assert_throws(invalid_input)',
60
+ type: 'edge',
61
+ },
62
+ ];
63
+ }
64
+ }
65
+ //# sourceMappingURL=test-patterns.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"test-patterns.js","sourceRoot":"","sources":["../../src/tester/test-patterns.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,YAAY;IACvB,WAAW,CAAC,QAAgB,EAAE,SAAiB;QAC7C,MAAM,UAAU,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;QAC1C,MAAM,EAAE,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC;QAEnC,IAAI,UAAU,KAAK,QAAQ,EAAE,CAAC;YAC5B,OAAO;gBACL;oBACE,IAAI,EAAE,WAAW;oBACjB,WAAW,EAAE,8CAA8C;oBAC3D,OAAO,EAAE,qDAAqD;oBAC9D,IAAI,EAAE,MAAM;iBACb;gBACD;oBACE,IAAI,EAAE,kBAAkB;oBACxB,WAAW,EAAE,qCAAqC;oBAClD,OAAO,EACL,iHAAiH;oBACnH,IAAI,EAAE,aAAa;iBACpB;gBACD;oBACE,IAAI,EAAE,WAAW;oBACjB,WAAW,EAAE,8BAA8B;oBAC3C,OAAO,EACL,iGAAiG;oBACnG,IAAI,EAAE,MAAM;iBACb;aACF,CAAC;QACJ,CAAC;QAED,IAAI,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,UAAU,KAAK,YAAY,EAAE,CAAC;YAChF,OAAO;gBACL;oBACE,IAAI,EAAE,WAAW;oBACjB,WAAW,EAAE,4BAA4B;oBACzC,OAAO,EACL,mGAAmG;oBACrG,IAAI,EAAE,MAAM;iBACb;gBACD;oBACE,IAAI,EAAE,kBAAkB;oBACxB,WAAW,EAAE,sCAAsC;oBACnD,OAAO,EACL,wJAAwJ;oBAC1J,IAAI,EAAE,aAAa;iBACpB;gBACD;oBACE,IAAI,EAAE,WAAW;oBACjB,WAAW,EAAE,8BAA8B;oBAC3C,OAAO,EACL,qFAAqF;oBACvF,IAAI,EAAE,MAAM;iBACb;aACF,CAAC;QACJ,CAAC;QAED,OAAO;YACL;gBACE,IAAI,EAAE,WAAW;gBACjB,WAAW,EAAE,yBAAyB;gBACtC,OAAO,EAAE,uBAAuB;gBAChC,IAAI,EAAE,MAAM;aACb;YACD;gBACE,IAAI,EAAE,WAAW;gBACjB,WAAW,EAAE,8BAA8B;gBAC3C,OAAO,EAAE,8BAA8B;gBACvC,IAAI,EAAE,MAAM;aACb;SACF,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,56 @@
1
+ import type { AgentInput, AgentOutput } from '../types.js';
2
+ import type { Task, TestSuite } from '@omaikit/models';
3
+ import { Agent } from '../agent.js';
4
+ import { Logger } from '../logger.js';
5
+ export interface TesterAgentInput extends AgentInput {
6
+ task: Task;
7
+ projectContext: any;
8
+ plan: any;
9
+ run?: boolean;
10
+ coverageTarget?: number;
11
+ force?: boolean;
12
+ }
13
+ export interface TesterAgentOutput extends AgentOutput {
14
+ result: TestSuite;
15
+ metadata: {
16
+ durationMs: number;
17
+ filesGenerated?: number;
18
+ testsGenerated?: number;
19
+ coverage?: number;
20
+ execution?: {
21
+ passed: number;
22
+ failed: number;
23
+ skipped: number;
24
+ durationMs: number;
25
+ };
26
+ tokenUsage?: {
27
+ input: number;
28
+ output: number;
29
+ total: number;
30
+ };
31
+ };
32
+ }
33
+ export declare class TesterAgent extends Agent {
34
+ name: string;
35
+ version: string;
36
+ private promptTemplates;
37
+ private parser;
38
+ private coverageAnalyzer;
39
+ private coverageValidator;
40
+ private frameworkDetector;
41
+ private testExecutor;
42
+ private provider?;
43
+ private memoryStore;
44
+ constructor(logger?: Logger);
45
+ init(): Promise<void>;
46
+ execute(input: TesterAgentInput): Promise<TesterAgentOutput>;
47
+ validate(output: AgentOutput): Promise<any>;
48
+ canHandle(_task: Task): boolean;
49
+ private validateInput;
50
+ private determineLanguage;
51
+ private isValidationError;
52
+ private callLLM;
53
+ private withTimeout;
54
+ private getMockGeneratedTests;
55
+ }
56
+ //# sourceMappingURL=tester.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tester.d.ts","sourceRoot":"","sources":["../../src/tester/tester.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACxD,OAAO,KAAK,EAAE,IAAI,EAAE,SAAS,EAAY,MAAM,iBAAiB,CAAC;AACjE,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACjC,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAUnC,MAAM,WAAW,gBAAiB,SAAQ,UAAU;IAClD,IAAI,EAAE,IAAI,CAAC;IACX,cAAc,EAAE,GAAG,CAAC;IACpB,IAAI,EAAE,GAAG,CAAC;IACV,GAAG,CAAC,EAAE,OAAO,CAAC;IACd,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,WAAW,iBAAkB,SAAQ,WAAW;IACpD,MAAM,EAAE,SAAS,CAAC;IAClB,QAAQ,EAAE;QACR,UAAU,EAAE,MAAM,CAAC;QACnB,cAAc,CAAC,EAAE,MAAM,CAAC;QACxB,cAAc,CAAC,EAAE,MAAM,CAAC;QACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,SAAS,CAAC,EAAE;YACV,MAAM,EAAE,MAAM,CAAC;YACf,MAAM,EAAE,MAAM,CAAC;YACf,OAAO,EAAE,MAAM,CAAC;YAChB,UAAU,EAAE,MAAM,CAAC;SACpB,CAAC;QACF,UAAU,CAAC,EAAE;YACX,KAAK,EAAE,MAAM,CAAC;YACd,MAAM,EAAE,MAAM,CAAC;YACf,KAAK,EAAE,MAAM,CAAC;SACf,CAAC;KACH,CAAC;CACH;AAED,qBAAa,WAAY,SAAQ,KAAK;IAC7B,IAAI,SAAY;IAChB,OAAO,SAAW;IAEzB,OAAO,CAAC,eAAe,CAAsB;IAC7C,OAAO,CAAC,MAAM,CAAa;IAC3B,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,iBAAiB,CAAoB;IAC7C,OAAO,CAAC,iBAAiB,CAAoB;IAC7C,OAAO,CAAC,YAAY,CAAe;IACnC,OAAO,CAAC,QAAQ,CAAC,CAAM;IACvB,OAAO,CAAC,WAAW,CAAc;gBAErB,MAAM,CAAC,EAAE,MAAM;IAWrB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IASrB,OAAO,CAAC,KAAK,EAAE,gBAAgB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAqG5D,QAAQ,CAAC,MAAM,EAAE,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC;IAyDjD,SAAS,CAAC,KAAK,EAAE,IAAI,GAAG,OAAO;IAI/B,OAAO,CAAC,aAAa;IAYrB,OAAO,CAAC,iBAAiB;IASzB,OAAO,CAAC,iBAAiB;YASX,OAAO;YA2CP,WAAW;IAgBzB,OAAO,CAAC,qBAAqB;CAO9B"}
@@ -0,0 +1,246 @@
1
+ import { Agent } from '../agent.js';
2
+ import { createProvider } from '../ai-provider/factory.js';
3
+ import { TestPromptTemplates } from './prompt-templates.js';
4
+ import { TestParser } from './test-parser.js';
5
+ import { CoverageAnalyzer } from './coverage-analyzer.js';
6
+ import { CoverageValidator } from './coverage-validator.js';
7
+ import { FrameworkDetector } from './framework-detector.js';
8
+ import { TestExecutor } from './test-executor.js';
9
+ import { MemoryStore } from '../memory/memory-store.js';
10
+ export class TesterAgent extends Agent {
11
+ name = 'tester';
12
+ version = '1.0.0';
13
+ promptTemplates;
14
+ parser;
15
+ coverageAnalyzer;
16
+ coverageValidator;
17
+ frameworkDetector;
18
+ testExecutor;
19
+ provider;
20
+ memoryStore;
21
+ constructor(logger) {
22
+ super(logger);
23
+ this.promptTemplates = new TestPromptTemplates();
24
+ this.parser = new TestParser();
25
+ this.coverageAnalyzer = new CoverageAnalyzer();
26
+ this.coverageValidator = new CoverageValidator();
27
+ this.frameworkDetector = new FrameworkDetector();
28
+ this.testExecutor = new TestExecutor();
29
+ this.memoryStore = new MemoryStore();
30
+ }
31
+ async init() {
32
+ this.logger.info('Initializing TesterAgent', { version: this.version });
33
+ try {
34
+ this.provider = await createProvider();
35
+ }
36
+ catch (error) {
37
+ this.logger.warn('Could not initialize AI provider, using mock mode');
38
+ }
39
+ }
40
+ async execute(input) {
41
+ const startTime = Date.now();
42
+ const output = {
43
+ agentName: this.name,
44
+ status: 'success',
45
+ timestamp: new Date().toISOString(),
46
+ result: {
47
+ id: `ts-${Date.now()}`,
48
+ taskId: input.task?.id || 'unknown',
49
+ files: [],
50
+ },
51
+ metadata: {
52
+ durationMs: 0,
53
+ filesGenerated: 0,
54
+ testsGenerated: 0,
55
+ coverage: 0,
56
+ },
57
+ };
58
+ try {
59
+ await this.beforeExecute(input);
60
+ this.validateInput(input);
61
+ const language = this.determineLanguage(input);
62
+ const framework = this.frameworkDetector.detect(language, input.projectContext);
63
+ const prompt = await this.promptTemplates.generatePrompt(input.task, input.projectContext, input.plan, language, framework);
64
+ const recentMemory = await this.memoryStore.readRecent(this.name, 3);
65
+ const memoryContext = this.memoryStore.formatRecent(recentMemory);
66
+ const finalPrompt = memoryContext
67
+ ? `${prompt}\n\n## Recent Agent Memory\n${memoryContext}`
68
+ : prompt;
69
+ const response = await this.callLLM(finalPrompt, language, framework, input);
70
+ await this.memoryStore.append(this.name, {
71
+ timestamp: new Date().toISOString(),
72
+ prompt: finalPrompt,
73
+ response,
74
+ taskId: input.task.id,
75
+ });
76
+ const files = this.parser.parse(response, language, framework);
77
+ const coverage = this.coverageAnalyzer.analyze(files);
78
+ const validation = this.coverageValidator.validate(coverage.overall, input.coverageTarget ?? 80);
79
+ output.result.files = files;
80
+ output.result.coverage = coverage.overall;
81
+ output.result.metadata = {
82
+ generatedAt: new Date().toISOString(),
83
+ model: 'mock-model',
84
+ };
85
+ output.metadata.filesGenerated = files.length;
86
+ output.metadata.testsGenerated = files.reduce((sum, file) => sum + file.testCases.length, 0);
87
+ output.metadata.coverage = coverage.overall;
88
+ if (!validation.isValid) {
89
+ output.status = 'partial';
90
+ }
91
+ if (input.run) {
92
+ output.metadata.execution = await this.testExecutor.run(files, framework);
93
+ }
94
+ await this.afterExecute(output);
95
+ await this.memoryStore.clear(this.name);
96
+ }
97
+ catch (error) {
98
+ const err = error;
99
+ await this.onError(err);
100
+ output.status = 'failed';
101
+ output.error = {
102
+ code: 'TESTER_ERROR',
103
+ message: err.message,
104
+ };
105
+ await this.memoryStore.append(this.name, {
106
+ timestamp: new Date().toISOString(),
107
+ prompt: '',
108
+ response: output.error.message,
109
+ taskId: input.task?.id,
110
+ metadata: { status: 'failed' },
111
+ });
112
+ if (this.isValidationError(err)) {
113
+ throw err;
114
+ }
115
+ }
116
+ output.metadata.durationMs = Date.now() - startTime;
117
+ return output;
118
+ }
119
+ async validate(output) {
120
+ const issues = [];
121
+ let qualityScore = 100;
122
+ const result = output.result || {};
123
+ if (!result.id) {
124
+ issues.push({ severity: 'error', message: 'Missing result.id', field: 'result.id' });
125
+ qualityScore -= 25;
126
+ }
127
+ if (!result.taskId) {
128
+ issues.push({ severity: 'error', message: 'Missing result.taskId', field: 'result.taskId' });
129
+ qualityScore -= 25;
130
+ }
131
+ if (!Array.isArray(result.files) || result.files.length === 0) {
132
+ issues.push({ severity: 'error', message: 'No test files generated', field: 'result.files' });
133
+ qualityScore -= 25;
134
+ }
135
+ if (Array.isArray(result.files)) {
136
+ result.files.forEach((file, idx) => {
137
+ if (!file.path) {
138
+ issues.push({
139
+ severity: 'error',
140
+ message: `File ${idx} missing path`,
141
+ field: `result.files[${idx}].path`,
142
+ });
143
+ qualityScore -= 5;
144
+ }
145
+ if (!file.language) {
146
+ issues.push({
147
+ severity: 'error',
148
+ message: `File ${idx} missing language`,
149
+ field: `result.files[${idx}].language`,
150
+ });
151
+ qualityScore -= 5;
152
+ }
153
+ if (!file.content) {
154
+ issues.push({
155
+ severity: 'error',
156
+ message: `File ${idx} missing content`,
157
+ field: `result.files[${idx}].content`,
158
+ });
159
+ qualityScore -= 5;
160
+ }
161
+ });
162
+ }
163
+ return {
164
+ isValid: issues.filter((issue) => issue.severity === 'error').length === 0,
165
+ issues,
166
+ warnings: [],
167
+ qualityScore: Math.max(0, qualityScore),
168
+ };
169
+ }
170
+ canHandle(_task) {
171
+ return true;
172
+ }
173
+ validateInput(input) {
174
+ if (!input.task) {
175
+ throw new Error('Task is required');
176
+ }
177
+ if (!input.projectContext) {
178
+ throw new Error('Project context is required');
179
+ }
180
+ if (!input.task.id || !input.task.title) {
181
+ throw new Error('Task must have id and title');
182
+ }
183
+ }
184
+ determineLanguage(input) {
185
+ const languages = input.projectContext?.metadata?.languages || input.projectContext?.analysis?.languages || [];
186
+ if (languages.length > 0) {
187
+ return languages[0];
188
+ }
189
+ return 'typescript';
190
+ }
191
+ isValidationError(error) {
192
+ const message = error.message || '';
193
+ return (message.includes('Task is required') ||
194
+ message.includes('Project context is required') ||
195
+ message.includes('Task must have id and title'));
196
+ }
197
+ async callLLM(prompt, language, framework, input) {
198
+ this.logger.info('Calling LLM for test generation', { language, framework });
199
+ if (process.env.VITEST !== undefined) {
200
+ await new Promise((resolve) => setTimeout(resolve, 10));
201
+ return this.getMockGeneratedTests(language, input.task);
202
+ }
203
+ if (!this.provider) {
204
+ await new Promise((resolve) => setTimeout(resolve, 100));
205
+ return this.getMockGeneratedTests(language, input.task);
206
+ }
207
+ const response = await this.withTimeout(this.provider.generate(prompt, {
208
+ temperature: 0.3,
209
+ maxTokens: 900,
210
+ }), 90_000);
211
+ if (!response) {
212
+ this.logger.warn('LLM generation timed out; using mock output', { timeoutMs: 90_000 });
213
+ return this.getMockGeneratedTests(language, input.task);
214
+ }
215
+ if (typeof response === 'string' &&
216
+ (response.startsWith('OPENAI_ECHO') || response.startsWith('ANTHROPIC_ECHO'))) {
217
+ return this.getMockGeneratedTests(language, input.task);
218
+ }
219
+ return typeof response === 'string'
220
+ ? response
221
+ : this.getMockGeneratedTests(language, input.task);
222
+ }
223
+ async withTimeout(promise, timeoutMs) {
224
+ let timeoutHandle = null;
225
+ try {
226
+ return await Promise.race([
227
+ promise,
228
+ new Promise((resolve) => {
229
+ timeoutHandle = setTimeout(() => resolve(null), timeoutMs);
230
+ }),
231
+ ]);
232
+ }
233
+ finally {
234
+ if (timeoutHandle) {
235
+ clearTimeout(timeoutHandle);
236
+ }
237
+ }
238
+ }
239
+ getMockGeneratedTests(language, task) {
240
+ if (language.toLowerCase() === 'python') {
241
+ return `# File: tests/${task.id}.test.py\n\nimport pytest\n\n\n\ndef test_${task.id}_happy_path():\n assert True\n\n\n\ndef test_${task.id}_invalid_input():\n with pytest.raises(Exception):\n raise Exception("Invalid input")\n`;
242
+ }
243
+ return `// File: tests/${task.id}.test.ts\n\nimport { describe, it, expect } from 'vitest';\n\n\ndescribe('${task.title}', () => {\n it('handles happy path', () => {\n expect(true).toBe(true);\n });\n\n it('handles invalid input', () => {\n expect(() => { throw new Error('Invalid input'); }).toThrow();\n });\n});\n`;
244
+ }
245
+ }
246
+ //# sourceMappingURL=tester.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tester.js","sourceRoot":"","sources":["../../src/tester/tester.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export { TesterAgent } from './tester/tester.js';
2
+ export type { TesterAgentInput, TesterAgentOutput } from './tester/tester.js';
3
+ //# sourceMappingURL=tester.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tester.d.ts","sourceRoot":"","sources":["../src/tester.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,YAAY,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC"}
package/dist/tester.js ADDED
@@ -0,0 +1,2 @@
1
+ export { TesterAgent } from './tester/tester.js';
2
+ //# sourceMappingURL=tester.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tester.js","sourceRoot":"","sources":["../src/tester.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { ToolRegistry } from './registry.js';
2
+ export declare function createDefaultToolRegistry(): ToolRegistry;
3
+ //# sourceMappingURL=default-registry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"default-registry.d.ts","sourceRoot":"","sources":["../../src/tools/default-registry.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAK1C,wBAAgB,yBAAyB,IAAI,YAAY,CAMxD"}
@@ -0,0 +1,12 @@
1
+ import { ToolRegistry } from './registry.js';
2
+ import { readToolDefinition, readToolHandler } from './read.js';
3
+ import { searchToolDefinition, searchToolHandler } from './search.js';
4
+ import { editToolDefinition, editToolHandler } from './edit.js';
5
+ export function createDefaultToolRegistry() {
6
+ const registry = new ToolRegistry();
7
+ registry.register(readToolDefinition, readToolHandler);
8
+ registry.register(searchToolDefinition, searchToolHandler);
9
+ registry.register(editToolDefinition, editToolHandler);
10
+ return registry;
11
+ }
12
+ //# sourceMappingURL=default-registry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"default-registry.js","sourceRoot":"","sources":["../../src/tools/default-registry.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAC7D,OAAO,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAE7D,MAAM,UAAU,yBAAyB;IACvC,MAAM,QAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;IACpC,QAAQ,CAAC,QAAQ,CAAC,kBAAkB,EAAE,eAAe,CAAC,CAAC;IACvD,QAAQ,CAAC,QAAQ,CAAC,oBAAoB,EAAE,iBAAiB,CAAC,CAAC;IAC3D,QAAQ,CAAC,QAAQ,CAAC,kBAAkB,EAAE,eAAe,CAAC,CAAC;IACvD,OAAO,QAAQ,CAAC;AAClB,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { ToolDefinition, ToolHandler } from './types.js';
2
+ export declare const editToolDefinition: ToolDefinition;
3
+ export declare const editToolHandler: ToolHandler;
4
+ //# sourceMappingURL=edit.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"edit.d.ts","sourceRoot":"","sources":["../../src/tools/edit.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAGtD,eAAO,MAAM,kBAAkB,EAAE,cAqBhC,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,WAwE7B,CAAC"}
@@ -0,0 +1,95 @@
1
+ import * as fs from 'fs';
2
+ import * as path from 'path';
3
+ import { resolveSafePath, ensureFileExists, readFileLines, writeFileLines } from './utils.js';
4
+ export const editToolDefinition = {
5
+ name: 'edit',
6
+ description: 'Edit a text file by replacing, inserting, appending, or overwriting content.',
7
+ parameters: {
8
+ type: 'object',
9
+ properties: {
10
+ path: { type: 'string', description: 'Path to the file, relative to the project root.' },
11
+ mode: {
12
+ type: 'string',
13
+ enum: ['overwrite', 'append', 'replace', 'insert'],
14
+ description: 'Edit mode to apply.',
15
+ },
16
+ content: { type: 'string', description: 'Content to write or insert.' },
17
+ startLine: { type: 'integer', description: '1-based start line for replace/insert.' },
18
+ endLine: { type: 'integer', description: '1-based end line for replace.' },
19
+ find: { type: 'string', description: 'String or regex pattern to replace.' },
20
+ replace: { type: 'string', description: 'Replacement string.' },
21
+ useRegex: { type: 'boolean', description: 'Treat find as regex (default: false).' },
22
+ },
23
+ required: ['path', 'mode'],
24
+ },
25
+ };
26
+ export const editToolHandler = (args, context) => {
27
+ const pathArg = String(args.path || '');
28
+ const mode = String(args.mode || '');
29
+ if (!pathArg) {
30
+ return { ok: false, error: { message: 'path is required', code: 'INVALID_ARGS' } };
31
+ }
32
+ if (!mode) {
33
+ return { ok: false, error: { message: 'mode is required', code: 'INVALID_ARGS' } };
34
+ }
35
+ const { absolutePath, relativePath } = resolveSafePath(pathArg, context.rootPath || context.cwd);
36
+ const encoding = 'utf-8';
37
+ if (mode === 'overwrite') {
38
+ const content = String(args.content ?? '');
39
+ ensureDir(path.dirname(absolutePath));
40
+ fs.writeFileSync(absolutePath, content, encoding);
41
+ return { ok: true, data: { path: relativePath, mode, bytes: Buffer.byteLength(content) } };
42
+ }
43
+ ensureFileExists(absolutePath);
44
+ if (mode === 'append') {
45
+ const content = String(args.content ?? '');
46
+ fs.appendFileSync(absolutePath, content, encoding);
47
+ return { ok: true, data: { path: relativePath, mode, bytes: Buffer.byteLength(content) } };
48
+ }
49
+ const lines = readFileLines(absolutePath, encoding);
50
+ if (mode === 'insert') {
51
+ const content = String(args.content ?? '');
52
+ const startLine = typeof args.startLine === 'number' ? Math.max(args.startLine, 1) : lines.length + 1;
53
+ const insertLines = content.split(/\r?\n/);
54
+ const updated = [
55
+ ...lines.slice(0, startLine - 1),
56
+ ...insertLines,
57
+ ...lines.slice(startLine - 1),
58
+ ];
59
+ writeFileLines(absolutePath, updated, encoding);
60
+ return { ok: true, data: { path: relativePath, mode, startLine } };
61
+ }
62
+ if (mode === 'replace') {
63
+ const content = String(args.content ?? '');
64
+ if (typeof args.startLine === 'number') {
65
+ const startLine = Math.max(args.startLine, 1);
66
+ const endLine = typeof args.endLine === 'number' ? Math.max(args.endLine, startLine) : startLine;
67
+ const replacement = content.split(/\r?\n/);
68
+ const updated = [...lines.slice(0, startLine - 1), ...replacement, ...lines.slice(endLine)];
69
+ writeFileLines(absolutePath, updated, encoding);
70
+ return { ok: true, data: { path: relativePath, mode, startLine, endLine } };
71
+ }
72
+ const find = String(args.find ?? '');
73
+ if (!find) {
74
+ return {
75
+ ok: false,
76
+ error: { message: 'find is required when startLine is not provided', code: 'INVALID_ARGS' },
77
+ };
78
+ }
79
+ const useRegex = Boolean(args.useRegex);
80
+ const regex = useRegex ? new RegExp(find, 'g') : new RegExp(escapeRegex(find), 'g');
81
+ const updatedContent = lines.join('\n').replace(regex, String(args.replace ?? ''));
82
+ fs.writeFileSync(absolutePath, updatedContent, encoding);
83
+ return { ok: true, data: { path: relativePath, mode } };
84
+ }
85
+ return { ok: false, error: { message: `Unsupported mode: ${mode}`, code: 'INVALID_ARGS' } };
86
+ };
87
+ function ensureDir(dirPath) {
88
+ if (!fs.existsSync(dirPath)) {
89
+ fs.mkdirSync(dirPath, { recursive: true });
90
+ }
91
+ }
92
+ function escapeRegex(value) {
93
+ return value.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
94
+ }
95
+ //# sourceMappingURL=edit.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"edit.js","sourceRoot":"","sources":["../../src/tools/edit.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ export * from './registry.js';
2
+ export * from './default-registry.js';
3
+ export { readToolDefinition, readToolHandler } from './read.js';
4
+ export { searchToolDefinition, searchToolHandler } from './search.js';
5
+ export { editToolDefinition, editToolHandler } from './edit.js';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAC7D,OAAO,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC"}
@@ -0,0 +1,6 @@
1
+ export * from './registry.js';
2
+ export * from './default-registry.js';
3
+ export { readToolDefinition, readToolHandler } from './read.js';
4
+ export { searchToolDefinition, searchToolHandler } from './search.js';
5
+ export { editToolDefinition, editToolHandler } from './edit.js';
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAC7D,OAAO,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { ToolDefinition, ToolHandler } from './types.js';
2
+ export declare const readToolDefinition: ToolDefinition;
3
+ export declare const readToolHandler: ToolHandler;
4
+ //# sourceMappingURL=read.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"read.d.ts","sourceRoot":"","sources":["../../src/tools/read.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAGtD,eAAO,MAAM,kBAAkB,EAAE,cAahC,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,WA4B7B,CAAC"}
@@ -0,0 +1,39 @@
1
+ import { resolveSafePath, ensureFileExists, readFileLines } from './utils.js';
2
+ export const readToolDefinition = {
3
+ name: 'read',
4
+ description: 'Read a text file from disk with optional line range.',
5
+ parameters: {
6
+ type: 'object',
7
+ properties: {
8
+ path: { type: 'string', description: 'Path to the file, relative to the project root.' },
9
+ startLine: { type: 'integer', description: '1-based start line number (inclusive).' },
10
+ endLine: { type: 'integer', description: '1-based end line number (inclusive).' },
11
+ encoding: { type: 'string', description: 'File encoding (default: utf-8).' },
12
+ },
13
+ required: ['path'],
14
+ },
15
+ };
16
+ export const readToolHandler = (args, context) => {
17
+ const pathArg = String(args.path || '');
18
+ if (!pathArg) {
19
+ return { ok: false, error: { message: 'path is required', code: 'INVALID_ARGS' } };
20
+ }
21
+ const { absolutePath, relativePath } = resolveSafePath(pathArg, context.rootPath || context.cwd);
22
+ ensureFileExists(absolutePath);
23
+ const encoding = args.encoding || 'utf-8';
24
+ const lines = readFileLines(absolutePath, encoding);
25
+ const startLine = typeof args.startLine === 'number' ? Math.max(args.startLine, 1) : 1;
26
+ const endLine = typeof args.endLine === 'number' ? Math.min(args.endLine, lines.length) : lines.length;
27
+ const slice = lines.slice(startLine - 1, endLine).join('\n');
28
+ return {
29
+ ok: true,
30
+ data: {
31
+ path: relativePath,
32
+ startLine,
33
+ endLine,
34
+ totalLines: lines.length,
35
+ content: slice,
36
+ },
37
+ };
38
+ };
39
+ //# sourceMappingURL=read.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"read.js","sourceRoot":"","sources":["../../src/tools/read.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAE3E,MAAM,CAAC,MAAM,kBAAkB,GAAmB;IAChD,IAAI,EAAE,MAAM;IACZ,WAAW,EAAE,sDAAsD;IACnE,UAAU,EAAE;QACV,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,iDAAiD,EAAE;YACxF,SAAS,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE,wCAAwC,EAAE;YACrF,OAAO,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE,sCAAsC,EAAE;YACjF,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,iCAAiC,EAAE;SAC7E;QACD,QAAQ,EAAE,CAAC,MAAM,CAAC;KACnB;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAgB,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE;IAC5D,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;IACxC,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAE,cAAc,EAAE,EAAE,CAAC;IACrF,CAAC;IAED,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,GAAG,eAAe,CAAC,OAAO,EAAE,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC;IACjG,gBAAgB,CAAC,YAAY,CAAC,CAAC;IAE/B,MAAM,QAAQ,GAAI,IAAI,CAAC,QAA2B,IAAI,OAAO,CAAC;IAC9D,MAAM,KAAK,GAAG,aAAa,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;IAEpD,MAAM,SAAS,GAAG,OAAO,IAAI,CAAC,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACvF,MAAM,OAAO,GACX,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC;IAEzF,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,GAAG,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAE7D,OAAO;QACL,EAAE,EAAE,IAAI;QACR,IAAI,EAAE;YACJ,IAAI,EAAE,YAAY;YAClB,SAAS;YACT,OAAO;YACP,UAAU,EAAE,KAAK,CAAC,MAAM;YACxB,OAAO,EAAE,KAAK;SACf;KACF,CAAC;AACJ,CAAC,CAAC"}