sage-team 3.0.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 (178) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +180 -0
  3. package/dist/agents/__tests__/personas.test.d.ts +2 -0
  4. package/dist/agents/__tests__/personas.test.d.ts.map +1 -0
  5. package/dist/agents/__tests__/personas.test.js +47 -0
  6. package/dist/agents/__tests__/personas.test.js.map +1 -0
  7. package/dist/agents/personas.d.ts +3 -0
  8. package/dist/agents/personas.d.ts.map +1 -0
  9. package/dist/agents/personas.js +127 -0
  10. package/dist/agents/personas.js.map +1 -0
  11. package/dist/agents/skills-map.d.ts +7 -0
  12. package/dist/agents/skills-map.d.ts.map +1 -0
  13. package/dist/agents/skills-map.js +55 -0
  14. package/dist/agents/skills-map.js.map +1 -0
  15. package/dist/cli/__tests__/cli.test.d.ts +2 -0
  16. package/dist/cli/__tests__/cli.test.d.ts.map +1 -0
  17. package/dist/cli/__tests__/cli.test.js +65 -0
  18. package/dist/cli/__tests__/cli.test.js.map +1 -0
  19. package/dist/cli/commands/config.d.ts +3 -0
  20. package/dist/cli/commands/config.d.ts.map +1 -0
  21. package/dist/cli/commands/config.js +50 -0
  22. package/dist/cli/commands/config.js.map +1 -0
  23. package/dist/cli/commands/doctor.d.ts +9 -0
  24. package/dist/cli/commands/doctor.d.ts.map +1 -0
  25. package/dist/cli/commands/doctor.js +74 -0
  26. package/dist/cli/commands/doctor.js.map +1 -0
  27. package/dist/cli/commands/init.d.ts +3 -0
  28. package/dist/cli/commands/init.d.ts.map +1 -0
  29. package/dist/cli/commands/init.js +67 -0
  30. package/dist/cli/commands/init.js.map +1 -0
  31. package/dist/cli/commands/logs.d.ts +3 -0
  32. package/dist/cli/commands/logs.d.ts.map +1 -0
  33. package/dist/cli/commands/logs.js +51 -0
  34. package/dist/cli/commands/logs.js.map +1 -0
  35. package/dist/cli/commands/resume.d.ts +3 -0
  36. package/dist/cli/commands/resume.d.ts.map +1 -0
  37. package/dist/cli/commands/resume.js +106 -0
  38. package/dist/cli/commands/resume.js.map +1 -0
  39. package/dist/cli/commands/start.d.ts +3 -0
  40. package/dist/cli/commands/start.d.ts.map +1 -0
  41. package/dist/cli/commands/start.js +103 -0
  42. package/dist/cli/commands/start.js.map +1 -0
  43. package/dist/cli/commands/status.d.ts +3 -0
  44. package/dist/cli/commands/status.d.ts.map +1 -0
  45. package/dist/cli/commands/status.js +64 -0
  46. package/dist/cli/commands/status.js.map +1 -0
  47. package/dist/cli/commands/team.d.ts +4 -0
  48. package/dist/cli/commands/team.d.ts.map +1 -0
  49. package/dist/cli/commands/team.js +33 -0
  50. package/dist/cli/commands/team.js.map +1 -0
  51. package/dist/cli/index.d.ts +4 -0
  52. package/dist/cli/index.d.ts.map +1 -0
  53. package/dist/cli/index.js +35 -0
  54. package/dist/cli/index.js.map +1 -0
  55. package/dist/cli/splash.d.ts +2 -0
  56. package/dist/cli/splash.d.ts.map +1 -0
  57. package/dist/cli/splash.js +20 -0
  58. package/dist/cli/splash.js.map +1 -0
  59. package/dist/engine/__tests__/ceo-brain.test.d.ts +2 -0
  60. package/dist/engine/__tests__/ceo-brain.test.d.ts.map +1 -0
  61. package/dist/engine/__tests__/ceo-brain.test.js +57 -0
  62. package/dist/engine/__tests__/ceo-brain.test.js.map +1 -0
  63. package/dist/engine/__tests__/dispatcher.test.d.ts +2 -0
  64. package/dist/engine/__tests__/dispatcher.test.d.ts.map +1 -0
  65. package/dist/engine/__tests__/dispatcher.test.js +60 -0
  66. package/dist/engine/__tests__/dispatcher.test.js.map +1 -0
  67. package/dist/engine/__tests__/orchestrator.test.d.ts +2 -0
  68. package/dist/engine/__tests__/orchestrator.test.d.ts.map +1 -0
  69. package/dist/engine/__tests__/orchestrator.test.js +83 -0
  70. package/dist/engine/__tests__/orchestrator.test.js.map +1 -0
  71. package/dist/engine/__tests__/pr-manager.test.d.ts +2 -0
  72. package/dist/engine/__tests__/pr-manager.test.d.ts.map +1 -0
  73. package/dist/engine/__tests__/pr-manager.test.js +44 -0
  74. package/dist/engine/__tests__/pr-manager.test.js.map +1 -0
  75. package/dist/engine/__tests__/prompt-builder.test.d.ts +2 -0
  76. package/dist/engine/__tests__/prompt-builder.test.d.ts.map +1 -0
  77. package/dist/engine/__tests__/prompt-builder.test.js +42 -0
  78. package/dist/engine/__tests__/prompt-builder.test.js.map +1 -0
  79. package/dist/engine/ceo-brain.d.ts +33 -0
  80. package/dist/engine/ceo-brain.d.ts.map +1 -0
  81. package/dist/engine/ceo-brain.js +94 -0
  82. package/dist/engine/ceo-brain.js.map +1 -0
  83. package/dist/engine/dispatcher.d.ts +40 -0
  84. package/dist/engine/dispatcher.d.ts.map +1 -0
  85. package/dist/engine/dispatcher.js +125 -0
  86. package/dist/engine/dispatcher.js.map +1 -0
  87. package/dist/engine/orchestrator.d.ts +49 -0
  88. package/dist/engine/orchestrator.d.ts.map +1 -0
  89. package/dist/engine/orchestrator.js +303 -0
  90. package/dist/engine/orchestrator.js.map +1 -0
  91. package/dist/engine/pr-manager.d.ts +14 -0
  92. package/dist/engine/pr-manager.d.ts.map +1 -0
  93. package/dist/engine/pr-manager.js +67 -0
  94. package/dist/engine/pr-manager.js.map +1 -0
  95. package/dist/engine/prompt-builder.d.ts +27 -0
  96. package/dist/engine/prompt-builder.d.ts.map +1 -0
  97. package/dist/engine/prompt-builder.js +73 -0
  98. package/dist/engine/prompt-builder.js.map +1 -0
  99. package/dist/server/__tests__/server.test.d.ts +2 -0
  100. package/dist/server/__tests__/server.test.d.ts.map +1 -0
  101. package/dist/server/__tests__/server.test.js +87 -0
  102. package/dist/server/__tests__/server.test.js.map +1 -0
  103. package/dist/server/index.d.ts +4 -0
  104. package/dist/server/index.d.ts.map +1 -0
  105. package/dist/server/index.js +72 -0
  106. package/dist/server/index.js.map +1 -0
  107. package/dist/server/routes/api.d.ts +4 -0
  108. package/dist/server/routes/api.d.ts.map +1 -0
  109. package/dist/server/routes/api.js +60 -0
  110. package/dist/server/routes/api.js.map +1 -0
  111. package/dist/skills/__tests__/loader.test.d.ts +2 -0
  112. package/dist/skills/__tests__/loader.test.d.ts.map +1 -0
  113. package/dist/skills/__tests__/loader.test.js +50 -0
  114. package/dist/skills/__tests__/loader.test.js.map +1 -0
  115. package/dist/skills/loader.d.ts +21 -0
  116. package/dist/skills/loader.d.ts.map +1 -0
  117. package/dist/skills/loader.js +190 -0
  118. package/dist/skills/loader.js.map +1 -0
  119. package/dist/state/__tests__/database.test.d.ts +2 -0
  120. package/dist/state/__tests__/database.test.d.ts.map +1 -0
  121. package/dist/state/__tests__/database.test.js +50 -0
  122. package/dist/state/__tests__/database.test.js.map +1 -0
  123. package/dist/state/database.d.ts +14 -0
  124. package/dist/state/database.d.ts.map +1 -0
  125. package/dist/state/database.js +164 -0
  126. package/dist/state/database.js.map +1 -0
  127. package/dist/state/repositories/__tests__/repositories.test.d.ts +2 -0
  128. package/dist/state/repositories/__tests__/repositories.test.d.ts.map +1 -0
  129. package/dist/state/repositories/__tests__/repositories.test.js +162 -0
  130. package/dist/state/repositories/__tests__/repositories.test.js.map +1 -0
  131. package/dist/state/repositories/agents.d.ts +14 -0
  132. package/dist/state/repositories/agents.d.ts.map +1 -0
  133. package/dist/state/repositories/agents.js +52 -0
  134. package/dist/state/repositories/agents.js.map +1 -0
  135. package/dist/state/repositories/events.d.ts +10 -0
  136. package/dist/state/repositories/events.d.ts.map +1 -0
  137. package/dist/state/repositories/events.js +27 -0
  138. package/dist/state/repositories/events.js.map +1 -0
  139. package/dist/state/repositories/messages.d.ts +15 -0
  140. package/dist/state/repositories/messages.d.ts.map +1 -0
  141. package/dist/state/repositories/messages.js +19 -0
  142. package/dist/state/repositories/messages.js.map +1 -0
  143. package/dist/state/repositories/pull-requests.d.ts +25 -0
  144. package/dist/state/repositories/pull-requests.d.ts.map +1 -0
  145. package/dist/state/repositories/pull-requests.js +40 -0
  146. package/dist/state/repositories/pull-requests.js.map +1 -0
  147. package/dist/state/repositories/sessions.d.ts +13 -0
  148. package/dist/state/repositories/sessions.d.ts.map +1 -0
  149. package/dist/state/repositories/sessions.js +41 -0
  150. package/dist/state/repositories/sessions.js.map +1 -0
  151. package/dist/state/repositories/sprints.d.ts +19 -0
  152. package/dist/state/repositories/sprints.d.ts.map +1 -0
  153. package/dist/state/repositories/sprints.js +26 -0
  154. package/dist/state/repositories/sprints.js.map +1 -0
  155. package/dist/state/repositories/tasks.d.ts +26 -0
  156. package/dist/state/repositories/tasks.d.ts.map +1 -0
  157. package/dist/state/repositories/tasks.js +43 -0
  158. package/dist/state/repositories/tasks.js.map +1 -0
  159. package/dist/types/__tests__/types.test.d.ts +2 -0
  160. package/dist/types/__tests__/types.test.d.ts.map +1 -0
  161. package/dist/types/__tests__/types.test.js +70 -0
  162. package/dist/types/__tests__/types.test.js.map +1 -0
  163. package/dist/types/index.d.ts +198 -0
  164. package/dist/types/index.d.ts.map +1 -0
  165. package/dist/types/index.js +3 -0
  166. package/dist/types/index.js.map +1 -0
  167. package/package.json +65 -0
  168. package/src/web/dist/assets/BufferResource-rnljfCCz.js +185 -0
  169. package/src/web/dist/assets/CanvasRenderer-BvTI2UTL.js +1 -0
  170. package/src/web/dist/assets/Filter-BzO9QkkB.js +1 -0
  171. package/src/web/dist/assets/RenderTargetSystem-CKlnKfTJ.js +172 -0
  172. package/src/web/dist/assets/WebGLRenderer-B5LAM4bk.js +156 -0
  173. package/src/web/dist/assets/WebGPURenderer-FkK3p3f4.js +41 -0
  174. package/src/web/dist/assets/browserAll-CDpBxY6s.js +14 -0
  175. package/src/web/dist/assets/index-B3XZpovA.js +298 -0
  176. package/src/web/dist/assets/index-BcX-h_hs.css +1 -0
  177. package/src/web/dist/assets/webworkerAll-B9AvsPZH.js +83 -0
  178. package/src/web/dist/index.html +18 -0
