@vibescope/mcp-server 0.5.0 → 0.5.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +84 -84
- package/README.md +194 -194
- package/dist/api-client/tasks.d.ts +1 -0
- package/dist/cli-init.js +21 -21
- package/dist/cli.js +26 -26
- package/dist/handlers/tasks.js +7 -1
- package/dist/handlers/tool-docs.js +1216 -1216
- package/dist/index.js +73 -73
- package/dist/templates/agent-guidelines.d.ts +1 -1
- package/dist/templates/agent-guidelines.js +205 -205
- package/dist/templates/help-content.js +1621 -1621
- package/dist/tools/bodies-of-work.js +6 -6
- package/dist/tools/cloud-agents.js +22 -22
- package/dist/tools/milestones.js +2 -2
- package/dist/tools/requests.js +1 -1
- package/dist/tools/session.js +11 -11
- package/dist/tools/sprints.js +9 -9
- package/dist/tools/tasks.js +43 -35
- package/dist/tools/worktrees.js +14 -14
- package/dist/utils.js +11 -11
- package/docs/TOOLS.md +2687 -2685
- package/package.json +53 -53
- package/scripts/generate-docs.ts +212 -212
- package/scripts/version-bump.ts +203 -203
- package/src/api-client/blockers.ts +86 -86
- package/src/api-client/bodies-of-work.ts +194 -194
- package/src/api-client/chat.ts +50 -50
- package/src/api-client/connectors.ts +152 -152
- package/src/api-client/cost.ts +185 -185
- package/src/api-client/decisions.ts +87 -87
- package/src/api-client/deployment.ts +313 -313
- package/src/api-client/discovery.ts +81 -81
- package/src/api-client/fallback.ts +52 -52
- package/src/api-client/file-checkouts.ts +115 -115
- package/src/api-client/findings.ts +100 -100
- package/src/api-client/git-issues.ts +88 -88
- package/src/api-client/ideas.ts +112 -112
- package/src/api-client/index.ts +592 -592
- package/src/api-client/milestones.ts +83 -83
- package/src/api-client/organizations.ts +185 -185
- package/src/api-client/progress.ts +94 -94
- package/src/api-client/project.ts +181 -181
- package/src/api-client/requests.ts +54 -54
- package/src/api-client/session.ts +220 -220
- package/src/api-client/sprints.ts +227 -227
- package/src/api-client/subtasks.ts +57 -57
- package/src/api-client/tasks.ts +451 -450
- package/src/api-client/types.ts +32 -32
- package/src/api-client/validation.ts +60 -60
- package/src/api-client/worktrees.ts +53 -53
- package/src/api-client.test.ts +847 -847
- package/src/api-client.ts +2728 -2728
- package/src/cli-init.ts +558 -558
- package/src/cli.test.ts +284 -284
- package/src/cli.ts +204 -204
- package/src/handlers/__test-setup__.ts +240 -240
- package/src/handlers/__test-utils__.ts +89 -89
- package/src/handlers/blockers.test.ts +468 -468
- package/src/handlers/blockers.ts +172 -172
- package/src/handlers/bodies-of-work.test.ts +704 -704
- package/src/handlers/bodies-of-work.ts +526 -526
- package/src/handlers/chat.test.ts +185 -185
- package/src/handlers/chat.ts +101 -101
- package/src/handlers/cloud-agents.test.ts +438 -438
- package/src/handlers/cloud-agents.ts +156 -156
- package/src/handlers/connectors.test.ts +834 -834
- package/src/handlers/connectors.ts +229 -229
- package/src/handlers/cost.test.ts +462 -462
- package/src/handlers/cost.ts +285 -285
- package/src/handlers/decisions.test.ts +382 -382
- package/src/handlers/decisions.ts +153 -153
- package/src/handlers/deployment.test.ts +551 -551
- package/src/handlers/deployment.ts +570 -570
- package/src/handlers/discovery.test.ts +206 -206
- package/src/handlers/discovery.ts +433 -433
- package/src/handlers/fallback.test.ts +537 -537
- package/src/handlers/fallback.ts +194 -194
- package/src/handlers/file-checkouts.test.ts +750 -750
- package/src/handlers/file-checkouts.ts +185 -185
- package/src/handlers/findings.test.ts +633 -633
- package/src/handlers/findings.ts +239 -239
- package/src/handlers/git-issues.test.ts +631 -631
- package/src/handlers/git-issues.ts +136 -136
- package/src/handlers/ideas.test.ts +644 -644
- package/src/handlers/ideas.ts +207 -207
- package/src/handlers/index.ts +93 -93
- package/src/handlers/milestones.test.ts +475 -475
- package/src/handlers/milestones.ts +180 -180
- package/src/handlers/organizations.test.ts +826 -826
- package/src/handlers/organizations.ts +315 -315
- package/src/handlers/progress.test.ts +269 -269
- package/src/handlers/progress.ts +77 -77
- package/src/handlers/project.test.ts +546 -546
- package/src/handlers/project.ts +245 -245
- package/src/handlers/requests.test.ts +303 -303
- package/src/handlers/requests.ts +99 -99
- package/src/handlers/roles.test.ts +305 -305
- package/src/handlers/roles.ts +219 -219
- package/src/handlers/session.test.ts +998 -998
- package/src/handlers/session.ts +1105 -1105
- package/src/handlers/sprints.test.ts +732 -732
- package/src/handlers/sprints.ts +537 -537
- package/src/handlers/tasks.test.ts +931 -931
- package/src/handlers/tasks.ts +1144 -1137
- package/src/handlers/tool-categories.test.ts +66 -66
- package/src/handlers/tool-docs.test.ts +511 -511
- package/src/handlers/tool-docs.ts +1595 -1595
- package/src/handlers/types.test.ts +259 -259
- package/src/handlers/types.ts +176 -176
- package/src/handlers/validation.test.ts +582 -582
- package/src/handlers/validation.ts +164 -164
- package/src/handlers/version.ts +63 -63
- package/src/index.test.ts +674 -674
- package/src/index.ts +884 -884
- package/src/setup.test.ts +243 -243
- package/src/setup.ts +410 -410
- package/src/templates/agent-guidelines.ts +233 -233
- package/src/templates/help-content.ts +1751 -1751
- package/src/token-tracking.test.ts +463 -463
- package/src/token-tracking.ts +167 -167
- package/src/tools/blockers.ts +122 -122
- package/src/tools/bodies-of-work.ts +283 -283
- package/src/tools/chat.ts +72 -72
- package/src/tools/cloud-agents.ts +101 -101
- package/src/tools/connectors.ts +191 -191
- package/src/tools/cost.ts +111 -111
- package/src/tools/decisions.ts +111 -111
- package/src/tools/deployment.ts +455 -455
- package/src/tools/discovery.ts +76 -76
- package/src/tools/fallback.ts +111 -111
- package/src/tools/features.ts +154 -154
- package/src/tools/file-checkouts.ts +145 -145
- package/src/tools/findings.ts +101 -101
- package/src/tools/git-issues.ts +130 -130
- package/src/tools/ideas.ts +162 -162
- package/src/tools/index.ts +145 -145
- package/src/tools/milestones.ts +118 -118
- package/src/tools/organizations.ts +224 -224
- package/src/tools/persona-templates.ts +25 -25
- package/src/tools/progress.ts +73 -73
- package/src/tools/project.ts +210 -210
- package/src/tools/requests.ts +68 -68
- package/src/tools/roles.ts +112 -112
- package/src/tools/session.ts +181 -181
- package/src/tools/sprints.ts +298 -298
- package/src/tools/tasks.ts +583 -575
- package/src/tools/tools.test.ts +222 -222
- package/src/tools/types.ts +9 -9
- package/src/tools/validation.ts +75 -75
- package/src/tools/version.ts +34 -34
- package/src/tools/worktrees.ts +66 -66
- package/src/tools.test.ts +416 -416
- package/src/utils.test.ts +1014 -1014
- package/src/utils.ts +586 -586
- package/src/validators.test.ts +223 -223
- package/src/validators.ts +249 -249
- package/src/version.ts +162 -162
- package/tsconfig.json +16 -16
- package/vitest.config.ts +14 -14
- package/dist/tools.d.ts +0 -2
- package/dist/tools.js +0 -3602
package/src/tools/tools.test.ts
CHANGED
|
@@ -1,222 +1,222 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Tests for split tool definitions
|
|
3
|
-
*
|
|
4
|
-
* Validates that domain-specific tool files:
|
|
5
|
-
* - Export valid Tool arrays
|
|
6
|
-
* - Have unique tool names
|
|
7
|
-
* - Have required inputSchema properties
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import { describe, it, expect } from 'vitest';
|
|
11
|
-
import { sessionTools } from './session.js';
|
|
12
|
-
import { costTools } from './cost.js';
|
|
13
|
-
import { discoveryTools } from './discovery.js';
|
|
14
|
-
import { worktreeTools } from './worktrees.js';
|
|
15
|
-
import { projectTools } from './project.js';
|
|
16
|
-
import { blockerTools } from './blockers.js';
|
|
17
|
-
import { decisionTools } from './decisions.js';
|
|
18
|
-
import { ideaTools } from './ideas.js';
|
|
19
|
-
import { buildToolList, toolCategories } from './index.js';
|
|
20
|
-
|
|
21
|
-
describe('Split Tool Definitions', () => {
|
|
22
|
-
describe('sessionTools', () => {
|
|
23
|
-
it('should export an array of tools', () => {
|
|
24
|
-
expect(Array.isArray(sessionTools)).toBe(true);
|
|
25
|
-
expect(sessionTools.length).toBeGreaterThan(0);
|
|
26
|
-
});
|
|
27
|
-
|
|
28
|
-
it('should include expected session tools', () => {
|
|
29
|
-
const toolNames = sessionTools.map(t => t.name);
|
|
30
|
-
expect(toolNames).toContain('start_work_session');
|
|
31
|
-
expect(toolNames).toContain('heartbeat');
|
|
32
|
-
expect(toolNames).toContain('end_work_session');
|
|
33
|
-
expect(toolNames).toContain('signal_idle');
|
|
34
|
-
expect(toolNames).toContain('get_token_usage');
|
|
35
|
-
expect(toolNames).toContain('report_token_usage');
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
it('should have valid inputSchema for all tools', () => {
|
|
39
|
-
for (const tool of sessionTools) {
|
|
40
|
-
expect(tool.inputSchema).toBeDefined();
|
|
41
|
-
expect(tool.inputSchema.type).toBe('object');
|
|
42
|
-
expect(tool.inputSchema.properties).toBeDefined();
|
|
43
|
-
}
|
|
44
|
-
});
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
describe('costTools', () => {
|
|
48
|
-
it('should export an array of tools', () => {
|
|
49
|
-
expect(Array.isArray(costTools)).toBe(true);
|
|
50
|
-
expect(costTools.length).toBeGreaterThan(0);
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
it('should include expected cost tools', () => {
|
|
54
|
-
const toolNames = costTools.map(t => t.name);
|
|
55
|
-
expect(toolNames).toContain('get_cost_summary');
|
|
56
|
-
expect(toolNames).toContain('add_cost_alert');
|
|
57
|
-
expect(toolNames).toContain('update_cost_alert');
|
|
58
|
-
expect(toolNames).toContain('delete_cost_alert');
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
describe('discoveryTools', () => {
|
|
63
|
-
it('should export an array of tools', () => {
|
|
64
|
-
expect(Array.isArray(discoveryTools)).toBe(true);
|
|
65
|
-
expect(discoveryTools.length).toBeGreaterThan(0);
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
it('should include expected discovery tools', () => {
|
|
69
|
-
const toolNames = discoveryTools.map(t => t.name);
|
|
70
|
-
expect(toolNames).toContain('query_knowledge_base');
|
|
71
|
-
expect(toolNames).toContain('discover_tools');
|
|
72
|
-
expect(toolNames).toContain('get_tool_info');
|
|
73
|
-
});
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
describe('worktreeTools', () => {
|
|
77
|
-
it('should export an array of tools', () => {
|
|
78
|
-
expect(Array.isArray(worktreeTools)).toBe(true);
|
|
79
|
-
expect(worktreeTools.length).toBeGreaterThan(0);
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
it('should include expected worktree tools', () => {
|
|
83
|
-
const toolNames = worktreeTools.map(t => t.name);
|
|
84
|
-
expect(toolNames).toContain('get_stale_worktrees');
|
|
85
|
-
expect(toolNames).toContain('clear_worktree_path');
|
|
86
|
-
});
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
describe('projectTools', () => {
|
|
90
|
-
it('should export an array of tools', () => {
|
|
91
|
-
expect(Array.isArray(projectTools)).toBe(true);
|
|
92
|
-
expect(projectTools.length).toBeGreaterThan(0);
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
it('should include expected project tools', () => {
|
|
96
|
-
const toolNames = projectTools.map(t => t.name);
|
|
97
|
-
expect(toolNames).toContain('get_project_context');
|
|
98
|
-
expect(toolNames).toContain('create_project');
|
|
99
|
-
expect(toolNames).toContain('update_project');
|
|
100
|
-
expect(toolNames).toContain('get_project_summary');
|
|
101
|
-
});
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
describe('blockerTools', () => {
|
|
105
|
-
it('should export an array of tools', () => {
|
|
106
|
-
expect(Array.isArray(blockerTools)).toBe(true);
|
|
107
|
-
expect(blockerTools.length).toBeGreaterThan(0);
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
it('should include expected blocker tools', () => {
|
|
111
|
-
const toolNames = blockerTools.map(t => t.name);
|
|
112
|
-
expect(toolNames).toContain('add_blocker');
|
|
113
|
-
expect(toolNames).toContain('resolve_blocker');
|
|
114
|
-
expect(toolNames).toContain('get_blockers');
|
|
115
|
-
expect(toolNames).toContain('delete_blocker');
|
|
116
|
-
});
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
describe('decisionTools', () => {
|
|
120
|
-
it('should export an array of tools', () => {
|
|
121
|
-
expect(Array.isArray(decisionTools)).toBe(true);
|
|
122
|
-
expect(decisionTools.length).toBeGreaterThan(0);
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
it('should include expected decision tools', () => {
|
|
126
|
-
const toolNames = decisionTools.map(t => t.name);
|
|
127
|
-
expect(toolNames).toContain('log_decision');
|
|
128
|
-
expect(toolNames).toContain('get_decisions');
|
|
129
|
-
expect(toolNames).toContain('delete_decision');
|
|
130
|
-
});
|
|
131
|
-
});
|
|
132
|
-
|
|
133
|
-
describe('ideaTools', () => {
|
|
134
|
-
it('should export an array of tools', () => {
|
|
135
|
-
expect(Array.isArray(ideaTools)).toBe(true);
|
|
136
|
-
expect(ideaTools.length).toBeGreaterThan(0);
|
|
137
|
-
});
|
|
138
|
-
|
|
139
|
-
it('should include expected idea tools', () => {
|
|
140
|
-
const toolNames = ideaTools.map(t => t.name);
|
|
141
|
-
expect(toolNames).toContain('add_idea');
|
|
142
|
-
expect(toolNames).toContain('update_idea');
|
|
143
|
-
expect(toolNames).toContain('get_ideas');
|
|
144
|
-
expect(toolNames).toContain('convert_idea_to_task');
|
|
145
|
-
});
|
|
146
|
-
});
|
|
147
|
-
|
|
148
|
-
describe('buildToolList', () => {
|
|
149
|
-
it('should combine all domain tools', () => {
|
|
150
|
-
const allTools = buildToolList();
|
|
151
|
-
expect(Array.isArray(allTools)).toBe(true);
|
|
152
|
-
|
|
153
|
-
// Should include tools from all domains
|
|
154
|
-
const toolNames = allTools.map(t => t.name);
|
|
155
|
-
expect(toolNames).toContain('start_work_session');
|
|
156
|
-
expect(toolNames).toContain('get_cost_summary');
|
|
157
|
-
expect(toolNames).toContain('discover_tools');
|
|
158
|
-
expect(toolNames).toContain('get_stale_worktrees');
|
|
159
|
-
expect(toolNames).toContain('get_project_context');
|
|
160
|
-
expect(toolNames).toContain('add_blocker');
|
|
161
|
-
expect(toolNames).toContain('log_decision');
|
|
162
|
-
expect(toolNames).toContain('add_idea');
|
|
163
|
-
});
|
|
164
|
-
|
|
165
|
-
it('should have unique tool names', () => {
|
|
166
|
-
const allTools = buildToolList();
|
|
167
|
-
const toolNames = allTools.map(t => t.name);
|
|
168
|
-
const uniqueNames = new Set(toolNames);
|
|
169
|
-
expect(uniqueNames.size).toBe(toolNames.length);
|
|
170
|
-
});
|
|
171
|
-
});
|
|
172
|
-
|
|
173
|
-
describe('toolCategories', () => {
|
|
174
|
-
it('should have categories for all domains', () => {
|
|
175
|
-
expect(toolCategories.session).toBeDefined();
|
|
176
|
-
expect(toolCategories.cost).toBeDefined();
|
|
177
|
-
expect(toolCategories.discovery).toBeDefined();
|
|
178
|
-
expect(toolCategories.worktrees).toBeDefined();
|
|
179
|
-
expect(toolCategories.project).toBeDefined();
|
|
180
|
-
expect(toolCategories.blockers).toBeDefined();
|
|
181
|
-
expect(toolCategories.decisions).toBeDefined();
|
|
182
|
-
expect(toolCategories.ideas).toBeDefined();
|
|
183
|
-
});
|
|
184
|
-
|
|
185
|
-
it('should have correct tool names per category', () => {
|
|
186
|
-
expect(toolCategories.session).toContain('start_work_session');
|
|
187
|
-
expect(toolCategories.cost).toContain('get_cost_summary');
|
|
188
|
-
expect(toolCategories.discovery).toContain('discover_tools');
|
|
189
|
-
expect(toolCategories.worktrees).toContain('get_stale_worktrees');
|
|
190
|
-
expect(toolCategories.project).toContain('get_project_context');
|
|
191
|
-
expect(toolCategories.blockers).toContain('add_blocker');
|
|
192
|
-
expect(toolCategories.decisions).toContain('log_decision');
|
|
193
|
-
expect(toolCategories.ideas).toContain('add_idea');
|
|
194
|
-
});
|
|
195
|
-
});
|
|
196
|
-
|
|
197
|
-
describe('tool structure validation', () => {
|
|
198
|
-
const allTools = buildToolList();
|
|
199
|
-
|
|
200
|
-
it('all tools should have a name', () => {
|
|
201
|
-
for (const tool of allTools) {
|
|
202
|
-
expect(tool.name).toBeDefined();
|
|
203
|
-
expect(typeof tool.name).toBe('string');
|
|
204
|
-
expect(tool.name.length).toBeGreaterThan(0);
|
|
205
|
-
}
|
|
206
|
-
});
|
|
207
|
-
|
|
208
|
-
it('all tools should have a description', () => {
|
|
209
|
-
for (const tool of allTools) {
|
|
210
|
-
expect(tool.description).toBeDefined();
|
|
211
|
-
expect(typeof tool.description).toBe('string');
|
|
212
|
-
}
|
|
213
|
-
});
|
|
214
|
-
|
|
215
|
-
it('all tools should have an inputSchema', () => {
|
|
216
|
-
for (const tool of allTools) {
|
|
217
|
-
expect(tool.inputSchema).toBeDefined();
|
|
218
|
-
expect(tool.inputSchema.type).toBe('object');
|
|
219
|
-
}
|
|
220
|
-
});
|
|
221
|
-
});
|
|
222
|
-
});
|
|
1
|
+
/**
|
|
2
|
+
* Tests for split tool definitions
|
|
3
|
+
*
|
|
4
|
+
* Validates that domain-specific tool files:
|
|
5
|
+
* - Export valid Tool arrays
|
|
6
|
+
* - Have unique tool names
|
|
7
|
+
* - Have required inputSchema properties
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import { describe, it, expect } from 'vitest';
|
|
11
|
+
import { sessionTools } from './session.js';
|
|
12
|
+
import { costTools } from './cost.js';
|
|
13
|
+
import { discoveryTools } from './discovery.js';
|
|
14
|
+
import { worktreeTools } from './worktrees.js';
|
|
15
|
+
import { projectTools } from './project.js';
|
|
16
|
+
import { blockerTools } from './blockers.js';
|
|
17
|
+
import { decisionTools } from './decisions.js';
|
|
18
|
+
import { ideaTools } from './ideas.js';
|
|
19
|
+
import { buildToolList, toolCategories } from './index.js';
|
|
20
|
+
|
|
21
|
+
describe('Split Tool Definitions', () => {
|
|
22
|
+
describe('sessionTools', () => {
|
|
23
|
+
it('should export an array of tools', () => {
|
|
24
|
+
expect(Array.isArray(sessionTools)).toBe(true);
|
|
25
|
+
expect(sessionTools.length).toBeGreaterThan(0);
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
it('should include expected session tools', () => {
|
|
29
|
+
const toolNames = sessionTools.map(t => t.name);
|
|
30
|
+
expect(toolNames).toContain('start_work_session');
|
|
31
|
+
expect(toolNames).toContain('heartbeat');
|
|
32
|
+
expect(toolNames).toContain('end_work_session');
|
|
33
|
+
expect(toolNames).toContain('signal_idle');
|
|
34
|
+
expect(toolNames).toContain('get_token_usage');
|
|
35
|
+
expect(toolNames).toContain('report_token_usage');
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
it('should have valid inputSchema for all tools', () => {
|
|
39
|
+
for (const tool of sessionTools) {
|
|
40
|
+
expect(tool.inputSchema).toBeDefined();
|
|
41
|
+
expect(tool.inputSchema.type).toBe('object');
|
|
42
|
+
expect(tool.inputSchema.properties).toBeDefined();
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
describe('costTools', () => {
|
|
48
|
+
it('should export an array of tools', () => {
|
|
49
|
+
expect(Array.isArray(costTools)).toBe(true);
|
|
50
|
+
expect(costTools.length).toBeGreaterThan(0);
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
it('should include expected cost tools', () => {
|
|
54
|
+
const toolNames = costTools.map(t => t.name);
|
|
55
|
+
expect(toolNames).toContain('get_cost_summary');
|
|
56
|
+
expect(toolNames).toContain('add_cost_alert');
|
|
57
|
+
expect(toolNames).toContain('update_cost_alert');
|
|
58
|
+
expect(toolNames).toContain('delete_cost_alert');
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
describe('discoveryTools', () => {
|
|
63
|
+
it('should export an array of tools', () => {
|
|
64
|
+
expect(Array.isArray(discoveryTools)).toBe(true);
|
|
65
|
+
expect(discoveryTools.length).toBeGreaterThan(0);
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
it('should include expected discovery tools', () => {
|
|
69
|
+
const toolNames = discoveryTools.map(t => t.name);
|
|
70
|
+
expect(toolNames).toContain('query_knowledge_base');
|
|
71
|
+
expect(toolNames).toContain('discover_tools');
|
|
72
|
+
expect(toolNames).toContain('get_tool_info');
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
describe('worktreeTools', () => {
|
|
77
|
+
it('should export an array of tools', () => {
|
|
78
|
+
expect(Array.isArray(worktreeTools)).toBe(true);
|
|
79
|
+
expect(worktreeTools.length).toBeGreaterThan(0);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
it('should include expected worktree tools', () => {
|
|
83
|
+
const toolNames = worktreeTools.map(t => t.name);
|
|
84
|
+
expect(toolNames).toContain('get_stale_worktrees');
|
|
85
|
+
expect(toolNames).toContain('clear_worktree_path');
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
describe('projectTools', () => {
|
|
90
|
+
it('should export an array of tools', () => {
|
|
91
|
+
expect(Array.isArray(projectTools)).toBe(true);
|
|
92
|
+
expect(projectTools.length).toBeGreaterThan(0);
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
it('should include expected project tools', () => {
|
|
96
|
+
const toolNames = projectTools.map(t => t.name);
|
|
97
|
+
expect(toolNames).toContain('get_project_context');
|
|
98
|
+
expect(toolNames).toContain('create_project');
|
|
99
|
+
expect(toolNames).toContain('update_project');
|
|
100
|
+
expect(toolNames).toContain('get_project_summary');
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
describe('blockerTools', () => {
|
|
105
|
+
it('should export an array of tools', () => {
|
|
106
|
+
expect(Array.isArray(blockerTools)).toBe(true);
|
|
107
|
+
expect(blockerTools.length).toBeGreaterThan(0);
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
it('should include expected blocker tools', () => {
|
|
111
|
+
const toolNames = blockerTools.map(t => t.name);
|
|
112
|
+
expect(toolNames).toContain('add_blocker');
|
|
113
|
+
expect(toolNames).toContain('resolve_blocker');
|
|
114
|
+
expect(toolNames).toContain('get_blockers');
|
|
115
|
+
expect(toolNames).toContain('delete_blocker');
|
|
116
|
+
});
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
describe('decisionTools', () => {
|
|
120
|
+
it('should export an array of tools', () => {
|
|
121
|
+
expect(Array.isArray(decisionTools)).toBe(true);
|
|
122
|
+
expect(decisionTools.length).toBeGreaterThan(0);
|
|
123
|
+
});
|
|
124
|
+
|
|
125
|
+
it('should include expected decision tools', () => {
|
|
126
|
+
const toolNames = decisionTools.map(t => t.name);
|
|
127
|
+
expect(toolNames).toContain('log_decision');
|
|
128
|
+
expect(toolNames).toContain('get_decisions');
|
|
129
|
+
expect(toolNames).toContain('delete_decision');
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
describe('ideaTools', () => {
|
|
134
|
+
it('should export an array of tools', () => {
|
|
135
|
+
expect(Array.isArray(ideaTools)).toBe(true);
|
|
136
|
+
expect(ideaTools.length).toBeGreaterThan(0);
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
it('should include expected idea tools', () => {
|
|
140
|
+
const toolNames = ideaTools.map(t => t.name);
|
|
141
|
+
expect(toolNames).toContain('add_idea');
|
|
142
|
+
expect(toolNames).toContain('update_idea');
|
|
143
|
+
expect(toolNames).toContain('get_ideas');
|
|
144
|
+
expect(toolNames).toContain('convert_idea_to_task');
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
describe('buildToolList', () => {
|
|
149
|
+
it('should combine all domain tools', () => {
|
|
150
|
+
const allTools = buildToolList();
|
|
151
|
+
expect(Array.isArray(allTools)).toBe(true);
|
|
152
|
+
|
|
153
|
+
// Should include tools from all domains
|
|
154
|
+
const toolNames = allTools.map(t => t.name);
|
|
155
|
+
expect(toolNames).toContain('start_work_session');
|
|
156
|
+
expect(toolNames).toContain('get_cost_summary');
|
|
157
|
+
expect(toolNames).toContain('discover_tools');
|
|
158
|
+
expect(toolNames).toContain('get_stale_worktrees');
|
|
159
|
+
expect(toolNames).toContain('get_project_context');
|
|
160
|
+
expect(toolNames).toContain('add_blocker');
|
|
161
|
+
expect(toolNames).toContain('log_decision');
|
|
162
|
+
expect(toolNames).toContain('add_idea');
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
it('should have unique tool names', () => {
|
|
166
|
+
const allTools = buildToolList();
|
|
167
|
+
const toolNames = allTools.map(t => t.name);
|
|
168
|
+
const uniqueNames = new Set(toolNames);
|
|
169
|
+
expect(uniqueNames.size).toBe(toolNames.length);
|
|
170
|
+
});
|
|
171
|
+
});
|
|
172
|
+
|
|
173
|
+
describe('toolCategories', () => {
|
|
174
|
+
it('should have categories for all domains', () => {
|
|
175
|
+
expect(toolCategories.session).toBeDefined();
|
|
176
|
+
expect(toolCategories.cost).toBeDefined();
|
|
177
|
+
expect(toolCategories.discovery).toBeDefined();
|
|
178
|
+
expect(toolCategories.worktrees).toBeDefined();
|
|
179
|
+
expect(toolCategories.project).toBeDefined();
|
|
180
|
+
expect(toolCategories.blockers).toBeDefined();
|
|
181
|
+
expect(toolCategories.decisions).toBeDefined();
|
|
182
|
+
expect(toolCategories.ideas).toBeDefined();
|
|
183
|
+
});
|
|
184
|
+
|
|
185
|
+
it('should have correct tool names per category', () => {
|
|
186
|
+
expect(toolCategories.session).toContain('start_work_session');
|
|
187
|
+
expect(toolCategories.cost).toContain('get_cost_summary');
|
|
188
|
+
expect(toolCategories.discovery).toContain('discover_tools');
|
|
189
|
+
expect(toolCategories.worktrees).toContain('get_stale_worktrees');
|
|
190
|
+
expect(toolCategories.project).toContain('get_project_context');
|
|
191
|
+
expect(toolCategories.blockers).toContain('add_blocker');
|
|
192
|
+
expect(toolCategories.decisions).toContain('log_decision');
|
|
193
|
+
expect(toolCategories.ideas).toContain('add_idea');
|
|
194
|
+
});
|
|
195
|
+
});
|
|
196
|
+
|
|
197
|
+
describe('tool structure validation', () => {
|
|
198
|
+
const allTools = buildToolList();
|
|
199
|
+
|
|
200
|
+
it('all tools should have a name', () => {
|
|
201
|
+
for (const tool of allTools) {
|
|
202
|
+
expect(tool.name).toBeDefined();
|
|
203
|
+
expect(typeof tool.name).toBe('string');
|
|
204
|
+
expect(tool.name.length).toBeGreaterThan(0);
|
|
205
|
+
}
|
|
206
|
+
});
|
|
207
|
+
|
|
208
|
+
it('all tools should have a description', () => {
|
|
209
|
+
for (const tool of allTools) {
|
|
210
|
+
expect(tool.description).toBeDefined();
|
|
211
|
+
expect(typeof tool.description).toBe('string');
|
|
212
|
+
}
|
|
213
|
+
});
|
|
214
|
+
|
|
215
|
+
it('all tools should have an inputSchema', () => {
|
|
216
|
+
for (const tool of allTools) {
|
|
217
|
+
expect(tool.inputSchema).toBeDefined();
|
|
218
|
+
expect(tool.inputSchema.type).toBe('object');
|
|
219
|
+
}
|
|
220
|
+
});
|
|
221
|
+
});
|
|
222
|
+
});
|
package/src/tools/types.ts
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Tool Definition Types
|
|
3
|
-
*
|
|
4
|
-
* Re-export the Tool type from the MCP SDK for use in domain-specific tool files.
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import type { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
8
|
-
|
|
9
|
-
export type { Tool };
|
|
1
|
+
/**
|
|
2
|
+
* Tool Definition Types
|
|
3
|
+
*
|
|
4
|
+
* Re-export the Tool type from the MCP SDK for use in domain-specific tool files.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import type { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
8
|
+
|
|
9
|
+
export type { Tool };
|
package/src/tools/validation.ts
CHANGED
|
@@ -1,75 +1,75 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Validation Tool Definitions
|
|
3
|
-
*
|
|
4
|
-
* Tools for task validation workflow:
|
|
5
|
-
* - get_tasks_awaiting_validation
|
|
6
|
-
* - claim_validation
|
|
7
|
-
* - validate_task
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import type { Tool } from './types.js';
|
|
11
|
-
|
|
12
|
-
export const validationTools: Tool[] = [
|
|
13
|
-
{
|
|
14
|
-
name: 'get_tasks_awaiting_validation',
|
|
15
|
-
description: `Get completed tasks not yet validated.`,
|
|
16
|
-
inputSchema: {
|
|
17
|
-
type: 'object',
|
|
18
|
-
properties: {
|
|
19
|
-
project_id: {
|
|
20
|
-
type: 'string',
|
|
21
|
-
description: 'Project UUID',
|
|
22
|
-
},
|
|
23
|
-
},
|
|
24
|
-
required: ['project_id'],
|
|
25
|
-
},
|
|
26
|
-
},
|
|
27
|
-
{
|
|
28
|
-
name: 'claim_validation',
|
|
29
|
-
description: 'Claim a completed task for review. Shows "being reviewed" on dashboard.',
|
|
30
|
-
inputSchema: {
|
|
31
|
-
type: 'object',
|
|
32
|
-
properties: {
|
|
33
|
-
task_id: {
|
|
34
|
-
type: 'string',
|
|
35
|
-
description: 'Task UUID to claim for review',
|
|
36
|
-
},
|
|
37
|
-
},
|
|
38
|
-
required: ['task_id'],
|
|
39
|
-
},
|
|
40
|
-
},
|
|
41
|
-
{
|
|
42
|
-
name: 'validate_task',
|
|
43
|
-
description: 'Validate a completed task. Include test results in validation_notes. For github-flow/git-flow projects, a PR must exist and checks must pass before approval.',
|
|
44
|
-
inputSchema: {
|
|
45
|
-
type: 'object',
|
|
46
|
-
properties: {
|
|
47
|
-
task_id: {
|
|
48
|
-
type: 'string',
|
|
49
|
-
description: 'Task UUID to validate',
|
|
50
|
-
},
|
|
51
|
-
validation_notes: {
|
|
52
|
-
type: 'string',
|
|
53
|
-
description: 'Notes about the validation (what was checked, any issues found)',
|
|
54
|
-
},
|
|
55
|
-
approved: {
|
|
56
|
-
type: 'boolean',
|
|
57
|
-
description: 'Whether the task passes validation (true = approved, false = needs more work)',
|
|
58
|
-
},
|
|
59
|
-
pr_checks_passing: {
|
|
60
|
-
type: 'boolean',
|
|
61
|
-
description: 'REQUIRED when approving tasks with PRs. Confirm you verified PR checks are passing via `gh pr view <PR_NUMBER> --json statusCheckRollup`. Set to true only if all required checks pass.',
|
|
62
|
-
},
|
|
63
|
-
skip_pr_check: {
|
|
64
|
-
type: 'boolean',
|
|
65
|
-
description: 'Skip PR existence check (use only for tasks that legitimately do not need a PR)',
|
|
66
|
-
},
|
|
67
|
-
create_fix_task: {
|
|
68
|
-
type: 'boolean',
|
|
69
|
-
description: 'When rejecting (approved: false), create a new fix task linked to the original. The fix task will contain the rejection reason and be assigned the same git branch.',
|
|
70
|
-
},
|
|
71
|
-
},
|
|
72
|
-
required: ['task_id', 'approved'],
|
|
73
|
-
},
|
|
74
|
-
},
|
|
75
|
-
];
|
|
1
|
+
/**
|
|
2
|
+
* Validation Tool Definitions
|
|
3
|
+
*
|
|
4
|
+
* Tools for task validation workflow:
|
|
5
|
+
* - get_tasks_awaiting_validation
|
|
6
|
+
* - claim_validation
|
|
7
|
+
* - validate_task
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import type { Tool } from './types.js';
|
|
11
|
+
|
|
12
|
+
export const validationTools: Tool[] = [
|
|
13
|
+
{
|
|
14
|
+
name: 'get_tasks_awaiting_validation',
|
|
15
|
+
description: `Get completed tasks not yet validated.`,
|
|
16
|
+
inputSchema: {
|
|
17
|
+
type: 'object',
|
|
18
|
+
properties: {
|
|
19
|
+
project_id: {
|
|
20
|
+
type: 'string',
|
|
21
|
+
description: 'Project UUID',
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
required: ['project_id'],
|
|
25
|
+
},
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
name: 'claim_validation',
|
|
29
|
+
description: 'Claim a completed task for review. Shows "being reviewed" on dashboard.',
|
|
30
|
+
inputSchema: {
|
|
31
|
+
type: 'object',
|
|
32
|
+
properties: {
|
|
33
|
+
task_id: {
|
|
34
|
+
type: 'string',
|
|
35
|
+
description: 'Task UUID to claim for review',
|
|
36
|
+
},
|
|
37
|
+
},
|
|
38
|
+
required: ['task_id'],
|
|
39
|
+
},
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
name: 'validate_task',
|
|
43
|
+
description: 'Validate a completed task. Include test results in validation_notes. For github-flow/git-flow projects, a PR must exist and checks must pass before approval.',
|
|
44
|
+
inputSchema: {
|
|
45
|
+
type: 'object',
|
|
46
|
+
properties: {
|
|
47
|
+
task_id: {
|
|
48
|
+
type: 'string',
|
|
49
|
+
description: 'Task UUID to validate',
|
|
50
|
+
},
|
|
51
|
+
validation_notes: {
|
|
52
|
+
type: 'string',
|
|
53
|
+
description: 'Notes about the validation (what was checked, any issues found)',
|
|
54
|
+
},
|
|
55
|
+
approved: {
|
|
56
|
+
type: 'boolean',
|
|
57
|
+
description: 'Whether the task passes validation (true = approved, false = needs more work)',
|
|
58
|
+
},
|
|
59
|
+
pr_checks_passing: {
|
|
60
|
+
type: 'boolean',
|
|
61
|
+
description: 'REQUIRED when approving tasks with PRs. Confirm you verified PR checks are passing via `gh pr view <PR_NUMBER> --json statusCheckRollup`. Set to true only if all required checks pass.',
|
|
62
|
+
},
|
|
63
|
+
skip_pr_check: {
|
|
64
|
+
type: 'boolean',
|
|
65
|
+
description: 'Skip PR existence check (use only for tasks that legitimately do not need a PR)',
|
|
66
|
+
},
|
|
67
|
+
create_fix_task: {
|
|
68
|
+
type: 'boolean',
|
|
69
|
+
description: 'When rejecting (approved: false), create a new fix task linked to the original. The fix task will contain the rejection reason and be assigned the same git branch.',
|
|
70
|
+
},
|
|
71
|
+
},
|
|
72
|
+
required: ['task_id', 'approved'],
|
|
73
|
+
},
|
|
74
|
+
},
|
|
75
|
+
];
|