@brookmind/ai-toolkit 1.1.7 → 1.2.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.
Files changed (149) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +42 -14
  3. package/dist/__tests__/constants.test.d.ts +2 -0
  4. package/dist/__tests__/constants.test.d.ts.map +1 -0
  5. package/dist/__tests__/constants.test.js +102 -0
  6. package/dist/__tests__/constants.test.js.map +1 -0
  7. package/dist/__tests__/index.test.d.ts +2 -0
  8. package/dist/__tests__/index.test.d.ts.map +1 -0
  9. package/dist/__tests__/index.test.js +114 -0
  10. package/dist/__tests__/index.test.js.map +1 -0
  11. package/dist/__tests__/integration/installer.test.d.ts +2 -0
  12. package/dist/__tests__/integration/installer.test.d.ts.map +1 -0
  13. package/dist/__tests__/integration/installer.test.js +425 -0
  14. package/dist/__tests__/integration/installer.test.js.map +1 -0
  15. package/dist/__tests__/services/installers.test.d.ts +2 -0
  16. package/dist/__tests__/services/installers.test.d.ts.map +1 -0
  17. package/dist/__tests__/services/installers.test.js +222 -0
  18. package/dist/__tests__/services/installers.test.js.map +1 -0
  19. package/dist/__tests__/services/opencode.test.d.ts +2 -0
  20. package/dist/__tests__/services/opencode.test.d.ts.map +1 -0
  21. package/dist/__tests__/services/opencode.test.js +120 -0
  22. package/dist/__tests__/services/opencode.test.js.map +1 -0
  23. package/dist/__tests__/ui/categorize.test.d.ts +2 -0
  24. package/dist/__tests__/ui/categorize.test.d.ts.map +1 -0
  25. package/dist/__tests__/ui/categorize.test.js +194 -0
  26. package/dist/__tests__/ui/categorize.test.js.map +1 -0
  27. package/dist/__tests__/ui/choices.test.d.ts +2 -0
  28. package/dist/__tests__/ui/choices.test.d.ts.map +1 -0
  29. package/dist/__tests__/ui/choices.test.js +180 -0
  30. package/dist/__tests__/ui/choices.test.js.map +1 -0
  31. package/dist/__tests__/ui/display.test.d.ts +2 -0
  32. package/dist/__tests__/ui/display.test.d.ts.map +1 -0
  33. package/dist/__tests__/ui/display.test.js +142 -0
  34. package/dist/__tests__/ui/display.test.js.map +1 -0
  35. package/dist/__tests__/utils/fs.test.d.ts +2 -0
  36. package/dist/__tests__/utils/fs.test.d.ts.map +1 -0
  37. package/dist/__tests__/utils/fs.test.js +142 -0
  38. package/dist/__tests__/utils/fs.test.js.map +1 -0
  39. package/dist/__tests__/utils/terminal.test.d.ts +2 -0
  40. package/dist/__tests__/utils/terminal.test.d.ts.map +1 -0
  41. package/dist/__tests__/utils/terminal.test.js +97 -0
  42. package/dist/__tests__/utils/terminal.test.js.map +1 -0
  43. package/dist/constants.d.ts +11 -0
  44. package/dist/constants.d.ts.map +1 -0
  45. package/dist/constants.js +40 -0
  46. package/dist/constants.js.map +1 -0
  47. package/dist/index.d.ts +2 -0
  48. package/dist/index.d.ts.map +1 -1
  49. package/dist/index.js +49 -332
  50. package/dist/index.js.map +1 -1
  51. package/dist/services/installers.d.ts +8 -0
  52. package/dist/services/installers.d.ts.map +1 -0
  53. package/dist/services/installers.js +79 -0
  54. package/dist/services/installers.js.map +1 -0
  55. package/dist/services/opencode.d.ts +3 -0
  56. package/dist/services/opencode.d.ts.map +1 -0
  57. package/dist/services/opencode.js +33 -0
  58. package/dist/services/opencode.js.map +1 -0
  59. package/dist/types.d.ts +10 -0
  60. package/dist/types.d.ts.map +1 -0
  61. package/dist/types.js +2 -0
  62. package/dist/types.js.map +1 -0
  63. package/dist/ui/categorize.d.ts +6 -0
  64. package/dist/ui/categorize.d.ts.map +1 -0
  65. package/dist/ui/categorize.js +69 -0
  66. package/dist/ui/categorize.js.map +1 -0
  67. package/dist/ui/choices.d.ts +6 -0
  68. package/dist/ui/choices.d.ts.map +1 -0
  69. package/dist/ui/choices.js +70 -0
  70. package/dist/ui/choices.js.map +1 -0
  71. package/dist/ui/display.d.ts +8 -0
  72. package/dist/ui/display.d.ts.map +1 -0
  73. package/dist/ui/display.js +86 -0
  74. package/dist/ui/display.js.map +1 -0
  75. package/dist/utils/fs.d.ts +5 -0
  76. package/dist/utils/fs.d.ts.map +1 -0
  77. package/dist/utils/fs.js +40 -0
  78. package/dist/utils/fs.js.map +1 -0
  79. package/dist/utils/terminal.d.ts +5 -0
  80. package/dist/utils/terminal.d.ts.map +1 -0
  81. package/dist/utils/terminal.js +18 -0
  82. package/dist/utils/terminal.js.map +1 -0
  83. package/package.json +29 -5
  84. package/agents/code-reviewer.md +0 -35
  85. package/agents/code-simplifier.md +0 -52
  86. package/commands/create-pr-description.md +0 -102
  87. package/commands/create-pr.md +0 -76
  88. package/commands/create-react-tests.md +0 -207
  89. package/mcps/context7/.mcp.json +0 -13
  90. package/mcps/expo-mcp/.mcp.json +0 -13
  91. package/mcps/figma-mcp/.mcp.json +0 -10
  92. package/skills/github-cli/SKILL.md +0 -125
  93. package/skills/pdf-processing-pro/FORMS.md +0 -610
  94. package/skills/pdf-processing-pro/OCR.md +0 -137
  95. package/skills/pdf-processing-pro/SKILL.md +0 -296
  96. package/skills/pdf-processing-pro/TABLES.md +0 -626
  97. package/skills/pdf-processing-pro/scripts/analyze_form.py +0 -307
  98. package/skills/react-best-practices/AGENTS.md +0 -915
  99. package/skills/react-best-practices/README.md +0 -127
  100. package/skills/react-best-practices/SKILL.md +0 -110
  101. package/skills/react-best-practices/metadata.json +0 -14
  102. package/skills/react-best-practices/rules/_sections.md +0 -41
  103. package/skills/react-best-practices/rules/_template.md +0 -28
  104. package/skills/react-best-practices/rules/advanced-event-handler-refs.md +0 -80
  105. package/skills/react-best-practices/rules/advanced-use-latest.md +0 -76
  106. package/skills/react-best-practices/rules/async-defer-await.md +0 -80
  107. package/skills/react-best-practices/rules/async-dependencies.md +0 -36
  108. package/skills/react-best-practices/rules/async-parallel.md +0 -28
  109. package/skills/react-best-practices/rules/async-suspense-boundaries.md +0 -100
  110. package/skills/react-best-practices/rules/bundle-barrel-imports.md +0 -42
  111. package/skills/react-best-practices/rules/bundle-conditional.md +0 -106
  112. package/skills/react-best-practices/rules/bundle-preload.md +0 -44
  113. package/skills/react-best-practices/rules/client-event-listeners.md +0 -131
  114. package/skills/react-best-practices/rules/client-swr-dedup.md +0 -133
  115. package/skills/react-best-practices/rules/js-batch-dom-css.md +0 -82
  116. package/skills/react-best-practices/rules/js-cache-function-results.md +0 -80
  117. package/skills/react-best-practices/rules/js-cache-property-access.md +0 -28
  118. package/skills/react-best-practices/rules/js-cache-storage.md +0 -70
  119. package/skills/react-best-practices/rules/js-combine-iterations.md +0 -32
  120. package/skills/react-best-practices/rules/js-early-exit.md +0 -50
  121. package/skills/react-best-practices/rules/js-hoist-regexp.md +0 -45
  122. package/skills/react-best-practices/rules/js-index-maps.md +0 -37
  123. package/skills/react-best-practices/rules/js-length-check-first.md +0 -49
  124. package/skills/react-best-practices/rules/js-min-max-loop.md +0 -82
  125. package/skills/react-best-practices/rules/js-set-map-lookups.md +0 -24
  126. package/skills/react-best-practices/rules/js-tosorted-immutable.md +0 -57
  127. package/skills/react-best-practices/rules/rendering-activity.md +0 -90
  128. package/skills/react-best-practices/rules/rendering-animate-svg-wrapper.md +0 -47
  129. package/skills/react-best-practices/rules/rendering-conditional-render.md +0 -40
  130. package/skills/react-best-practices/rules/rendering-content-visibility.md +0 -38
  131. package/skills/react-best-practices/rules/rendering-hoist-jsx.md +0 -65
  132. package/skills/react-best-practices/rules/rendering-svg-precision.md +0 -28
  133. package/skills/react-best-practices/rules/rerender-defer-reads.md +0 -39
  134. package/skills/react-best-practices/rules/rerender-dependencies.md +0 -45
  135. package/skills/react-best-practices/rules/rerender-derived-state.md +0 -29
  136. package/skills/react-best-practices/rules/rerender-functional-setstate.md +0 -74
  137. package/skills/react-best-practices/rules/rerender-lazy-state-init.md +0 -58
  138. package/skills/react-best-practices/rules/rerender-memo.md +0 -85
  139. package/skills/react-best-practices/rules/rerender-transitions.md +0 -40
  140. package/skills/skill-creator/LICENSE.txt +0 -202
  141. package/skills/skill-creator/SKILL.md +0 -209
  142. package/skills/skill-creator/scripts/init_skill.py +0 -303
  143. package/skills/skill-creator/scripts/package_skill.py +0 -110
  144. package/skills/skill-creator/scripts/quick_validate.py +0 -65
  145. package/skills/spring-boot-development/EXAMPLES.md +0 -2346
  146. package/skills/spring-boot-development/README.md +0 -595
  147. package/skills/spring-boot-development/SKILL.md +0 -1519
  148. package/themes/README.md +0 -68
  149. package/themes/claude-vivid.json +0 -72
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 David Castillo
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md CHANGED
@@ -1,5 +1,9 @@
1
1
  # AI Toolkit