@@ -0,0 +1,35 @@
1
+ #!/usr/bin/env node
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.buildProgram = buildProgram;
5
+ const commander_1 = require("commander");
6
+ const init_1 = require("./commands/init");
7
+ const start_1 = require("./commands/start");
8
+ const resume_1 = require("./commands/resume");
9
+ const config_1 = require("./commands/config");
10
+ const team_1 = require("./commands/team");
11
+ const status_1 = require("./commands/status");
12
+ const doctor_1 = require("./commands/doctor");
13
+ const logs_1 = require("./commands/logs");
14
+ function buildProgram() {
15
+ const program = new commander_1.Command();
16
+ program
17
+ .name('sage-team')
18
+ .description('AI-powered autonomous software company')
19
+ .version('3.0.0');
20
+ program.addCommand((0, init_1.initCommand)());
21
+ program.addCommand((0, start_1.startCommand)());
22
+ program.addCommand((0, resume_1.resumeCommand)());
23
+ program.addCommand((0, config_1.configCommand)());
24
+ program.addCommand((0, team_1.teamCommand)());
25
+ program.addCommand((0, status_1.statusCommand)());
26
+ program.addCommand((0, doctor_1.doctorCommand)());
27
+ program.addCommand((0, logs_1.logsCommand)());
28
+ return program;
29
+ }
30
+ // Only run if executed directly
31
+ if (require.main === module) {
32
+ const program = buildProgram();
33
+ program.parse(process.argv);
34
+ }
35
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":";;;AAWA,oCAkBC;AA5BD,yCAAoC;AACpC,0CAA8C;AAC9C,4CAAgD;AAChD,8CAAkD;AAClD,8CAAkD;AAClD,0CAA8C;AAC9C,8CAAkD;AAClD,8CAAkD;AAClD,0CAA8C;AAE9C,SAAgB,YAAY;IAC1B,MAAM,OAAO,GAAG,IAAI,mBAAO,EAAE,CAAC;IAE9B,OAAO;SACJ,IAAI,CAAC,WAAW,CAAC;SACjB,WAAW,CAAC,wCAAwC,CAAC;SACrD,OAAO,CAAC,OAAO,CAAC,CAAC;IAEpB,OAAO,CAAC,UAAU,CAAC,IAAA,kBAAW,GAAE,CAAC,CAAC;IAClC,OAAO,CAAC,UAAU,CAAC,IAAA,oBAAY,GAAE,CAAC,CAAC;IACnC,OAAO,CAAC,UAAU,CAAC,IAAA,sBAAa,GAAE,CAAC,CAAC;IACpC,OAAO,CAAC,UAAU,CAAC,IAAA,sBAAa,GAAE,CAAC,CAAC;IACpC,OAAO,CAAC,UAAU,CAAC,IAAA,kBAAW,GAAE,CAAC,CAAC;IAClC,OAAO,CAAC,UAAU,CAAC,IAAA,sBAAa,GAAE,CAAC,CAAC;IACpC,OAAO,CAAC,UAAU,CAAC,IAAA,sBAAa,GAAE,CAAC,CAAC;IACpC,OAAO,CAAC,UAAU,CAAC,IAAA,kBAAW,GAAE,CAAC,CAAC;IAElC,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,gCAAgC;AAChC,IAAI,OAAO,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;IAC5B,MAAM,OAAO,GAAG,YAAY,EAAE,CAAC;IAC/B,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;AAC9B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function showSplash(): void;
2
+ //# sourceMappingURL=splash.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"splash.d.ts","sourceRoot":"","sources":["../../src/cli/splash.ts"],"names":[],"mappings":"AAEA,wBAAgB,UAAU,IAAI,IAAI,CAejC"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.showSplash = showSplash;
4
+ const personas_1 = require("../agents/personas");
5
+ function showSplash() {
6
+ const art = `
7
+ ____ _____
8
+ / ___| __ _ __ _ ___|_ _|__ __ _ _ __ ___
9
+ \\___ \\ / _\` |/ _\` |/ _ \\ | |/ _ \\/ _\` | '_ \` _ \\
10
+ ___) | (_| | (_| | __/ | | __/ (_| | | | | | |
11
+ |____/ \\__,_|\\__, |\\___| |_|\\___|\\__,_|_| |_| |_|
12
+ |___/ v3.0
13
+ `;
14
+ console.log(art);
15
+ console.log(' AI-Powered Autonomous Software Company\n');
16
+ const roster = personas_1.PERSONAS.map(p => ` ${p.emoji} ${p.name.padEnd(8)} ${p.role}`).join('\n');
17
+ console.log(roster);
18
+ console.log('');
19
+ }
20
+ //# sourceMappingURL=splash.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"splash.js","sourceRoot":"","sources":["../../src/cli/splash.ts"],"names":[],"mappings":";;AAEA,gCAeC;AAjBD,iDAA8C;AAE9C,SAAgB,UAAU;IACxB,MAAM,GAAG,GAAG;;;;;;;CAOb,CAAC;IACA,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACjB,OAAO,CAAC,GAAG,CAAC,4CAA4C,CAAC,CAAC;IAE1D,MAAM,MAAM,GAAG,mBAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1F,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACpB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;AAClB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=ceo-brain.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ceo-brain.test.d.ts","sourceRoot":"","sources":["../../../src/engine/__tests__/ceo-brain.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const vitest_1 = require("vitest");
4
+ const ceo_brain_1 = require("../ceo-brain");
5
+ (0, vitest_1.describe)('CEOBrain', () => {
6
+ (0, vitest_1.it)('should format goal decomposition prompt correctly', () => {
7
+ const brain = new ceo_brain_1.CEOBrain({ apiKey: 'test', model: 'claude-sonnet-4-20250514' });
8
+ const prompt = brain.buildDecompositionPrompt('Build a REST API for todo app', [{ id: 'dex', name: 'Dex', role: 'dev-senior', skills: ['sp-tdd-cycle', 'ag-typescript-pro'] }]);
9
+ (0, vitest_1.expect)(prompt).toContain('Build a REST API for todo app');
10
+ (0, vitest_1.expect)(prompt).toContain('Dex');
11
+ (0, vitest_1.expect)(prompt).toContain('sp-tdd-cycle');
12
+ });
13
+ (0, vitest_1.it)('should parse decomposition response into tasks', () => {
14
+ const brain = new ceo_brain_1.CEOBrain({ apiKey: 'test', model: 'claude-sonnet-4-20250514' });
15
+ const mockResponse = JSON.stringify({
16
+ sprint: { name: 'Todo API MVP', goal: 'Working REST API' },
17
+ tasks: [
18
+ { title: 'Design API schema', assignee: 'aria', priority: 1, required_skills: ['ag-api-design'], depends_on: [] },
19
+ { title: 'Implement endpoints', assignee: 'dex', priority: 2, required_skills: ['sp-tdd-cycle'], depends_on: ['task-0'] },
20
+ ]
21
+ });
22
+ const result = brain.parseDecomposition(mockResponse);
23
+ (0, vitest_1.expect)(result.sprint.name).toBe('Todo API MVP');
24
+ (0, vitest_1.expect)(result.tasks.length).toBe(2);
25
+ (0, vitest_1.expect)(result.tasks[1].depends_on).toEqual(['task-0']);
26
+ });
27
+ (0, vitest_1.it)('should handle malformed JSON gracefully', () => {
28
+ const brain = new ceo_brain_1.CEOBrain({ apiKey: 'test', model: 'claude-sonnet-4-20250514' });
29
+ (0, vitest_1.expect)(() => brain.parseDecomposition('not json at all')).toThrow();
30
+ });
31
+ (0, vitest_1.it)('should extract JSON from markdown-wrapped response', () => {
32
+ const brain = new ceo_brain_1.CEOBrain({ apiKey: 'test', model: 'claude-sonnet-4-20250514' });
33
+ const wrappedResponse = `Here's the plan:
34
+ \`\`\`json
35
+ {
36
+ "sprint": { "name": "Sprint 1", "goal": "Build it" },
37
+ "tasks": [{ "title": "Do stuff", "assignee": "dex", "priority": 1, "required_skills": [], "depends_on": [] }]
38
+ }
39
+ \`\`\``;
40
+ const result = brain.parseDecomposition(wrappedResponse);
41
+ (0, vitest_1.expect)(result.sprint.name).toBe('Sprint 1');
42
+ (0, vitest_1.expect)(result.tasks.length).toBe(1);
43
+ });
44
+ (0, vitest_1.it)('should include all agent roster in prompt', () => {
45
+ const brain = new ceo_brain_1.CEOBrain({ apiKey: 'test', model: 'claude-sonnet-4-20250514' });
46
+ const prompt = brain.buildDecompositionPrompt('Build something', [
47
+ { id: 'dex', name: 'Dex', role: 'dev-senior', skills: ['sp-tdd-cycle'] },
48
+ { id: 'flux', name: 'Flux', role: 'dev-fullstack', skills: ['ag-react-patterns'] },
49
+ { id: 'quinn', name: 'Quinn', role: 'qa-lead', skills: ['ag-testing-patterns'] },
50
+ ]);
51
+ (0, vitest_1.expect)(prompt).toContain('Dex');
52
+ (0, vitest_1.expect)(prompt).toContain('Flux');
53
+ (0, vitest_1.expect)(prompt).toContain('Quinn');
54
+ (0, vitest_1.expect)(prompt).toContain('JSON');
55
+ });
56
+ });
57
+ //# sourceMappingURL=ceo-brain.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ceo-brain.test.js","sourceRoot":"","sources":["../../../src/engine/__tests__/ceo-brain.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=dispatcher.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dispatcher.test.d.ts","sourceRoot":"","sources":["../../../src/engine/__tests__/dispatcher.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const vitest_1 = require("vitest");
4
+ const dispatcher_1 = require("../dispatcher");
5
+ (0, vitest_1.describe)('Dispatcher', () => {
6
+ (0, vitest_1.it)('should not exceed max concurrent processes', () => {
7
+ const dispatcher = new dispatcher_1.Dispatcher({ maxConcurrent: 2 });
8
+ (0, vitest_1.expect)(dispatcher.availableSlots()).toBe(2);
9
+ });
10
+ (0, vitest_1.it)('should build correct Claude Code command', () => {
11
+ const dispatcher = new dispatcher_1.Dispatcher({ maxConcurrent: 3 });
12
+ const cmd = dispatcher.buildCommand({
13
+ systemPrompt: 'You are Dex...',
14
+ taskPrompt: 'Build auth middleware',
15
+ cwd: '/tmp/worktree-dex',
16
+ maxTurns: 50,
17
+ });
18
+ (0, vitest_1.expect)(cmd.command).toBe('claude');
19
+ (0, vitest_1.expect)(cmd.args).toContain('--print');
20
+ (0, vitest_1.expect)(cmd.args).toContain('--output-format');
21
+ (0, vitest_1.expect)(cmd.args).toContain('stream-json');
22
+ (0, vitest_1.expect)(cmd.args).toContain('--permission-mode');
23
+ (0, vitest_1.expect)(cmd.args).toContain('bypassPermissions');
24
+ (0, vitest_1.expect)(cmd.args).toContain('--max-turns');
25
+ (0, vitest_1.expect)(cmd.args).toContain('50');
26
+ // Task prompt is positional (last arg)
27
+ (0, vitest_1.expect)(cmd.args[cmd.args.length - 1]).toBe('Build auth middleware');
28
+ });
29
+ (0, vitest_1.it)('should parse stream-json events from stdout', () => {
30
+ const dispatcher = new dispatcher_1.Dispatcher({ maxConcurrent: 3 });
31
+ const toolUse = '{"type":"tool_use","tool":"Edit","input":{"file":"auth.ts"}}';
32
+ const event1 = dispatcher.parseStreamEvent(toolUse);
33
+ (0, vitest_1.expect)(event1?.type).toBe('tool_use');
34
+ (0, vitest_1.expect)(event1?.tool).toBe('Edit');
35
+ const result = '{"type":"result","cost_usd":0.042,"duration_ms":12000,"turns":5}';
36
+ const event2 = dispatcher.parseStreamEvent(result);
37
+ (0, vitest_1.expect)(event2?.type).toBe('result');
38
+ (0, vitest_1.expect)(event2?.cost_usd).toBe(0.042);
39
+ });
40
+ (0, vitest_1.it)('should handle invalid JSON lines gracefully', () => {
41
+ const dispatcher = new dispatcher_1.Dispatcher({ maxConcurrent: 3 });
42
+ const event = dispatcher.parseStreamEvent('not json at all');
43
+ (0, vitest_1.expect)(event).toBeNull();
44
+ });
45
+ (0, vitest_1.it)('should map tool_use events to agent status', () => {
46
+ const dispatcher = new dispatcher_1.Dispatcher({ maxConcurrent: 3 });
47
+ (0, vitest_1.expect)(dispatcher.toolToStatus('Edit')).toBe('coding');
48
+ (0, vitest_1.expect)(dispatcher.toolToStatus('Write')).toBe('coding');
49
+ (0, vitest_1.expect)(dispatcher.toolToStatus('Bash')).toBe('testing');
50
+ (0, vitest_1.expect)(dispatcher.toolToStatus('Read')).toBe('reviewing');
51
+ (0, vitest_1.expect)(dispatcher.toolToStatus('Grep')).toBe('reviewing');
52
+ (0, vitest_1.expect)(dispatcher.toolToStatus('Glob')).toBe('reviewing');
53
+ });
54
+ (0, vitest_1.it)('should track running processes count', () => {
55
+ const dispatcher = new dispatcher_1.Dispatcher({ maxConcurrent: 3 });
56
+ (0, vitest_1.expect)(dispatcher.runningCount()).toBe(0);
57
+ (0, vitest_1.expect)(dispatcher.availableSlots()).toBe(3);
58
+ });
59
+ });
60
+ //# sourceMappingURL=dispatcher.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dispatcher.test.js","sourceRoot":"","sources":["../../../src/engine/__tests__/dispatcher.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=orchestrator.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"orchestrator.test.d.ts","sourceRoot":"","sources":["../../../src/engine/__tests__/orchestrator.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,83 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const vitest_1 = require("vitest");
7
+ const orchestrator_1 = require("../orchestrator");
8
+ const database_1 = require("../../state/database");
9
+ const fs_1 = __importDefault(require("fs"));
10
+ (0, vitest_1.describe)('Orchestrator', () => {
11
+ let db;
12
+ let orchestrator;
13
+ const testDbPath = '.sage-team/test-orchestrator.db';
14
+ (0, vitest_1.beforeEach)(() => {
15
+ db = new database_1.Database(testDbPath);
16
+ orchestrator = new orchestrator_1.Orchestrator(db, {
17
+ apiKey: 'test',
18
+ model: 'claude-sonnet-4-20250514',
19
+ maxConcurrentAgents: 3,
20
+ autonomyMode: 'sandbox',
21
+ companyName: 'Test Co',
22
+ mission: 'Build great software',
23
+ });
24
+ });
25
+ (0, vitest_1.afterEach)(() => {
26
+ orchestrator.stop();
27
+ db.close();
28
+ if (fs_1.default.existsSync(testDbPath))
29
+ fs_1.default.unlinkSync(testDbPath);
30
+ if (fs_1.default.existsSync(testDbPath + '-wal'))
31
+ fs_1.default.unlinkSync(testDbPath + '-wal');
32
+ if (fs_1.default.existsSync(testDbPath + '-shm'))
33
+ fs_1.default.unlinkSync(testDbPath + '-shm');
34
+ });
35
+ (0, vitest_1.it)('should create a session on start', () => {
36
+ const session = orchestrator.start();
37
+ (0, vitest_1.expect)(session.status).toBe('active');
38
+ (0, vitest_1.expect)(session.id).toBeTruthy();
39
+ });
40
+ (0, vitest_1.it)('should initialize all 11 agents on start', () => {
41
+ const session = orchestrator.start();
42
+ const agents = orchestrator.getAgents();
43
+ (0, vitest_1.expect)(agents.length).toBe(11);
44
+ });
45
+ (0, vitest_1.it)('should emit events on state changes', () => {
46
+ const events = [];
47
+ orchestrator.on('event', (e) => events.push(e));
48
+ orchestrator.start();
49
+ (0, vitest_1.expect)(events.length).toBeGreaterThan(0);
50
+ (0, vitest_1.expect)(events[0].type).toBe('system');
51
+ });
52
+ (0, vitest_1.it)('should track session ID', () => {
53
+ const session = orchestrator.start();
54
+ (0, vitest_1.expect)(orchestrator.sessionId).toBe(session.id);
55
+ });
56
+ (0, vitest_1.it)('should find no available tasks initially', () => {
57
+ orchestrator.start();
58
+ const available = orchestrator.getAvailableTasks(5);
59
+ (0, vitest_1.expect)(available.length).toBe(0);
60
+ });
61
+ (0, vitest_1.it)('should resume an existing session', () => {
62
+ const session = orchestrator.start();
63
+ const sessionId = session.id;
64
+ // Create a new orchestrator and resume
65
+ const db2 = new database_1.Database(testDbPath);
66
+ const orch2 = new orchestrator_1.Orchestrator(db2, {
67
+ apiKey: 'test',
68
+ model: 'claude-sonnet-4-20250514',
69
+ maxConcurrentAgents: 3,
70
+ autonomyMode: 'sandbox',
71
+ companyName: 'Test Co',
72
+ mission: 'Build great software',
73
+ });
74
+ const resumed = orch2.resume(sessionId);
75
+ (0, vitest_1.expect)(resumed).toBe(true);
76
+ (0, vitest_1.expect)(orch2.sessionId).toBe(sessionId);
77
+ const agents = orch2.getAgents();
78
+ (0, vitest_1.expect)(agents.length).toBe(11);
79
+ orch2.stop();
80
+ db2.close();
81
+ });
82
+ });
83
+ //# sourceMappingURL=orchestrator.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"orchestrator.test.js","sourceRoot":"","sources":["../../../src/engine/__tests__/orchestrator.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=pr-manager.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pr-manager.test.d.ts","sourceRoot":"","sources":["../../../src/engine/__tests__/pr-manager.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const vitest_1 = require("vitest");
4
+ const pr_manager_1 = require("../pr-manager");
5
+ (0, vitest_1.describe)('PRManager', () => {
6
+ (0, vitest_1.it)('should generate correct branch name', () => {
7
+ const pm = new pr_manager_1.PRManager();
8
+ (0, vitest_1.expect)(pm.branchName('dex', 'build-auth-middleware')).toBe('sage/dex/build-auth-middleware');
9
+ (0, vitest_1.expect)(pm.branchName('flux', 'add-ui-components')).toBe('sage/flux/add-ui-components');
10
+ });
11
+ (0, vitest_1.it)('should generate slug from task title', () => {
12
+ const pm = new pr_manager_1.PRManager();
13
+ (0, vitest_1.expect)(pm.slugify('Build Auth Middleware')).toBe('build-auth-middleware');
14
+ (0, vitest_1.expect)(pm.slugify('Implement JWT (v2)')).toBe('implement-jwt-v2');
15
+ (0, vitest_1.expect)(pm.slugify('Fix bug #123 — urgent!')).toBe('fix-bug-123-urgent');
16
+ });
17
+ (0, vitest_1.it)('should build worktree add command', () => {
18
+ const pm = new pr_manager_1.PRManager();
19
+ const cmd = pm.buildWorktreeAddCommand('dex', 'task-abc', 'build-auth');
20
+ (0, vitest_1.expect)(cmd).toContain('git worktree add');
21
+ (0, vitest_1.expect)(cmd).toContain('.sage-team/worktrees/dex-task-abc');
22
+ (0, vitest_1.expect)(cmd).toContain('sage/dex/build-auth');
23
+ });
24
+ (0, vitest_1.it)('should build worktree path', () => {
25
+ const pm = new pr_manager_1.PRManager();
26
+ (0, vitest_1.expect)(pm.worktreePath('dex', 'task-abc')).toBe('.sage-team/worktrees/dex-task-abc');
27
+ });
28
+ (0, vitest_1.it)('should build merge command', () => {
29
+ const pm = new pr_manager_1.PRManager();
30
+ const cmds = pm.buildMergeCommands('sage/dex/build-auth', '[sage:ceo] feat: add auth middleware');
31
+ (0, vitest_1.expect)(cmds.length).toBe(2);
32
+ (0, vitest_1.expect)(cmds[0]).toContain('git merge --squash');
33
+ (0, vitest_1.expect)(cmds[1]).toContain('git commit');
34
+ (0, vitest_1.expect)(cmds[1]).toContain('[sage:ceo]');
35
+ });
36
+ (0, vitest_1.it)('should build cleanup commands', () => {
37
+ const pm = new pr_manager_1.PRManager();
38
+ const cmds = pm.buildCleanupCommands('.sage-team/worktrees/dex-task-abc', 'sage/dex/build-auth');
39
+ (0, vitest_1.expect)(cmds.length).toBe(2);
40
+ (0, vitest_1.expect)(cmds[0]).toContain('git worktree remove');
41
+ (0, vitest_1.expect)(cmds[1]).toContain('git branch -d');
42
+ });
43
+ });
44
+ //# sourceMappingURL=pr-manager.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pr-manager.test.js","sourceRoot":"","sources":["../../../src/engine/__tests__/pr-manager.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=prompt-builder.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompt-builder.test.d.ts","sourceRoot":"","sources":["../../../src/engine/__tests__/prompt-builder.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const vitest_1 = require("vitest");
4
+ const prompt_builder_1 = require("../prompt-builder");
5
+ (0, vitest_1.describe)('PromptBuilder', () => {
6
+ const builder = new prompt_builder_1.PromptBuilder();
7
+ (0, vitest_1.it)('should build a system prompt with identity section', () => {
8
+ const prompt = builder.build({
9
+ agent: { id: 'dex', name: 'Dex', role: 'dev-senior', description: 'Senior TypeScript developer' },
10
+ company: { name: 'Test Co', mission: 'Build great software' },
11
+ skills: ['## TDD\nWrite test first.\n'],
12
+ task: { title: 'Build auth', description: 'JWT middleware', requiredSkills: ['sp-tdd-cycle'] },
13
+ });
14
+ (0, vitest_1.expect)(prompt).toContain('You are Dex');
15
+ (0, vitest_1.expect)(prompt).toContain('dev-senior');
16
+ (0, vitest_1.expect)(prompt).toContain('TDD');
17
+ (0, vitest_1.expect)(prompt).toContain('Build auth');
18
+ (0, vitest_1.expect)(prompt).toContain('[sage:dex]');
19
+ });
20
+ (0, vitest_1.it)('should stay within token budget', () => {
21
+ const prompt = builder.build({
22
+ agent: { id: 'dex', name: 'Dex', role: 'dev-senior', description: 'Test' },
23
+ company: { name: 'Co', mission: 'Test' },
24
+ skills: ['x'.repeat(200000)], // Huge skill
25
+ task: { title: 'Test', description: 'Test', requiredSkills: [] },
26
+ });
27
+ // Prompt should be truncated to ~30k tokens (~120k chars)
28
+ (0, vitest_1.expect)(prompt.length).toBeLessThan(130000);
29
+ });
30
+ (0, vitest_1.it)('should include rules section', () => {
31
+ const prompt = builder.build({
32
+ agent: { id: 'flux', name: 'Flux', role: 'dev-fullstack', description: 'Fullstack dev' },
33
+ company: { name: 'Co', mission: 'Test' },
34
+ skills: [],
35
+ task: { title: 'Build UI', description: 'React components', requiredSkills: [] },
36
+ });
37
+ (0, vitest_1.expect)(prompt).toContain('Work ONLY on the assigned task');
38
+ (0, vitest_1.expect)(prompt).toContain('[sage:flux]');
39
+ (0, vitest_1.expect)(prompt).toContain('Do NOT push');
40
+ });
41
+ });
42
+ //# sourceMappingURL=prompt-builder.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompt-builder.test.js","sourceRoot":"","sources":["../../../src/engine/__tests__/prompt-builder.test.ts"],"names":[],"mappings":";;AAAA,mCAA8C;AAC9C,sDAAkD;AAElD,IAAA,iBAAQ,EAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,MAAM,OAAO,GAAG,IAAI,8BAAa,EAAE,CAAC;IAEpC,IAAA,WAAE,EAAC,oDAAoD,EAAE,GAAG,EAAE;QAC5D,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC;YAC3B,KAAK,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,WAAW,EAAE,6BAA6B,EAAE;YACjG,OAAO,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,sBAAsB,EAAE;YAC7D,MAAM,EAAE,CAAC,6BAA6B,CAAC;YACvC,IAAI,EAAE,EAAE,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,gBAAgB,EAAE,cAAc,EAAE,CAAC,cAAc,CAAC,EAAE;SAC/F,CAAC,CAAC;QACH,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QACxC,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QACvC,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAChC,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QACvC,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC;YAC3B,KAAK,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,EAAE;YAC1E,OAAO,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE;YACxC,MAAM,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,aAAa;YAC3C,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,cAAc,EAAE,EAAE,EAAE;SACjE,CAAC,CAAC;QACH,0DAA0D;QAC1D,IAAA,eAAM,EAAC,MAAM,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC;YAC3B,KAAK,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,eAAe,EAAE,WAAW,EAAE,eAAe,EAAE;YACxF,OAAO,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE;YACxC,MAAM,EAAE,EAAE;YACV,IAAI,EAAE,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,kBAAkB,EAAE,cAAc,EAAE,EAAE,EAAE;SACjF,CAAC,CAAC;QACH,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,SAAS,CAAC,gCAAgC,CAAC,CAAC;QAC3D,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QACxC,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,33 @@
1
+ export interface CEOBrainConfig {
2
+ apiKey: string;
3
+ model: string;
4
+ }
5
+ export interface AgentRoster {
6
+ id: string;
7
+ name: string;
8
+ role: string;
9
+ skills: string[];
10
+ }
11
+ export interface DecompositionResult {
12
+ sprint: {
13
+ name: string;
14
+ goal: string;
15
+ };
16
+ tasks: {
17
+ title: string;
18
+ assignee: string;
19
+ priority: number;
20
+ required_skills: string[];
21
+ depends_on: string[];
22
+ description?: string;
23
+ }[];
24
+ }
25
+ export declare class CEOBrain {
26
+ private config;
27
+ private client;
28
+ constructor(config: CEOBrainConfig);
29
+ buildDecompositionPrompt(goal: string, roster: AgentRoster[]): string;
30
+ parseDecomposition(response: string): DecompositionResult;
31
+ decompose(goal: string, roster: AgentRoster[]): Promise<DecompositionResult>;
32
+ }
33
+ //# sourceMappingURL=ceo-brain.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ceo-brain.d.ts","sourceRoot":"","sources":["../../src/engine/ceo-brain.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,WAAW;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB;AAED,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;IACvC,KAAK,EAAE;QACL,KAAK,EAAE,MAAM,CAAC;QACd,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,CAAC;QACjB,eAAe,EAAE,MAAM,EAAE,CAAC;QAC1B,UAAU,EAAE,MAAM,EAAE,CAAC;QACrB,WAAW,CAAC,EAAE,MAAM,CAAC;KACtB,EAAE,CAAC;CACL;AAED,qBAAa,QAAQ;IACnB,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,MAAM,CAA0B;gBAE5B,MAAM,EAAE,cAAc;IAOlC,wBAAwB,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,MAAM;IAwCrE,kBAAkB,CAAC,QAAQ,EAAE,MAAM,GAAG,mBAAmB;IA2BnD,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,OAAO,CAAC,mBAAmB,CAAC;CAoBnF"}
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.CEOBrain = void 0;
7
+ const sdk_1 = __importDefault(require("@anthropic-ai/sdk"));
8
+ class CEOBrain {
9
+ config;
10
+ client = null;
11
+ constructor(config) {
12
+ this.config = config;
13
+ if (config.apiKey && config.apiKey !== 'test') {
14
+ this.client = new sdk_1.default({ apiKey: config.apiKey });
15
+ }
16
+ }
17
+ buildDecompositionPrompt(goal, roster) {
18
+ const agentList = roster.map(a => `- **${a.name}** (${a.id}): ${a.role} — skills: ${a.skills.join(', ')}`).join('\n');
19
+ return `You are Sage, CEO of an AI software company. Decompose this goal into a sprint with concrete tasks.
20
+
21
+ ## Goal
22
+ ${goal}
23
+
24
+ ## Available Team
25
+ ${agentList}
26
+
27
+ ## Rules
28
+ - Each task must be assignable to exactly ONE agent
29
+ - Tasks should be 2-5 minutes of focused work each
30
+ - Use depends_on to express task dependencies (reference by index: "task-0", "task-1", etc.)
31
+ - Assign required_skills using the agent's skill IDs (sp- or ag- prefix)
32
+ - Priority: 1=critical, 2=high, 3=medium, 4=low, 5=nice-to-have
33
+ - Order tasks by dependency chain: independent tasks first
34
+ - Include description with enough context for the agent to work autonomously
35
+
36
+ ## Response Format
37
+ Respond with ONLY valid JSON (no markdown, no explanation):
38
+
39
+ {
40
+ "sprint": { "name": "Sprint Name", "goal": "Sprint goal" },
41
+ "tasks": [
42
+ {
43
+ "title": "Task title",
44
+ "description": "Detailed description",
45
+ "assignee": "agent-id",
46
+ "priority": 1,
47
+ "required_skills": ["sp-tdd-cycle"],
48
+ "depends_on": []
49
+ }
50
+ ]
51
+ }`;
52
+ }
53
+ parseDecomposition(response) {
54
+ // Try to extract JSON from markdown code blocks
55
+ const jsonMatch = response.match(/```(?:json)?\s*\n?([\s\S]*?)\n?\s*```/);
56
+ const jsonStr = jsonMatch ? jsonMatch[1].trim() : response.trim();
57
+ const parsed = JSON.parse(jsonStr);
58
+ if (!parsed.sprint || !parsed.tasks || !Array.isArray(parsed.tasks)) {
59
+ throw new Error('Invalid decomposition: missing sprint or tasks');
60
+ }
61
+ return {
62
+ sprint: {
63
+ name: parsed.sprint.name,
64
+ goal: parsed.sprint.goal,
65
+ },
66
+ tasks: parsed.tasks.map((t) => ({
67
+ title: t.title,
68
+ description: t.description || '',
69
+ assignee: t.assignee,
70
+ priority: t.priority || 3,
71
+ required_skills: t.required_skills || [],
72
+ depends_on: t.depends_on || [],
73
+ })),
74
+ };
75
+ }
76
+ async decompose(goal, roster) {
77
+ if (!this.client) {
78
+ throw new Error('CEO Brain not initialized: no API key');
79
+ }
80
+ const prompt = this.buildDecompositionPrompt(goal, roster);
81
+ const response = await this.client.messages.create({
82
+ model: this.config.model,
83
+ max_tokens: 4096,
84
+ messages: [{ role: 'user', content: prompt }],
85
+ });
86
+ const text = response.content
87
+ .filter(block => block.type === 'text')
88
+ .map(block => block.text)
89
+ .join('');
90
+ return this.parseDecomposition(text);
91
+ }
92
+ }
93
+ exports.CEOBrain = CEOBrain;
94
+ //# sourceMappingURL=ceo-brain.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ceo-brain.js","sourceRoot":"","sources":["../../src/engine/ceo-brain.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,40 @@
1
+ import { ChildProcess } from 'child_process';
2
+ import { EventEmitter } from 'events';
3
+ export interface DispatcherConfig {
4
+ maxConcurrent: number;
5
+ }
6
+ export interface SpawnCommandInput {
7
+ systemPrompt: string;
8
+ taskPrompt: string;
9
+ cwd: string;
10
+ maxTurns: number;
11
+ }
12
+ export interface SpawnCommand {
13
+ command: string;
14
+ args: string[];
15
+ cwd: string;
16
+ }
17
+ export interface StreamEvent {
18
+ type: string;
19
+ [key: string]: unknown;
20
+ }
21
+ export interface RunningProcess {
22
+ agentId: string;
23
+ taskId: string;
24
+ process: ChildProcess;
25
+ startedAt: number;
26
+ }
27
+ export declare class Dispatcher extends EventEmitter {
28
+ private config;
29
+ private running;
30
+ constructor(config: DispatcherConfig);
31
+ availableSlots(): number;
32
+ runningCount(): number;
33
+ buildCommand(input: SpawnCommandInput): SpawnCommand;
34
+ parseStreamEvent(line: string): StreamEvent | null;
35
+ toolToStatus(toolName: string): string;
36
+ spawnAgent(agentId: string, taskId: string, systemPrompt: string, taskPrompt: string, cwd: string, maxTurns?: number): Promise<void>;
37
+ killAgent(taskId: string): boolean;
38
+ killAll(): void;
39
+ }
40
+ //# sourceMappingURL=dispatcher.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dispatcher.d.ts","sourceRoot":"","sources":["../../src/engine/dispatcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAS,YAAY,EAAE,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,MAAM,WAAW,gBAAgB;IAC/B,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,iBAAiB;IAChC,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;CACb;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,YAAY,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;CACnB;AAYD,qBAAa,UAAW,SAAQ,YAAY;IAC1C,OAAO,CAAC,MAAM,CAAmB;IACjC,OAAO,CAAC,OAAO,CAA0C;gBAE7C,MAAM,EAAE,gBAAgB;IAKpC,cAAc,IAAI,MAAM;IAIxB,YAAY,IAAI,MAAM;IAItB,YAAY,CAAC,KAAK,EAAE,iBAAiB,GAAG,YAAY;IAiBpD,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI;IAQlD,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM;IAIhC,UAAU,CACd,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,MAAM,EACd,YAAY,EAAE,MAAM,EACpB,UAAU,EAAE,MAAM,EAClB,GAAG,EAAE,MAAM,EACX,QAAQ,GAAE,MAAW,GACpB,OAAO,CAAC,IAAI,CAAC;IAgEhB,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAQlC,OAAO,IAAI,IAAI;CAMhB"}