@deimoscloud/coreai 0.1.9 → 0.1.10

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 (196) hide show
  1. package/dist/cli/index.js +1 -1
  2. package/dist/cli/index.js.map +1 -1
  3. package/dist/index.js +1 -1
  4. package/dist/index.js.map +1 -1
  5. package/package.json +6 -1
  6. package/.prettierrc +0 -9
  7. package/AGENT_SPEC.md +0 -347
  8. package/ARCHITECTURE.md +0 -547
  9. package/DRAFT_PRD.md +0 -1440
  10. package/IMPLEMENTATION_PLAN.md +0 -256
  11. package/PRODUCT.md +0 -473
  12. package/WORKFLOWS.md +0 -295
  13. package/commands/core/check-inbox.md +0 -34
  14. package/commands/core/delegate.md +0 -30
  15. package/commands/core/git-commit.md +0 -144
  16. package/commands/core/pr-create.md +0 -193
  17. package/commands/core/review.md +0 -56
  18. package/commands/core/sprint-status.md +0 -65
  19. package/commands/optional/docs-update.md +0 -200
  20. package/commands/optional/jira-create.md +0 -200
  21. package/commands/optional/jira-transition.md +0 -184
  22. package/commands/optional/worktree-cleanup.md +0 -167
  23. package/commands/optional/worktree-setup.md +0 -110
  24. package/eslint.config.js +0 -29
  25. package/jest.config.js +0 -22
  26. package/knowledge-library/README.md +0 -118
  27. package/knowledge-library/android-engineer/context/current.txt +0 -42
  28. package/knowledge-library/android-engineer/control/decisions.txt +0 -9
  29. package/knowledge-library/android-engineer/control/dependencies.txt +0 -19
  30. package/knowledge-library/android-engineer/control/objectives.txt +0 -26
  31. package/knowledge-library/android-engineer/history/.gitkeep +0 -0
  32. package/knowledge-library/android-engineer/inbox/processed/.gitkeep +0 -0
  33. package/knowledge-library/android-engineer/outbox/.gitkeep +0 -0
  34. package/knowledge-library/android-engineer/tech/.gitkeep +0 -0
  35. package/knowledge-library/architecture.txt +0 -61
  36. package/knowledge-library/backend-engineer/context/current.txt +0 -42
  37. package/knowledge-library/backend-engineer/control/decisions.txt +0 -9
  38. package/knowledge-library/backend-engineer/control/dependencies.txt +0 -19
  39. package/knowledge-library/backend-engineer/control/objectives.txt +0 -26
  40. package/knowledge-library/backend-engineer/history/.gitkeep +0 -0
  41. package/knowledge-library/backend-engineer/inbox/processed/.gitkeep +0 -0
  42. package/knowledge-library/backend-engineer/outbox/.gitkeep +0 -0
  43. package/knowledge-library/backend-engineer/tech/.gitkeep +0 -0
  44. package/knowledge-library/context.txt +0 -52
  45. package/knowledge-library/devops-engineer/context/current.txt +0 -42
  46. package/knowledge-library/devops-engineer/control/decisions.txt +0 -9
  47. package/knowledge-library/devops-engineer/control/dependencies.txt +0 -19
  48. package/knowledge-library/devops-engineer/control/objectives.txt +0 -26
  49. package/knowledge-library/devops-engineer/history/.gitkeep +0 -0
  50. package/knowledge-library/devops-engineer/inbox/processed/.gitkeep +0 -0
  51. package/knowledge-library/devops-engineer/outbox/.gitkeep +0 -0
  52. package/knowledge-library/devops-engineer/tech/.gitkeep +0 -0
  53. package/knowledge-library/engineering-manager/context/current.txt +0 -40
  54. package/knowledge-library/engineering-manager/control/decisions.txt +0 -9
  55. package/knowledge-library/engineering-manager/control/objectives.txt +0 -27
  56. package/knowledge-library/engineering-manager/history/.gitkeep +0 -0
  57. package/knowledge-library/engineering-manager/inbox/processed/.gitkeep +0 -0
  58. package/knowledge-library/engineering-manager/outbox/.gitkeep +0 -0
  59. package/knowledge-library/engineering-manager/tech/.gitkeep +0 -0
  60. package/knowledge-library/prd.txt +0 -81
  61. package/knowledge-library/product-manager/context/current.txt +0 -42
  62. package/knowledge-library/product-manager/control/decisions.txt +0 -9
  63. package/knowledge-library/product-manager/control/dependencies.txt +0 -19
  64. package/knowledge-library/product-manager/control/objectives.txt +0 -26
  65. package/knowledge-library/product-manager/history/.gitkeep +0 -0
  66. package/knowledge-library/product-manager/inbox/processed/.gitkeep +0 -0
  67. package/knowledge-library/product-manager/outbox/.gitkeep +0 -0
  68. package/knowledge-library/product-manager/tech/.gitkeep +0 -0
  69. package/knowledge-library/qa-engineer/context/current.txt +0 -42
  70. package/knowledge-library/qa-engineer/control/decisions.txt +0 -9
  71. package/knowledge-library/qa-engineer/control/dependencies.txt +0 -19
  72. package/knowledge-library/qa-engineer/control/objectives.txt +0 -26
  73. package/knowledge-library/qa-engineer/history/.gitkeep +0 -0
  74. package/knowledge-library/qa-engineer/inbox/processed/.gitkeep +0 -0
  75. package/knowledge-library/qa-engineer/outbox/.gitkeep +0 -0
  76. package/knowledge-library/qa-engineer/tech/.gitkeep +0 -0
  77. package/knowledge-library/security-engineer/context/current.txt +0 -42
  78. package/knowledge-library/security-engineer/control/decisions.txt +0 -9
  79. package/knowledge-library/security-engineer/control/dependencies.txt +0 -19
  80. package/knowledge-library/security-engineer/control/objectives.txt +0 -26
  81. package/knowledge-library/security-engineer/history/.gitkeep +0 -0
  82. package/knowledge-library/security-engineer/inbox/processed/.gitkeep +0 -0
  83. package/knowledge-library/security-engineer/outbox/.gitkeep +0 -0
  84. package/knowledge-library/security-engineer/tech/.gitkeep +0 -0
  85. package/knowledge-library/solutions-architect/context/current.txt +0 -42
  86. package/knowledge-library/solutions-architect/control/decisions.txt +0 -9
  87. package/knowledge-library/solutions-architect/control/dependencies.txt +0 -19
  88. package/knowledge-library/solutions-architect/control/objectives.txt +0 -26
  89. package/knowledge-library/solutions-architect/history/.gitkeep +0 -0
  90. package/knowledge-library/solutions-architect/inbox/processed/.gitkeep +0 -0
  91. package/knowledge-library/solutions-architect/outbox/.gitkeep +0 -0
  92. package/knowledge-library/solutions-architect/tech/.gitkeep +0 -0
  93. package/knowledge-library/wearos-engineer/context/current.txt +0 -42
  94. package/knowledge-library/wearos-engineer/control/decisions.txt +0 -9
  95. package/knowledge-library/wearos-engineer/control/dependencies.txt +0 -19
  96. package/knowledge-library/wearos-engineer/control/objectives.txt +0 -26
  97. package/knowledge-library/wearos-engineer/history/.gitkeep +0 -0
  98. package/knowledge-library/wearos-engineer/inbox/processed/.gitkeep +0 -0
  99. package/knowledge-library/wearos-engineer/outbox/.gitkeep +0 -0
  100. package/knowledge-library/wearos-engineer/tech/.gitkeep +0 -0
  101. package/scripts/add-agent.sh +0 -323
  102. package/scripts/install.sh +0 -354
  103. package/src/adapters/factory.test.ts +0 -386
  104. package/src/adapters/factory.ts +0 -305
  105. package/src/adapters/index.ts +0 -113
  106. package/src/adapters/interfaces.ts +0 -268
  107. package/src/adapters/mcp/client.test.ts +0 -130
  108. package/src/adapters/mcp/client.ts +0 -451
  109. package/src/adapters/mcp/discovery.test.ts +0 -315
  110. package/src/adapters/mcp/discovery.ts +0 -340
  111. package/src/adapters/mcp/index.ts +0 -66
  112. package/src/adapters/mcp/mapper.test.ts +0 -218
  113. package/src/adapters/mcp/mapper.ts +0 -536
  114. package/src/adapters/mcp/registry.test.ts +0 -433
  115. package/src/adapters/mcp/registry.ts +0 -550
  116. package/src/adapters/mcp/types.ts +0 -258
  117. package/src/adapters/native/filesystem.test.ts +0 -350
  118. package/src/adapters/native/filesystem.ts +0 -393
  119. package/src/adapters/native/github.test.ts +0 -173
  120. package/src/adapters/native/github.ts +0 -627
  121. package/src/adapters/native/index.ts +0 -22
  122. package/src/adapters/native/selector.test.ts +0 -224
  123. package/src/adapters/native/selector.ts +0 -150
  124. package/src/adapters/types.ts +0 -270
  125. package/src/agents/compiler.test.ts +0 -410
  126. package/src/agents/compiler.ts +0 -424
  127. package/src/agents/index.ts +0 -37
  128. package/src/agents/loader.test.ts +0 -319
  129. package/src/agents/loader.ts +0 -143
  130. package/src/agents/resolver.test.ts +0 -282
  131. package/src/agents/resolver.ts +0 -262
  132. package/src/agents/types.ts +0 -97
  133. package/src/cache/index.ts +0 -38
  134. package/src/cache/interfaces.ts +0 -283
  135. package/src/cache/manager.test.ts +0 -266
  136. package/src/cache/manager.ts +0 -388
  137. package/src/cache/provider.test.ts +0 -485
  138. package/src/cache/provider.ts +0 -745
  139. package/src/cache/types.test.ts +0 -192
  140. package/src/cache/types.ts +0 -313
  141. package/src/cli/commands/build.test.ts +0 -248
  142. package/src/cli/commands/build.ts +0 -284
  143. package/src/cli/commands/cache.test.ts +0 -221
  144. package/src/cli/commands/cache.ts +0 -229
  145. package/src/cli/commands/index.ts +0 -63
  146. package/src/cli/commands/init.test.ts +0 -173
  147. package/src/cli/commands/init.ts +0 -296
  148. package/src/cli/commands/skills.test.ts +0 -272
  149. package/src/cli/commands/skills.ts +0 -348
  150. package/src/cli/commands/status.test.ts +0 -392
  151. package/src/cli/commands/status.ts +0 -332
  152. package/src/cli/commands/sync.test.ts +0 -213
  153. package/src/cli/commands/sync.ts +0 -251
  154. package/src/cli/commands/validate.test.ts +0 -216
  155. package/src/cli/commands/validate.ts +0 -340
  156. package/src/cli/index.test.ts +0 -190
  157. package/src/cli/index.ts +0 -493
  158. package/src/commands/context.test.ts +0 -163
  159. package/src/commands/context.ts +0 -111
  160. package/src/commands/index.ts +0 -56
  161. package/src/commands/loader.test.ts +0 -273
  162. package/src/commands/loader.ts +0 -355
  163. package/src/commands/registry.test.ts +0 -384
  164. package/src/commands/registry.ts +0 -248
  165. package/src/commands/runner.test.ts +0 -297
  166. package/src/commands/runner.ts +0 -222
  167. package/src/commands/types.ts +0 -361
  168. package/src/config/index.ts +0 -19
  169. package/src/config/loader.test.ts +0 -262
  170. package/src/config/loader.ts +0 -188
  171. package/src/config/types.ts +0 -154
  172. package/src/context/index.ts +0 -14
  173. package/src/context/loader.test.ts +0 -334
  174. package/src/context/loader.ts +0 -357
  175. package/src/index.test.ts +0 -13
  176. package/src/index.ts +0 -268
  177. package/src/knowledge-library/index.ts +0 -44
  178. package/src/knowledge-library/manager.test.ts +0 -536
  179. package/src/knowledge-library/manager.ts +0 -804
  180. package/src/knowledge-library/types.ts +0 -432
  181. package/src/skills/generator.test.ts +0 -602
  182. package/src/skills/generator.ts +0 -491
  183. package/src/skills/index.ts +0 -27
  184. package/src/skills/templates.ts +0 -520
  185. package/src/skills/types.ts +0 -251
  186. package/templates/completion-report.md +0 -72
  187. package/templates/feedback.md +0 -56
  188. package/templates/project-files/CLAUDE.md.template +0 -109
  189. package/templates/project-files/coreai.json.example +0 -47
  190. package/templates/project-files/mcp.json.template +0 -20
  191. package/templates/review-complete.md +0 -64
  192. package/templates/review-request.md +0 -67
  193. package/templates/task-assignment.md +0 -51
  194. package/tsconfig.build.json +0 -4
  195. package/tsconfig.json +0 -26
  196. package/tsup.config.ts +0 -23