2
2
 
3
+ [![npm version](https://img.shields.io/npm/v/@brookmind/ai-toolkit.svg)](https://www.npmjs.com/package/@brookmind/ai-toolkit)
4
+ [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
5
+ [![Node.js](https://img.shields.io/badge/node-%3E%3D20-brightgreen.svg)](https://nodejs.org/)
6
+
3
7
  A collection of agents, skills, and MCPs for AI coding assistants.
4
8
 
5
9
  ## Quick Install
@@ -14,6 +18,7 @@ The installer will:
14
18
  2. **Guide you through selecting**:
15
19
  - **Agents**: AI assistants for specific tasks
16
20
  - **Skills**: Extended capabilities and workflows
21
+ - **Commands**: Reusable prompts for common tasks
17
22
  - **MCPs**: Model Context Protocol servers
18
23
  3. **Theme installation**:
19
24
  - **New installations**: claude-vivid theme is installed automatically
@@ -23,27 +28,47 @@ The installer will:
23
28
 
24
29
  ### Agents
25
30
 
26
- - `code-reviewer` - Expert code review for quality and security
27
- - `code-simplifier` - Simplifies and refines code for clarity and maintainability
31
+ | Name | Description |
32
+ |------|-------------|
33
+ | `changelog-generator` | Changelog and release notes from git history |
34
+ | `code-reviewer` | Code review for quality, security, maintainability |
35
+ | `code-simplifier` | Simplify code for clarity and maintainability |
36
+
37
+ ### Commands
38
+
39
+ | Name | Description |
40
+ |------|-------------|
41
+ | `create-pr` | Create PR on GitHub with optional reviewer |
42
+ | `create-pr-description` | Generate PR title and description |
43
+ | `create-react-tests` | Generate Jest + RTL tests (90% coverage) |
28
44
 
29
45
  ### Skills
30
46
 
31
- - `github-cli` - GitHub operations (issues, PRs, releases)
32
- - `pdf-processing-pro` - Advanced PDF processing (OCR, tables, forms extraction)
33
- - `react-best-practices` - React performance optimization guidelines from Vercel Engineering
34
- - `skill-creator` - Create new skills
47
+ | Name | Description |
48
+ |------|-------------|
49
+ | `expo-best-practices` | UI, navigation, styling, data fetching for Expo apps |
50
+ | `github-cli` | Issues, PRs, releases via gh CLI |
51
+ | `pdf-processing-pro` | Forms, tables, OCR, batch PDF operations |
52
+ | `react-best-practices` | Performance patterns from Vercel Engineering |
53
+ | `react-native-best-practices` | FPS, TTI, bundle size, animations optimization |
54
+ | `skill-creator` | Guide for creating custom skills |
55
+ | `spring-boot-development` | REST APIs, JPA, Security, microservices |
35
56
 
36
57
  ### MCPs
37
58
 
38
- - `context7` - Up-to-date library documentation
39
- - `expo-mcp` - Expo/React Native utilities
40
- - `figma-mcp` - Figma design integration (requires Figma Desktop app)
59
+ | Name | Description |
60
+ |------|-------------|
61
+ | `context7` | Up-to-date library documentation |
62
+ | `expo-mcp` | Expo/React Native utilities |
63
+ | `figma-mcp` | Figma design integration (requires Desktop app) |
41
64
 
42
65
  ### Theme
43
66
 
44
- - `claude-vivid` - High-contrast theme with vivid colors inspired by Claude Code
45
- - Auto-installed for new OpenCode users
46
- - Optional for existing OpenCode users
67
+ | Name | Description |
68
+ |------|-------------|
69
+ | `claude-vivid` | High-contrast theme with vivid colors |
70
+
71
+ > Theme is auto-installed for new users, optional for existing installations.
47
72
 
48
73
  ## Manual Installation
49
74
 
@@ -58,8 +83,7 @@ npm start
58
83
 
59
84
  ## Requirements
60
85
 
61
- - Node.js 18+
62
- - OpenCode installed
86
+ - Node.js 20+
63
87
  - For Figma MCP: Figma Desktop app running
64
88
 
65
89
  ## Configuration
@@ -95,6 +119,10 @@ To use GitHub Copilot with OpenCode, follow these steps:
95
119
 
96
120
  That's it! GitHub Copilot will now be available as a provider in OpenCode.
97
121
 
122
+ ## Contributing
123
+
124
+ See [CONTRIBUTING.md](CONTRIBUTING.md) for guidelines.
125
+
98
126
  ## License
99
127
 
100
128
  MIT
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=constants.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/constants.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,102 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { join } from 'path';
3
+ import { homedir } from 'os';
4
+ import { ROOT_DIR, TOOLS_DIR, HOME_DIR, OPENCODE_DIR, OPENCODE_CONFIG, BOTTOM_PADDING, MCP_DISPLAY_NAMES, DESCRIPTIONS, getDescription, } from '../constants.js';
5
+ describe('constants', () => {
6
+ describe('path constants', () => {
7
+ it('should have ROOT_DIR pointing to project root', () => {
8
+ expect(ROOT_DIR).toBeDefined();
9
+ expect(typeof ROOT_DIR).toBe('string');
10
+ expect(ROOT_DIR.length).toBeGreaterThan(0);
11
+ });
12
+ it('should have TOOLS_DIR as subdirectory of ROOT_DIR', () => {
13
+ expect(TOOLS_DIR).toBe(join(ROOT_DIR, 'tools'));
14
+ });
15
+ it('should have HOME_DIR equal to os.homedir()', () => {
16
+ expect(HOME_DIR).toBe(homedir());
17
+ });
18
+ it('should have OPENCODE_DIR in .config/opencode', () => {
19
+ expect(OPENCODE_DIR).toBe(join(HOME_DIR, '.config', 'opencode'));
20
+ });
21
+ it('should have OPENCODE_CONFIG as opencode.json in OPENCODE_DIR', () => {
22
+ expect(OPENCODE_CONFIG).toBe(join(OPENCODE_DIR, 'opencode.json'));
23
+ });
24
+ });
25
+ describe('BOTTOM_PADDING', () => {
26
+ it('should be 5', () => {
27
+ expect(BOTTOM_PADDING).toBe(5);
28
+ });
29
+ it('should be a positive integer', () => {
30
+ expect(Number.isInteger(BOTTOM_PADDING)).toBe(true);
31
+ expect(BOTTOM_PADDING).toBeGreaterThan(0);
32
+ });
33
+ });
34
+ describe('MCP_DISPLAY_NAMES', () => {
35
+ it('should be a non-empty object', () => {
36
+ expect(typeof MCP_DISPLAY_NAMES).toBe('object');
37
+ expect(Object.keys(MCP_DISPLAY_NAMES).length).toBeGreaterThan(0);
38
+ });
39
+ it('should map pg-aiguide to postgres-mcp', () => {
40
+ expect(MCP_DISPLAY_NAMES['pg-aiguide']).toBe('postgres-mcp');
41
+ });
42
+ it('should have string values only', () => {
43
+ for (const value of Object.values(MCP_DISPLAY_NAMES)) {
44
+ expect(typeof value).toBe('string');
45
+ }
46
+ });
47
+ });
48
+ describe('DESCRIPTIONS', () => {
49
+ it('should be a non-empty object', () => {
50
+ expect(typeof DESCRIPTIONS).toBe('object');
51
+ expect(Object.keys(DESCRIPTIONS).length).toBeGreaterThan(0);
52
+ });
53
+ it('should have string values only', () => {
54
+ for (const value of Object.values(DESCRIPTIONS)) {
55
+ expect(typeof value).toBe('string');
56
+ expect(value.length).toBeGreaterThan(0);
57
+ }
58
+ });
59
+ it('should contain agent descriptions', () => {
60
+ expect(DESCRIPTIONS['changelog-generator']).toBeDefined();
61
+ expect(DESCRIPTIONS['code-reviewer']).toBeDefined();
62
+ expect(DESCRIPTIONS['code-simplifier']).toBeDefined();
63
+ });
64
+ it('should contain command descriptions', () => {
65
+ expect(DESCRIPTIONS['create-pr']).toBeDefined();
66
+ expect(DESCRIPTIONS['create-pr-description']).toBeDefined();
67
+ expect(DESCRIPTIONS['create-react-tests']).toBeDefined();
68
+ });
69
+ it('should contain skill descriptions', () => {
70
+ expect(DESCRIPTIONS['expo-best-practices']).toBeDefined();
71
+ expect(DESCRIPTIONS['github-cli']).toBeDefined();
72
+ expect(DESCRIPTIONS['react-best-practices']).toBeDefined();
73
+ });
74
+ it('should contain MCP descriptions', () => {
75
+ expect(DESCRIPTIONS['context7']).toBeDefined();
76
+ expect(DESCRIPTIONS['expo-mcp']).toBeDefined();
77
+ });
78
+ });
79
+ describe('getDescription', () => {
80
+ it('should return description for existing key', () => {
81
+ const result = getDescription('changelog-generator');
82
+ expect(result).toBe('Generate changelogs and release notes');
83
+ });
84
+ it('should return null for non-existing key', () => {
85
+ const result = getDescription('non-existing-key');
86
+ expect(result).toBeNull();
87
+ });
88
+ it('should return null for empty string key', () => {
89
+ const result = getDescription('');
90
+ expect(result).toBeNull();
91
+ });
92
+ it('should handle context7 (unquoted key)', () => {
93
+ const result = getDescription('context7');
94
+ expect(result).toBe('Library documentation lookup');
95
+ });
96
+ it('should handle quoted and hyphenated keys', () => {
97
+ const result = getDescription('pdf-processing-pro');
98
+ expect(result).toBe('Forms, tables, OCR, batch operations');
99
+ });
100
+ });
101
+ });
102
+ //# sourceMappingURL=constants.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.test.js","sourceRoot":"","sources":["../../src/__tests__/constants.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/index.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,114 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { access, readdir, readFile } from 'fs/promises';
3
+ import { join } from 'path';
4
+ async function exists(path) {
5
+ try {
6
+ await access(path);
7
+ return true;
8
+ }
9
+ catch {
10
+ return false;
11
+ }
12
+ }
13
+ describe('project structure', () => {
14
+ it('should have required directories in tools/', async () => {
15
+ const rootDir = join(import.meta.dirname, '..', '..');
16
+ const toolsDir = join(rootDir, 'tools');
17
+ const dirs = ['agents', 'commands', 'skills', 'mcps', 'themes'];
18
+ for (const dir of dirs) {
19
+ const dirExists = await exists(join(toolsDir, dir));
20
+ expect(dirExists, `tools/${dir} directory should exist`).toBe(true);
21
+ }
22
+ });
23
+ it('should have package.json', async () => {
24
+ const rootDir = join(import.meta.dirname, '..', '..');
25
+ const pkgExists = await exists(join(rootDir, 'package.json'));
26
+ expect(pkgExists).toBe(true);
27
+ });
28
+ it('should have LICENSE file', async () => {
29
+ const rootDir = join(import.meta.dirname, '..', '..');
30
+ const licenseExists = await exists(join(rootDir, 'LICENSE'));
31
+ expect(licenseExists).toBe(true);
32
+ });
33
+ });
34
+ describe('skills validation', () => {
35
+ it('should have SKILL.md in each skill folder', async () => {
36
+ const rootDir = join(import.meta.dirname, '..', '..');
37
+ const skillsDir = join(rootDir, 'tools', 'skills');
38
+ const skills = await readdir(skillsDir, { withFileTypes: true });
39
+ const skillDirs = skills.filter((s) => s.isDirectory()).map((s) => s.name);
40
+ for (const skill of skillDirs) {
41
+ const skillMdExists = await exists(join(skillsDir, skill, 'SKILL.md'));
42
+ expect(skillMdExists, `${skill}/SKILL.md should exist`).toBe(true);
43
+ }
44
+ });
45
+ });
46
+ describe('mcps validation', () => {
47
+ it('should have .mcp.json in each mcp folder', async () => {
48
+ const rootDir = join(import.meta.dirname, '..', '..');
49
+ const mcpsDir = join(rootDir, 'tools', 'mcps');
50
+ const mcps = await readdir(mcpsDir, { withFileTypes: true });
51
+ const mcpDirs = mcps.filter((m) => m.isDirectory()).map((m) => m.name);
52
+ for (const mcp of mcpDirs) {
53
+ const mcpJsonExists = await exists(join(mcpsDir, mcp, '.mcp.json'));
54
+ expect(mcpJsonExists, `${mcp}/.mcp.json should exist`).toBe(true);
55
+ }
56
+ });
57
+ });
58
+ describe('descriptions validation', () => {
59
+ const getDescriptionsFromSource = async () => {
60
+ const rootDir = join(import.meta.dirname, '..', '..');
61
+ const constantsPath = join(rootDir, 'src', 'constants.ts');
62
+ const content = await readFile(constantsPath, 'utf-8');
63
+ const match = content.match(/export const DESCRIPTIONS[^{]*\{([^}]+)\}/s);
64
+ if (!match)
65
+ return new Set();
66
+ const quotedKeys = match[1].match(/'([^']+)':/g) || [];
67
+ const unquotedKeys = match[1].match(/^\s*([a-zA-Z0-9-]+):/gm) || [];
68
+ const keys = new Set();
69
+ quotedKeys.forEach((k) => keys.add(k.replace(/'/g, '').replace(':', '')));
70
+ unquotedKeys.forEach((k) => keys.add(k.trim().replace(':', '')));
71
+ return keys;
72
+ };
73
+ it('should have description for each agent', async () => {
74
+ const rootDir = join(import.meta.dirname, '..', '..');
75
+ const agentsDir = join(rootDir, 'tools', 'agents');
76
+ const descriptions = await getDescriptionsFromSource();
77
+ const files = await readdir(agentsDir);
78
+ const agents = files.filter((f) => f.endsWith('.md')).map((f) => f.replace('.md', ''));
79
+ for (const agent of agents) {
80
+ expect(descriptions.has(agent), `Agent '${agent}' missing description`).toBe(true);
81
+ }
82
+ });
83
+ it('should have description for each skill', async () => {
84
+ const rootDir = join(import.meta.dirname, '..', '..');
85
+ const skillsDir = join(rootDir, 'tools', 'skills');
86
+ const descriptions = await getDescriptionsFromSource();
87
+ const entries = await readdir(skillsDir, { withFileTypes: true });
88
+ const skills = entries.filter((e) => e.isDirectory()).map((e) => e.name);
89
+ for (const skill of skills) {
90
+ expect(descriptions.has(skill), `Skill '${skill}' missing description`).toBe(true);
91
+ }
92
+ });
93
+ it('should have description for each command', async () => {
94
+ const rootDir = join(import.meta.dirname, '..', '..');
95
+ const commandsDir = join(rootDir, 'tools', 'commands');
96
+ const descriptions = await getDescriptionsFromSource();
97
+ const files = await readdir(commandsDir);
98
+ const commands = files.filter((f) => f.endsWith('.md')).map((f) => f.replace('.md', ''));
99
+ for (const command of commands) {
100
+ expect(descriptions.has(command), `Command '${command}' missing description`).toBe(true);
101
+ }
102
+ });
103
+ it('should have description for each MCP', async () => {
104
+ const rootDir = join(import.meta.dirname, '..', '..');
105
+ const mcpsDir = join(rootDir, 'tools', 'mcps');
106
+ const descriptions = await getDescriptionsFromSource();
107
+ const entries = await readdir(mcpsDir, { withFileTypes: true });
108
+ const mcps = entries.filter((e) => e.isDirectory()).map((e) => e.name);
109
+ for (const mcp of mcps) {
110
+ expect(descriptions.has(mcp), `MCP '${mcp}' missing description`).toBe(true);
111
+ }
112
+ });
113
+ });
114
+ //# sourceMappingURL=index.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../src/__tests__/index.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=installer.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"installer.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/integration/installer.test.ts"],"names":[],"mappings":""}