@@ -1,392 +0,0 @@
1
- /**
2
- * Status Command Tests
3
- */
4
-
5
- import { promises as fs } from 'fs';
6
- import { join } from 'path';
7
- import { tmpdir } from 'os';
8
- import { status, formatStatusResult, formatStatusSummary } from './status.js';
9
- import {
10
- initKnowledgeLibrary,
11
- initAgentKnowledgeLibrary,
12
- writeInboxMessage,
13
- updateAgentContext,
14
- } from '../../knowledge-library/index.js';
15
-
16
- describe('Status Command', () => {
17
- let testDir: string;
18
-
19
- beforeEach(async () => {
20
- testDir = join(
21
- tmpdir(),
22
- `status-cmd-test-${Date.now()}-${Math.random().toString(36).slice(2)}`
23
- );
24
- await fs.mkdir(testDir, { recursive: true });
25
- });
26
-
27
- afterEach(async () => {
28
- try {
29
- await fs.rm(testDir, { recursive: true, force: true });
30
- } catch {
31
- // Ignore cleanup errors
32
- }
33
- });
34
-
35
- describe('status', () => {
36
- it('should warn when KnowledgeLibrary not initialized', () => {
37
- const result = status({ projectRoot: testDir });
38
-
39
- expect(result.success).toBe(true);
40
- expect(result.agents).toEqual([]);
41
- expect(result.warnings).toBeDefined();
42
- expect(result.warnings?.some((w) => w.includes('not initialized'))).toBe(true);
43
- });
44
-
45
- it('should initialize KnowledgeLibrary with init option', () => {
46
- const result = status({ projectRoot: testDir, init: true });
47
-
48
- expect(result.success).toBe(true);
49
- expect(result.knowledgeLibrary).toBeDefined();
50
- });
51
-
52
- it('should show agents from KnowledgeLibrary', () => {
53
- initKnowledgeLibrary({ projectRoot: testDir });
54
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
55
- initAgentKnowledgeLibrary('frontend-engineer', { projectRoot: testDir });
56
-
57
- const result = status({ projectRoot: testDir });
58
-
59
- expect(result.success).toBe(true);
60
- expect(result.agents.length).toBe(2);
61
- expect(result.agents.map((a) => a.name)).toContain('backend-engineer');
62
- expect(result.agents.map((a) => a.name)).toContain('frontend-engineer');
63
- });
64
-
65
- it('should show agents from config', async () => {
66
- // Create config with agents
67
- const configContent = `
68
- version: "1.0"
69
- project:
70
- name: test-project
71
- team:
72
- agents:
73
- - backend-engineer
74
- - qa-engineer
75
- `;
76
- await fs.writeFile(join(testDir, 'coreai.config.yaml'), configContent);
77
-
78
- initKnowledgeLibrary({ projectRoot: testDir });
79
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
80
-
81
- const result = status({ projectRoot: testDir });
82
-
83
- expect(result.success).toBe(true);
84
- // Should include both configured and initialized agents
85
- expect(result.agents.map((a) => a.name)).toContain('backend-engineer');
86
- expect(result.agents.map((a) => a.name)).toContain('qa-engineer');
87
- });
88
-
89
- it('should show status for specific agent', () => {
90
- initKnowledgeLibrary({ projectRoot: testDir });
91
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
92
- initAgentKnowledgeLibrary('frontend-engineer', { projectRoot: testDir });
93
-
94
- const result = status({ projectRoot: testDir, agent: 'backend-engineer' });
95
-
96
- expect(result.success).toBe(true);
97
- expect(result.agents.length).toBe(1);
98
- expect(result.agents[0]?.name).toBe('backend-engineer');
99
- });
100
-
101
- it('should show pending message count', () => {
102
- initKnowledgeLibrary({ projectRoot: testDir });
103
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
104
- initAgentKnowledgeLibrary('em', { projectRoot: testDir });
105
-
106
- writeInboxMessage({
107
- projectRoot: testDir,
108
- type: 'task-assignment',
109
- from: 'em',
110
- to: 'backend-engineer',
111
- subject: 'Task 1',
112
- body: 'Body 1',
113
- });
114
-
115
- writeInboxMessage({
116
- projectRoot: testDir,
117
- type: 'task-assignment',
118
- from: 'em',
119
- to: 'backend-engineer',
120
- subject: 'Task 2',
121
- body: 'Body 2',
122
- });
123
-
124
- const result = status({ projectRoot: testDir });
125
-
126
- expect(result.success).toBe(true);
127
- const beAgent = result.agents.find((a) => a.name === 'backend-engineer');
128
- expect(beAgent?.pendingMessages).toBe(2);
129
- });
130
-
131
- it('should show agent context', () => {
132
- initKnowledgeLibrary({ projectRoot: testDir });
133
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
134
-
135
- updateAgentContext(
136
- 'backend-engineer',
137
- {
138
- status: 'working',
139
- currentTask: 'Implementing feature X',
140
- currentTicket: 'PROJ-123',
141
- },
142
- { projectRoot: testDir }
143
- );
144
-
145
- const result = status({ projectRoot: testDir });
146
-
147
- expect(result.success).toBe(true);
148
- const beAgent = result.agents.find((a) => a.name === 'backend-engineer');
149
- expect(beAgent?.status).toBe('working');
150
- expect(beAgent?.currentTask).toBe('Implementing feature X');
151
- expect(beAgent?.currentTicket).toBe('PROJ-123');
152
- });
153
-
154
- it('should include message details in detailed mode', () => {
155
- initKnowledgeLibrary({ projectRoot: testDir });
156
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
157
- initAgentKnowledgeLibrary('em', { projectRoot: testDir });
158
-
159
- writeInboxMessage({
160
- projectRoot: testDir,
161
- type: 'task-assignment',
162
- from: 'em',
163
- to: 'backend-engineer',
164
- subject: 'Implement Feature X',
165
- body: 'Details',
166
- });
167
-
168
- const result = status({ projectRoot: testDir, detailed: true });
169
-
170
- expect(result.success).toBe(true);
171
- const beAgent = result.agents.find((a) => a.name === 'backend-engineer');
172
- expect(beAgent?.messageDetails).toBeDefined();
173
- expect(beAgent?.messageDetails?.length).toBe(1);
174
- expect(beAgent?.messageDetails?.[0]?.type).toBe('task-assignment');
175
- expect(beAgent?.messageDetails?.[0]?.from).toBe('em');
176
- });
177
-
178
- it('should sort agents by pending messages', () => {
179
- initKnowledgeLibrary({ projectRoot: testDir });
180
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
181
- initAgentKnowledgeLibrary('frontend-engineer', { projectRoot: testDir });
182
- initAgentKnowledgeLibrary('em', { projectRoot: testDir });
183
-
184
- // frontend-engineer gets more messages
185
- writeInboxMessage({
186
- projectRoot: testDir,
187
- type: 'task-assignment',
188
- from: 'em',
189
- to: 'frontend-engineer',
190
- subject: 'Task 1',
191
- body: 'Body',
192
- });
193
- writeInboxMessage({
194
- projectRoot: testDir,
195
- type: 'task-assignment',
196
- from: 'em',
197
- to: 'frontend-engineer',
198
- subject: 'Task 2',
199
- body: 'Body',
200
- });
201
-
202
- // backend-engineer gets one message
203
- writeInboxMessage({
204
- projectRoot: testDir,
205
- type: 'task-assignment',
206
- from: 'em',
207
- to: 'backend-engineer',
208
- subject: 'Task 1',
209
- body: 'Body',
210
- });
211
-
212
- const result = status({ projectRoot: testDir });
213
-
214
- expect(result.success).toBe(true);
215
- // frontend-engineer should be first (2 messages)
216
- expect(result.agents[0]?.name).toBe('frontend-engineer');
217
- expect(result.agents[0]?.pendingMessages).toBe(2);
218
- });
219
-
220
- it('should show uninitialized agents from config', async () => {
221
- const configContent = `
222
- version: "1.0"
223
- project:
224
- name: test-project
225
- team:
226
- agents:
227
- - backend-engineer
228
- - qa-engineer
229
- `;
230
- await fs.writeFile(join(testDir, 'coreai.config.yaml'), configContent);
231
-
232
- initKnowledgeLibrary({ projectRoot: testDir });
233
- // Don't initialize any agents
234
-
235
- const result = status({ projectRoot: testDir });
236
-
237
- expect(result.success).toBe(true);
238
- expect(result.agents.length).toBe(2);
239
- expect(result.agents.every((a) => !a.initialized)).toBe(true);
240
- });
241
- });
242
-
243
- describe('formatStatusResult', () => {
244
- it('should format empty result', () => {
245
- const result = status({ projectRoot: testDir, init: true });
246
- const output = formatStatusResult(result);
247
-
248
- expect(output).toContain('No agents found');
249
- });
250
-
251
- it('should format agents with pending messages', () => {
252
- initKnowledgeLibrary({ projectRoot: testDir });
253
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
254
- initAgentKnowledgeLibrary('em', { projectRoot: testDir });
255
-
256
- writeInboxMessage({
257
- projectRoot: testDir,
258
- type: 'task-assignment',
259
- from: 'em',
260
- to: 'backend-engineer',
261
- subject: 'Test Task',
262
- body: 'Body',
263
- });
264
-
265
- const result = status({ projectRoot: testDir });
266
- const output = formatStatusResult(result);
267
-
268
- expect(output).toContain('backend-engineer');
269
- expect(output).toContain('Pending messages: 1');
270
- });
271
-
272
- it('should format agents with current task', () => {
273
- initKnowledgeLibrary({ projectRoot: testDir });
274
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
275
-
276
- updateAgentContext(
277
- 'backend-engineer',
278
- {
279
- status: 'working',
280
- currentTask: 'Implementing feature X',
281
- },
282
- { projectRoot: testDir }
283
- );
284
-
285
- const result = status({ projectRoot: testDir });
286
- const output = formatStatusResult(result);
287
-
288
- expect(output).toContain('backend-engineer');
289
- expect(output).toContain('Status: working');
290
- expect(output).toContain('Implementing feature X');
291
- });
292
-
293
- it('should show error result', () => {
294
- const result = {
295
- success: false,
296
- agents: [],
297
- error: 'Something went wrong',
298
- };
299
-
300
- const output = formatStatusResult(result);
301
- expect(output).toContain('Error');
302
- expect(output).toContain('Something went wrong');
303
- });
304
-
305
- it('should show warnings', () => {
306
- const result = {
307
- success: true,
308
- agents: [],
309
- warnings: ['Warning 1', 'Warning 2'],
310
- };
311
-
312
- const output = formatStatusResult(result);
313
- expect(output).toContain('Warning 1');
314
- expect(output).toContain('Warning 2');
315
- });
316
-
317
- it('should show summary counts', () => {
318
- initKnowledgeLibrary({ projectRoot: testDir });
319
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
320
- initAgentKnowledgeLibrary('frontend-engineer', { projectRoot: testDir });
321
-
322
- updateAgentContext('backend-engineer', { status: 'working' }, { projectRoot: testDir });
323
-
324
- const result = status({ projectRoot: testDir });
325
- const output = formatStatusResult(result);
326
-
327
- expect(output).toContain('Total agents: 2');
328
- expect(output).toContain('Active: 1');
329
- });
330
-
331
- it('should show message details in detailed mode', () => {
332
- initKnowledgeLibrary({ projectRoot: testDir });
333
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
334
- initAgentKnowledgeLibrary('em', { projectRoot: testDir });
335
-
336
- writeInboxMessage({
337
- projectRoot: testDir,
338
- type: 'task-assignment',
339
- from: 'em',
340
- to: 'backend-engineer',
341
- subject: 'Implement Feature X',
342
- body: 'Details',
343
- });
344
-
345
- const result = status({ projectRoot: testDir, detailed: true });
346
- const output = formatStatusResult(result);
347
-
348
- expect(output).toContain('task-assignment');
349
- expect(output).toContain('from em');
350
- expect(output).toContain('Implement Feature X');
351
- });
352
- });
353
-
354
- describe('formatStatusSummary', () => {
355
- it('should format compact summary', () => {
356
- initKnowledgeLibrary({ projectRoot: testDir });
357
- initAgentKnowledgeLibrary('backend-engineer', { projectRoot: testDir });
358
- initAgentKnowledgeLibrary('frontend-engineer', { projectRoot: testDir });
359
- initAgentKnowledgeLibrary('em', { projectRoot: testDir });
360
-
361
- updateAgentContext('backend-engineer', { status: 'working' }, { projectRoot: testDir });
362
-
363
- writeInboxMessage({
364
- projectRoot: testDir,
365
- type: 'task-assignment',
366
- from: 'em',
367
- to: 'frontend-engineer',
368
- subject: 'Task',
369
- body: 'Body',
370
- });
371
-
372
- const result = status({ projectRoot: testDir });
373
- const summary = formatStatusSummary(result);
374
-
375
- expect(summary).toContain('3 agents');
376
- expect(summary).toContain('1 active');
377
- expect(summary).toContain('1 pending messages');
378
- });
379
-
380
- it('should format error', () => {
381
- const result = {
382
- success: false,
383
- agents: [],
384
- error: 'Something went wrong',
385
- };
386
-
387
- const summary = formatStatusSummary(result);
388
- expect(summary).toContain('Error');
389
- expect(summary).toContain('Something went wrong');
390
- });
391
- });
392
- });