0xray 2.1.1 → 2.1.3

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 (254) hide show
  1. package/.opencode/codex.codex +1 -1
  2. package/.opencode/commands/dependency-audit.md +3 -3
  3. package/.opencode/enforcer-config.json +2 -2
  4. package/AGENTS.md +3 -2
  5. package/README.md +12 -11
  6. package/dist/AGENTS.md +3 -2
  7. package/dist/CHANGELOG.md +26 -0
  8. package/dist/README.md +12 -11
  9. package/dist/agents/code-reviewer.js +1 -1
  10. package/dist/analytics/routing-refiner.js +1 -1
  11. package/dist/cli/index.js +11 -1
  12. package/dist/cli/server.js +3 -3
  13. package/dist/core/activity-logger.d.ts +2 -2
  14. package/dist/core/activity-logger.js +4 -4
  15. package/dist/core/boot-orchestrator.d.ts +1 -1
  16. package/dist/core/boot-orchestrator.js +13 -28
  17. package/dist/core/bridge.mjs +3 -3
  18. package/dist/core/codex-formatter.js +2 -2
  19. package/dist/core/codex-injector.d.ts +0 -1
  20. package/dist/core/codex-injector.js +2 -3
  21. package/dist/core/config-loader.d.ts +1 -1
  22. package/dist/core/config-loader.js +1 -1
  23. package/dist/core/config-paths.d.ts +0 -2
  24. package/dist/core/config-paths.js +7 -8
  25. package/dist/core/context-loader.d.ts +1 -1
  26. package/dist/core/context-loader.js +1 -1
  27. package/dist/core/errors.d.ts +3 -0
  28. package/dist/core/errors.js +10 -0
  29. package/dist/core/features-config.js +1 -1
  30. package/dist/core/framework-logger.d.ts +3 -3
  31. package/dist/core/framework-logger.js +17 -9
  32. package/dist/core/index.d.ts +2 -2
  33. package/dist/core/index.js +4 -2
  34. package/dist/core/logging-config.d.ts +2 -1
  35. package/dist/core/logging-config.js +7 -7
  36. package/dist/enforcement/loaders/codex-loader.js +1 -1
  37. package/dist/execution/opencode-cli-invoker.js +5 -5
  38. package/dist/governance/governance-service.js +1 -1
  39. package/dist/index.d.ts +3 -3
  40. package/dist/index.js +3 -3
  41. package/dist/inference/inference-cycle.d.ts +1 -1
  42. package/dist/inference/inference-cycle.js +10 -10
  43. package/dist/integrations/base/Integration.js +1 -1
  44. package/dist/integrations/base/registry.js +19 -19
  45. package/dist/integrations/grok/grok-cli.js +17 -17
  46. package/dist/integrations/grok/hooks/pre-tool-use.js +1 -1
  47. package/dist/integrations/hermes-agent/bridge.mjs +1 -1
  48. package/dist/integrations/openclaw/api-server.d.ts +0 -1
  49. package/dist/integrations/openclaw/api-server.js +7 -10
  50. package/dist/integrations/openclaw/client.d.ts +0 -1
  51. package/dist/integrations/openclaw/client.js +22 -24
  52. package/dist/integrations/openclaw/hooks/xray-hooks.d.ts +0 -1
  53. package/dist/integrations/openclaw/hooks/xray-hooks.js +17 -18
  54. package/dist/integrations/plugins/plugin-registry.js +5 -5
  55. package/dist/mcps/architect-tools.server.d.ts +2 -4
  56. package/dist/mcps/architect-tools.server.js +112 -195
  57. package/dist/mcps/auto-format.server.d.ts +2 -4
  58. package/dist/mcps/auto-format.server.js +49 -95
  59. package/dist/mcps/boot-orchestrator.server.d.ts +2 -4
  60. package/dist/mcps/boot-orchestrator.server.js +73 -105
  61. package/dist/mcps/config/server-config-registry.js +3 -3
  62. package/dist/mcps/enforcer-tools.server.d.ts +2 -4
  63. package/dist/mcps/enforcer-tools.server.js +202 -285
  64. package/dist/mcps/estimation.server.d.ts +2 -4
  65. package/dist/mcps/estimation.server.js +63 -107
  66. package/dist/mcps/framework-compliance-audit.server.d.ts +2 -4
  67. package/dist/mcps/framework-compliance-audit.server.js +53 -82
  68. package/dist/mcps/framework-help.server.d.ts +2 -4
  69. package/dist/mcps/framework-help.server.js +63 -101
  70. package/dist/mcps/governance.server.js +2 -2
  71. package/dist/mcps/knowledge-skills/api-design.server.d.ts +2 -4
  72. package/dist/mcps/knowledge-skills/api-design.server.js +35 -67
  73. package/dist/mcps/knowledge-skills/architecture-patterns.server.d.ts +2 -10
  74. package/dist/mcps/knowledge-skills/architecture-patterns.server.js +35 -74
  75. package/dist/mcps/knowledge-skills/bug-triage-specialist.server.d.ts +2 -4
  76. package/dist/mcps/knowledge-skills/bug-triage-specialist.server.js +143 -162
  77. package/dist/mcps/knowledge-skills/code-analyzer.server.d.ts +3 -4
  78. package/dist/mcps/knowledge-skills/code-analyzer.server.js +20 -45
  79. package/dist/mcps/knowledge-skills/code-review.server.d.ts +2 -4
  80. package/dist/mcps/knowledge-skills/code-review.server.js +109 -143
  81. package/dist/mcps/knowledge-skills/content-creator.server.d.ts +2 -4
  82. package/dist/mcps/knowledge-skills/content-creator.server.js +205 -226
  83. package/dist/mcps/knowledge-skills/database-design.server.d.ts +2 -4
  84. package/dist/mcps/knowledge-skills/database-design.server.js +117 -151
  85. package/dist/mcps/knowledge-skills/devops-deployment.server.d.ts +2 -4
  86. package/dist/mcps/knowledge-skills/devops-deployment.server.js +71 -160
  87. package/dist/mcps/knowledge-skills/git-workflow.server.d.ts +2 -4
  88. package/dist/mcps/knowledge-skills/git-workflow.server.js +36 -68
  89. package/dist/mcps/knowledge-skills/growth-strategist.server.d.ts +2 -4
  90. package/dist/mcps/knowledge-skills/growth-strategist.server.js +303 -324
  91. package/dist/mcps/knowledge-skills/log-monitor.server.d.ts +2 -4
  92. package/dist/mcps/knowledge-skills/log-monitor.server.js +141 -160
  93. package/dist/mcps/knowledge-skills/mobile-development.server.d.ts +2 -4
  94. package/dist/mcps/knowledge-skills/mobile-development.server.js +92 -209
  95. package/dist/mcps/knowledge-skills/multimodal-looker.server.d.ts +2 -4
  96. package/dist/mcps/knowledge-skills/multimodal-looker.server.js +123 -159
  97. package/dist/mcps/knowledge-skills/performance-optimization.server.d.ts +2 -5
  98. package/dist/mcps/knowledge-skills/performance-optimization.server.js +155 -296
  99. package/dist/mcps/knowledge-skills/project-analysis.server.d.ts +2 -4
  100. package/dist/mcps/knowledge-skills/project-analysis.server.js +75 -226
  101. package/dist/mcps/knowledge-skills/refactoring-strategies.server.d.ts +2 -4
  102. package/dist/mcps/knowledge-skills/refactoring-strategies.server.js +63 -156
  103. package/dist/mcps/knowledge-skills/security-audit.server.d.ts +2 -4
  104. package/dist/mcps/knowledge-skills/security-audit.server.js +102 -136
  105. package/dist/mcps/knowledge-skills/seo-consultant.server.d.ts +2 -4
  106. package/dist/mcps/knowledge-skills/seo-consultant.server.js +80 -203
  107. package/dist/mcps/knowledge-skills/session-management.server.d.ts +2 -4
  108. package/dist/mcps/knowledge-skills/session-management.server.js +50 -203
  109. package/dist/mcps/knowledge-skills/skill-invocation.server.d.ts +2 -4
  110. package/dist/mcps/knowledge-skills/skill-invocation.server.js +168 -347
  111. package/dist/mcps/knowledge-skills/strategist.server.d.ts +2 -11
  112. package/dist/mcps/knowledge-skills/strategist.server.js +72 -122
  113. package/dist/mcps/knowledge-skills/tech-writer.server.d.ts +2 -4
  114. package/dist/mcps/knowledge-skills/tech-writer.server.js +87 -300
  115. package/dist/mcps/knowledge-skills/testing-best-practices.server.d.ts +2 -4
  116. package/dist/mcps/knowledge-skills/testing-best-practices.server.js +147 -182
  117. package/dist/mcps/knowledge-skills/testing-strategy.server.d.ts +2 -4
  118. package/dist/mcps/knowledge-skills/testing-strategy.server.js +78 -153
  119. package/dist/mcps/knowledge-skills/ui-ux-design.server.d.ts +2 -5
  120. package/dist/mcps/knowledge-skills/ui-ux-design.server.js +90 -399
  121. package/dist/mcps/lint.server.d.ts +2 -4
  122. package/dist/mcps/lint.server.js +51 -92
  123. package/dist/mcps/mcp-client.js +2 -2
  124. package/dist/mcps/model-health-check.server.d.ts +2 -4
  125. package/dist/mcps/model-health-check.server.js +32 -60
  126. package/dist/mcps/performance-analysis.server.d.ts +2 -4
  127. package/dist/mcps/performance-analysis.server.js +57 -88
  128. package/dist/mcps/processor-pipeline.server.d.ts +2 -4
  129. package/dist/mcps/processor-pipeline.server.js +69 -100
  130. package/dist/mcps/registry.json +1 -1
  131. package/dist/mcps/researcher.server.d.ts +3 -5
  132. package/dist/mcps/researcher.server.js +81 -154
  133. package/dist/mcps/security-scan.server.d.ts +2 -4
  134. package/dist/mcps/security-scan.server.js +54 -96
  135. package/dist/mcps/shared/knowledge-skill-base.d.ts +14 -0
  136. package/dist/mcps/shared/knowledge-skill-base.js +45 -0
  137. package/dist/{security → mcps/shared}/security-scanner.js +1 -1
  138. package/dist/mcps/state-manager.server.d.ts +2 -4
  139. package/dist/mcps/state-manager.server.js +115 -160
  140. package/dist/orchestrator/orchestrator.d.ts +1 -1
  141. package/dist/orchestrator/orchestrator.js +1 -1
  142. package/dist/orchestrator/universal-registry-bridge.js +1 -1
  143. package/dist/plugin/xray-codex-injection.d.ts +1 -1
  144. package/dist/plugin/xray-codex-injection.js +1 -1
  145. package/dist/postprocessor/PostProcessor.d.ts +4 -44
  146. package/dist/postprocessor/PostProcessor.js +39 -553
  147. package/dist/postprocessor/analysis/CodeChangeAnalyzer.d.ts +11 -0
  148. package/dist/postprocessor/analysis/CodeChangeAnalyzer.js +50 -0
  149. package/dist/postprocessor/compliance/ArchitecturalComplianceChecker.d.ts +11 -0
  150. package/dist/postprocessor/compliance/ArchitecturalComplianceChecker.js +356 -0
  151. package/dist/postprocessor/config/ProcessorConfigLoader.d.ts +44 -0
  152. package/dist/postprocessor/config/ProcessorConfigLoader.js +21 -0
  153. package/dist/postprocessor/reporting/PostProcessorReporter.d.ts +19 -0
  154. package/dist/postprocessor/reporting/PostProcessorReporter.js +96 -0
  155. package/dist/postprocessor/triggers/GitHookTrigger.js +11 -11
  156. package/dist/processors/implementations/refactoring-logging-processor-wrapper.d.ts +32 -0
  157. package/dist/processors/implementations/refactoring-logging-processor-wrapper.js +95 -1
  158. package/dist/processors/processor-manager.js +346 -314
  159. package/dist/reporting/report-formatter.js +1 -1
  160. package/dist/security/security-hardener.d.ts +69 -2
  161. package/dist/security/security-hardener.js +129 -1
  162. package/dist/skills/registry.json +1 -1
  163. package/dist/state/index.d.ts +3 -5
  164. package/dist/state/index.js +1 -7
  165. package/dist/state/state-manager.d.ts +1 -1
  166. package/dist/state/state-manager.js +2 -3
  167. package/package.json +14 -10
  168. package/scripts/node/setup.cjs +32 -0
  169. package/scripts/node/universal-version-manager.js +11 -11
  170. package/src/mcps/architect-tools.server.ts +112 -215
  171. package/src/mcps/auto-format.server.ts +50 -110
  172. package/src/mcps/boot-orchestrator.server.ts +75 -121
  173. package/src/mcps/config/__tests__/server-config-registry.test.ts +21 -12
  174. package/src/mcps/config/server-config-registry.ts +3 -3
  175. package/src/mcps/enforcer-tools.server.ts +212 -310
  176. package/src/mcps/estimation.server.ts +62 -122
  177. package/src/mcps/framework-compliance-audit.server.ts +52 -97
  178. package/src/mcps/framework-help.server.ts +64 -114
  179. package/src/mcps/governance.server.ts +2 -2
  180. package/src/mcps/knowledge-skills/api-design.server.ts +32 -77
  181. package/src/mcps/knowledge-skills/architecture-patterns.server.ts +31 -87
  182. package/src/mcps/knowledge-skills/bug-triage-specialist.server.ts +165 -193
  183. package/src/mcps/knowledge-skills/code-analyzer.server.ts +20 -55
  184. package/src/mcps/knowledge-skills/code-review.server.ts +114 -161
  185. package/src/mcps/knowledge-skills/content-creator.server.ts +218 -255
  186. package/src/mcps/knowledge-skills/database-design.server.ts +118 -165
  187. package/src/mcps/knowledge-skills/devops-deployment.server.ts +67 -172
  188. package/src/mcps/knowledge-skills/git-workflow.server.ts +32 -77
  189. package/src/mcps/knowledge-skills/growth-strategist.server.ts +324 -361
  190. package/src/mcps/knowledge-skills/log-monitor.server.ts +160 -187
  191. package/src/mcps/knowledge-skills/mobile-development.server.ts +89 -223
  192. package/src/mcps/knowledge-skills/multimodal-looker.server.ts +128 -175
  193. package/src/mcps/knowledge-skills/performance-optimization.server.ts +156 -329
  194. package/src/mcps/knowledge-skills/project-analysis.server.ts +72 -248
  195. package/src/mcps/knowledge-skills/refactoring-strategies.server.ts +59 -171
  196. package/src/mcps/knowledge-skills/security-audit.server.ts +104 -151
  197. package/src/mcps/knowledge-skills/seo-consultant.server.ts +80 -220
  198. package/src/mcps/knowledge-skills/session-management.server.ts +51 -232
  199. package/src/mcps/knowledge-skills/skill-invocation.server.ts +165 -372
  200. package/src/mcps/knowledge-skills/strategist.server.ts +72 -143
  201. package/src/mcps/knowledge-skills/tech-writer.server.ts +85 -350
  202. package/src/mcps/knowledge-skills/testing-best-practices.server.ts +146 -195
  203. package/src/mcps/knowledge-skills/testing-strategy.server.ts +75 -161
  204. package/src/mcps/knowledge-skills/ui-ux-design.server.ts +93 -487
  205. package/src/mcps/lint.server.ts +53 -107
  206. package/src/mcps/mcp-client.ts +2 -2
  207. package/src/mcps/model-health-check.server.ts +34 -71
  208. package/src/mcps/performance-analysis.server.ts +60 -104
  209. package/src/mcps/processor-pipeline.server.ts +72 -110
  210. package/src/mcps/registry.json +1 -1
  211. package/src/mcps/researcher.server.ts +88 -177
  212. package/src/mcps/security-scan.server.ts +55 -104
  213. package/src/mcps/shared/knowledge-skill-base.ts +62 -0
  214. package/src/mcps/shared/prompt-security-validator.ts +199 -0
  215. package/src/mcps/shared/security-scanner.ts +599 -0
  216. package/src/mcps/state-manager.server.ts +117 -175
  217. package/src/opencode/codex.codex +1 -1
  218. package/src/opencode/commands/dependency-audit.md +3 -3
  219. package/src/opencode/enforcer-config.json +2 -2
  220. package/src/skills/registry.json +1 -1
  221. package/xray/agents_template.md +109 -0
  222. package/xray/codex.json +598 -0
  223. package/xray/config.json +26 -0
  224. package/xray/features.json +132 -0
  225. package/xray/integrations.json +23 -0
  226. package/xray/routing-mappings.json +752 -0
  227. package/xray/workflow_state.json +28 -0
  228. package/dist/integrations/hermes-agent/__pycache__/__init__.cpython-313.pyc +0 -0
  229. package/dist/integrations/hermes-agent/__pycache__/conftest.cpython-313-pytest-9.0.2.pyc +0 -0
  230. package/dist/integrations/hermes-agent/__pycache__/schemas.cpython-313.pyc +0 -0
  231. package/dist/integrations/hermes-agent/__pycache__/test_plugin.cpython-313-pytest-9.0.2.pyc +0 -0
  232. package/dist/integrations/hermes-agent/__pycache__/test_plugin.cpython-313.pyc +0 -0
  233. package/dist/integrations/hermes-agent/__pycache__/tools.cpython-313.pyc +0 -0
  234. package/dist/integrations/hermes-agent/conftest.py +0 -14
  235. package/dist/integrations/hermes-agent/test_plugin.py +0 -1103
  236. package/dist/processors/implementations/refactoring-logging-processor.d.ts +0 -31
  237. package/dist/processors/implementations/refactoring-logging-processor.js +0 -96
  238. package/dist/processors/implementations/session-capture-processor.d.ts +0 -14
  239. package/dist/processors/implementations/session-capture-processor.js +0 -37
  240. package/dist/scripts/activate-kernel-pipeline.d.ts +0 -7
  241. package/dist/scripts/activate-kernel-pipeline.js +0 -101
  242. package/dist/security/index.d.ts +0 -13
  243. package/dist/security/index.js +0 -13
  244. package/dist/security/security-agent-coordinator.d.ts +0 -72
  245. package/dist/security/security-agent-coordinator.js +0 -204
  246. package/dist/security/security-auditor.d.ts +0 -56
  247. package/dist/security/security-auditor.js +0 -584
  248. package/dist/security/security-hardening-system.d.ts +0 -239
  249. package/dist/security/security-hardening-system.js +0 -727
  250. package/dist/security/security-orchestration-layer.d.ts +0 -119
  251. package/dist/security/security-orchestration-layer.js +0 -496
  252. /package/dist/{security → mcps/shared}/prompt-security-validator.d.ts +0 -0
  253. /package/dist/{security → mcps/shared}/prompt-security-validator.js +0 -0
  254. /package/dist/{security → mcps/shared}/security-scanner.d.ts +0 -0
@@ -4,190 +4,164 @@
4
4
  * Knowledge skill for comprehensive testing strategies, TDD/BDD implementation,
5
5
  * test coverage optimization, and automated testing workflows
6
6
  */
7
- import { Server } from "@modelcontextprotocol/sdk/server/index.js";
8
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
9
- import { createGracefulShutdown } from "../../utils/shutdown-handler.js";
10
- import { CallToolRequestSchema, ListToolsRequestSchema, } from "@modelcontextprotocol/sdk/types.js";
11
- class XrayTestingBestPracticesServer {
12
- server;
7
+ import { XrayKnowledgeSkillBase } from "../shared/knowledge-skill-base.js";
8
+ import { frameworkLogger } from "../../core/framework-logger.js";
9
+ class XrayTestingBestPracticesServer extends XrayKnowledgeSkillBase {
13
10
  constructor() {
14
- this.server = new Server({
15
- name: "testing-best-practices", version: "2.0.1",
16
- }, {
17
- capabilities: {
18
- tools: {},
19
- },
20
- });
21
- this.setupToolHandlers();
22
- // Server initialization - removed unnecessary startup logging
23
- }
24
- setupToolHandlers() {
25
- this.server.setRequestHandler(ListToolsRequestSchema, async () => {
26
- return {
27
- tools: [
28
- {
29
- name: "analyze_test_coverage",
30
- description: "Analyze current test coverage and identify gaps",
31
- inputSchema: {
32
- type: "object",
33
- properties: {
34
- codePath: {
35
- type: "string",
36
- description: "Path to codebase to analyze",
37
- },
38
- testFramework: {
39
- type: "string",
40
- description: "Testing framework used (jest, vitest, mocha, etc.)",
41
- default: "auto-detect",
42
- },
43
- coverageThreshold: {
44
- type: "number",
45
- description: "Minimum coverage threshold (0-100)",
46
- default: 80,
47
- },
48
- },
49
- required: ["codePath"],
11
+ super("testing-best-practices", "2.0.1");
12
+ this.tools = [
13
+ {
14
+ name: "analyze_test_coverage",
15
+ description: "Analyze current test coverage and identify gaps",
16
+ inputSchema: {
17
+ type: "object",
18
+ properties: {
19
+ codePath: {
20
+ type: "string",
21
+ description: "Path to codebase to analyze",
22
+ },
23
+ testFramework: {
24
+ type: "string",
25
+ description: "Testing framework used (jest, vitest, mocha, etc.)",
26
+ default: "auto-detect",
27
+ },
28
+ coverageThreshold: {
29
+ type: "number",
30
+ description: "Minimum coverage threshold (0-100)",
31
+ default: 80,
50
32
  },
51
33
  },
52
- {
53
- name: "design_test_strategy",
54
- description: "Design comprehensive testing strategy for a project",
55
- inputSchema: {
56
- type: "object",
57
- properties: {
58
- projectType: {
59
- type: "string",
60
- enum: ["web-app", "api", "library", "mobile", "desktop"],
61
- description: "Type of project",
62
- },
63
- techStack: {
64
- type: "array",
65
- items: { type: "string" },
66
- description: "Technologies used (react, node, typescript, etc.)",
67
- },
68
- teamSize: {
69
- type: "string",
70
- enum: ["solo", "small", "medium", "large"],
71
- description: "Development team size",
72
- },
73
- timeline: {
74
- type: "string",
75
- enum: ["rapid", "balanced", "thorough"],
76
- description: "Development timeline priority",
77
- },
78
- },
79
- required: ["projectType"],
34
+ required: ["codePath"],
35
+ },
36
+ },
37
+ {
38
+ name: "design_test_strategy",
39
+ description: "Design comprehensive testing strategy for a project",
40
+ inputSchema: {
41
+ type: "object",
42
+ properties: {
43
+ projectType: {
44
+ type: "string",
45
+ enum: ["web-app", "api", "library", "mobile", "desktop"],
46
+ description: "Type of project",
47
+ },
48
+ techStack: {
49
+ type: "array",
50
+ items: { type: "string" },
51
+ description: "Technologies used (react, node, typescript, etc.)",
52
+ },
53
+ teamSize: {
54
+ type: "string",
55
+ enum: ["solo", "small", "medium", "large"],
56
+ description: "Development team size",
57
+ },
58
+ timeline: {
59
+ type: "string",
60
+ enum: ["rapid", "balanced", "thorough"],
61
+ description: "Development timeline priority",
80
62
  },
81
63
  },
82
- {
83
- name: "implement_tdd_workflow",
84
- description: "Implement Test-Driven Development workflow and practices",
85
- inputSchema: {
86
- type: "object",
87
- properties: {
88
- language: {
89
- type: "string",
90
- description: "Programming language",
91
- default: "typescript",
92
- },
93
- framework: {
94
- type: "string",
95
- description: "Preferred testing framework",
96
- default: "jest",
97
- },
98
- existingTests: {
99
- type: "boolean",
100
- description: "Whether tests already exist",
101
- default: false,
102
- },
103
- },
104
- required: [],
64
+ required: ["projectType"],
65
+ },
66
+ },
67
+ {
68
+ name: "implement_tdd_workflow",
69
+ description: "Implement Test-Driven Development workflow and practices",
70
+ inputSchema: {
71
+ type: "object",
72
+ properties: {
73
+ language: {
74
+ type: "string",
75
+ description: "Programming language",
76
+ default: "typescript",
77
+ },
78
+ framework: {
79
+ type: "string",
80
+ description: "Preferred testing framework",
81
+ default: "jest",
82
+ },
83
+ existingTests: {
84
+ type: "boolean",
85
+ description: "Whether tests already exist",
86
+ default: false,
105
87
  },
106
88
  },
107
- {
108
- name: "optimize_test_performance",
109
- description: "Analyze and optimize test execution performance",
110
- inputSchema: {
111
- type: "object",
112
- properties: {
113
- testResults: {
114
- type: "string",
115
- description: "Path to test results or current execution time",
116
- },
117
- targetRuntime: {
118
- type: "number",
119
- description: "Target test execution time in seconds",
120
- default: 300,
121
- },
122
- parallelExecution: {
123
- type: "boolean",
124
- description: "Whether parallel execution is supported",
125
- default: true,
126
- },
127
- },
128
- required: ["testResults"],
89
+ required: [],
90
+ },
91
+ },
92
+ {
93
+ name: "optimize_test_performance",
94
+ description: "Analyze and optimize test execution performance",
95
+ inputSchema: {
96
+ type: "object",
97
+ properties: {
98
+ testResults: {
99
+ type: "string",
100
+ description: "Path to test results or current execution time",
101
+ },
102
+ targetRuntime: {
103
+ type: "number",
104
+ description: "Target test execution time in seconds",
105
+ default: 300,
106
+ },
107
+ parallelExecution: {
108
+ type: "boolean",
109
+ description: "Whether parallel execution is supported",
110
+ default: true,
129
111
  },
130
112
  },
131
- {
132
- name: "setup_ci_cd_testing",
133
- description: "Set up comprehensive CI/CD testing pipeline",
134
- inputSchema: {
135
- type: "object",
136
- properties: {
137
- ciPlatform: {
138
- type: "string",
139
- enum: [
140
- "github-actions",
141
- "gitlab-ci",
142
- "jenkins",
143
- "circle-ci",
144
- "travis-ci",
145
- ],
146
- description: "CI/CD platform",
147
- },
148
- testTypes: {
149
- type: "array",
150
- items: {
151
- type: "string",
152
- enum: [
153
- "unit",
154
- "integration",
155
- "e2e",
156
- "performance",
157
- "security",
158
- ],
159
- },
160
- description: "Types of tests to include",
161
- },
162
- coverageReporting: {
163
- type: "boolean",
164
- description: "Enable coverage reporting",
165
- default: true,
166
- },
113
+ required: ["testResults"],
114
+ },
115
+ },
116
+ {
117
+ name: "setup_ci_cd_testing",
118
+ description: "Set up comprehensive CI/CD testing pipeline",
119
+ inputSchema: {
120
+ type: "object",
121
+ properties: {
122
+ ciPlatform: {
123
+ type: "string",
124
+ enum: [
125
+ "github-actions",
126
+ "gitlab-ci",
127
+ "jenkins",
128
+ "circle-ci",
129
+ "travis-ci",
130
+ ],
131
+ description: "CI/CD platform",
132
+ },
133
+ testTypes: {
134
+ type: "array",
135
+ items: {
136
+ type: "string",
137
+ enum: [
138
+ "unit",
139
+ "integration",
140
+ "e2e",
141
+ "performance",
142
+ "security",
143
+ ],
167
144
  },
168
- required: ["ciPlatform", "testTypes"],
145
+ description: "Types of tests to include",
146
+ },
147
+ coverageReporting: {
148
+ type: "boolean",
149
+ description: "Enable coverage reporting",
150
+ default: true,
169
151
  },
170
152
  },
171
- ],
172
- };
173
- });
174
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
175
- const { name, arguments: args } = request.params;
176
- switch (name) {
177
- case "analyze_test_coverage":
178
- return await this.analyzeTestCoverage(args);
179
- case "design_test_strategy":
180
- return await this.designTestStrategy(args);
181
- case "implement_tdd_workflow":
182
- return await this.implementTDDWorkflow(args);
183
- case "optimize_test_performance":
184
- return await this.optimizeTestPerformance(args);
185
- case "setup_ci_cd_testing":
186
- return await this.setupCICDTesting(args);
187
- default:
188
- throw new Error(`Unknown tool: ${name}`);
189
- }
190
- });
153
+ required: ["ciPlatform", "testTypes"],
154
+ },
155
+ },
156
+ ];
157
+ this.handlers = {
158
+ "analyze_test_coverage": async (args) => this.analyzeTestCoverage(args),
159
+ "design_test_strategy": async (args) => this.designTestStrategy(args),
160
+ "implement_tdd_workflow": async (args) => this.implementTDDWorkflow(args),
161
+ "optimize_test_performance": async (args) => this.optimizeTestPerformance(args),
162
+ "setup_ci_cd_testing": async (args) => this.setupCICDTesting(args),
163
+ };
164
+ this.setupToolHandlers();
191
165
  }
192
166
  async analyzeTestCoverage(args) {
193
167
  const { codePath, testFramework = "auto-detect", coverageThreshold = 80, } = args;
@@ -848,19 +822,10 @@ class XrayTestingBestPracticesServer {
848
822
  };
849
823
  return icons[type] || "🧪";
850
824
  }
851
- async run() {
852
- const transport = new StdioServerTransport();
853
- await this.server.connect(transport);
854
- // Use centralized shutdown handler
855
- createGracefulShutdown({
856
- serverName: "testing-best-practices.server",
857
- server: this.server,
858
- });
859
- }
860
825
  }
861
826
  // Run the server if this file is executed directly
862
827
  if (import.meta.url === `file://${process.argv[1]}`) {
863
828
  const server = new XrayTestingBestPracticesServer();
864
- server.run().catch(() => { });
829
+ server.run("testing-best-practices").catch((err) => { frameworkLogger.log("testing-best-practices", "run", "error", { error: err instanceof Error ? err.message : String(err) }); });
865
830
  }
866
831
  export { XrayTestingBestPracticesServer };
@@ -4,10 +4,9 @@
4
4
  * Knowledge skill for test planning, coverage optimization,
5
5
  * and testing methodology recommendations
6
6
  */
7
- declare class XrayTestingStrategyServer {
8
- private server;
7
+ import { XrayKnowledgeSkillBase } from "../shared/knowledge-skill-base.js";
8
+ declare class XrayTestingStrategyServer extends XrayKnowledgeSkillBase {
9
9
  constructor();
10
- private setupToolHandlers;
11
10
  private analyzeTestCoverage;
12
11
  private designTestStrategy;
13
12
  private identifyTestGaps;
@@ -42,6 +41,5 @@ declare class XrayTestingStrategyServer {
42
41
  private calculateOptimizationROI;
43
42
  private generateMilestones;
44
43
  private shouldIgnorePath;
45
- run(): Promise<void>;
46
44
  }
47
45
  export default XrayTestingStrategyServer;
@@ -4,159 +4,93 @@
4
4
  * Knowledge skill for test planning, coverage optimization,
5
5
  * and testing methodology recommendations
6
6
  */
7
- import { Server } from "@modelcontextprotocol/sdk/server/index.js";
8
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
9
- import { CallToolRequestSchema, ListToolsRequestSchema, } from "@modelcontextprotocol/sdk/types.js";
7
+ import { XrayKnowledgeSkillBase } from "../shared/knowledge-skill-base.js";
10
8
  import * as fs from "fs";
11
9
  import * as path from "path";
12
10
  import { frameworkLogger } from "../../core/framework-logger.js";
13
- import { createGracefulShutdown } from "../../utils/shutdown-handler.js";
14
11
  import { detectProjectLanguage, LANGUAGE_CONFIGS, } from "../../utils/language-detector.js";
15
- class XrayTestingStrategyServer {
16
- server;
12
+ class XrayTestingStrategyServer extends XrayKnowledgeSkillBase {
17
13
  constructor() {
18
- this.server = new Server({
19
- name: "testing-strategy", version: "2.0.1",
20
- }, {
21
- capabilities: {
22
- tools: {},
23
- },
24
- });
25
- this.setupToolHandlers();
26
- // Server initialization - removed unnecessary startup logging
27
- }
28
- setupToolHandlers() {
29
- this.server.setRequestHandler(ListToolsRequestSchema, async () => {
30
- return {
31
- tools: [
32
- {
33
- name: "analyze-test-coverage",
34
- description: "Analyze current test coverage and identify gaps",
35
- inputSchema: {
36
- type: "object",
37
- properties: {
38
- projectRoot: { type: "string" },
39
- includeBreakdown: { type: "boolean", default: true },
40
- coverageThreshold: { type: "number", default: 80 },
41
- },
42
- required: ["projectRoot"],
43
- },
14
+ super("testing-strategy", "2.0.1");
15
+ this.tools = [
16
+ {
17
+ name: "analyze-test-coverage",
18
+ description: "Analyze current test coverage and identify gaps",
19
+ inputSchema: {
20
+ type: "object",
21
+ properties: {
22
+ projectRoot: { type: "string" },
23
+ includeBreakdown: { type: "boolean", default: true },
24
+ coverageThreshold: { type: "number", default: 80 },
44
25
  },
45
- {
46
- name: "design-test-strategy",
47
- description: "Design comprehensive testing strategy for the project",
48
- inputSchema: {
49
- type: "object",
50
- properties: {
51
- projectRoot: { type: "string" },
52
- projectType: {
53
- type: "string",
54
- enum: ["web", "api", "mobile", "desktop"],
55
- },
56
- complexity: {
57
- type: "string",
58
- enum: ["simple", "medium", "complex"],
59
- },
60
- timeline: {
61
- type: "string",
62
- enum: ["agile", "waterfall", "continuous"],
63
- },
64
- },
65
- required: ["projectRoot"],
66
- },
26
+ required: ["projectRoot"],
27
+ },
28
+ },
29
+ {
30
+ name: "design-test-strategy",
31
+ description: "Design comprehensive testing strategy for the project",
32
+ inputSchema: {
33
+ type: "object",
34
+ properties: {
35
+ projectRoot: { type: "string" },
36
+ projectType: { type: "string", enum: ["web", "api", "mobile", "desktop"] },
37
+ complexity: { type: "string", enum: ["simple", "medium", "complex"] },
38
+ timeline: { type: "string", enum: ["agile", "waterfall", "continuous"] },
67
39
  },
68
- {
69
- name: "identify-test-gaps",
70
- description: "Identify untested code and recommend test cases",
71
- inputSchema: {
72
- type: "object",
73
- properties: {
74
- projectRoot: { type: "string" },
75
- sourceFiles: { type: "array", items: { type: "string" } },
76
- existingTests: { type: "array", items: { type: "string" } },
77
- },
78
- required: ["projectRoot"],
79
- },
40
+ required: ["projectRoot"],
41
+ },
42
+ },
43
+ {
44
+ name: "identify-test-gaps",
45
+ description: "Identify untested code and recommend test cases",
46
+ inputSchema: {
47
+ type: "object",
48
+ properties: {
49
+ projectRoot: { type: "string" },
50
+ sourceFiles: { type: "array", items: { type: "string" } },
51
+ existingTests: { type: "array", items: { type: "string" } },
80
52
  },
81
- {
82
- name: "optimize-test-coverage",
83
- description: "Analyze and optimize test coverage patterns",
84
- inputSchema: {
85
- type: "object",
86
- properties: {
87
- projectRoot: { type: "string" },
88
- currentCoverage: { type: "number" },
89
- targetCoverage: { type: "number", default: 85 },
90
- focusAreas: { type: "array", items: { type: "string" } },
91
- },
92
- required: ["projectRoot"],
93
- },
53
+ required: ["projectRoot"],
54
+ },
55
+ },
56
+ {
57
+ name: "optimize-test-coverage",
58
+ description: "Analyze and optimize test coverage patterns",
59
+ inputSchema: {
60
+ type: "object",
61
+ properties: {
62
+ projectRoot: { type: "string" },
63
+ currentCoverage: { type: "number" },
64
+ targetCoverage: { type: "number", default: 85 },
65
+ focusAreas: { type: "array", items: { type: "string" } },
94
66
  },
95
- {
96
- name: "generate-test-file",
97
- description: "Generate test file for a source file with exports",
98
- inputSchema: {
99
- type: "object",
100
- properties: {
101
- sourceFile: {
102
- type: "string",
103
- description: "Path to source file",
104
- },
105
- sourceContent: {
106
- type: "string",
107
- description: "Source file content",
108
- },
109
- exports: {
110
- type: "array",
111
- items: {
112
- type: "object",
113
- properties: {
114
- name: { type: "string" },
115
- type: { type: "string" },
116
- },
117
- },
118
- description: "Exported functions/classes to test",
119
- },
120
- testFilePath: {
121
- type: "string",
122
- description: "Path for generated test file",
123
- },
124
- directory: { type: "string", description: "Project directory" },
125
- },
126
- required: [
127
- "sourceFile",
128
- "sourceContent",
129
- "exports",
130
- "testFilePath",
131
- ],
132
- },
67
+ required: ["projectRoot"],
68
+ },
69
+ },
70
+ {
71
+ name: "generate-test-file",
72
+ description: "Generate test file for a source file with exports",
73
+ inputSchema: {
74
+ type: "object",
75
+ properties: {
76
+ sourceFile: { type: "string", description: "Path to source file" },
77
+ sourceContent: { type: "string", description: "Source file content" },
78
+ exports: { type: "array", items: { type: "object", properties: { name: { type: "string" }, type: { type: "string" } } }, description: "Exported functions/classes to test" },
79
+ testFilePath: { type: "string", description: "Path for generated test file" },
80
+ directory: { type: "string", description: "Project directory" },
133
81
  },
134
- ],
135
- };
136
- });
137
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
138
- const { name, arguments: args } = request.params;
139
- try {
140
- switch (name) {
141
- case "analyze-test-coverage":
142
- return await this.analyzeTestCoverage(args);
143
- case "design-test-strategy":
144
- return await this.designTestStrategy(args);
145
- case "identify-test-gaps":
146
- return await this.identifyTestGaps(args);
147
- case "optimize-test-coverage":
148
- return await this.optimizeTestCoverage(args);
149
- case "generate-test-file":
150
- return await this.generateTestFile(args);
151
- default:
152
- throw new Error(`Unknown tool: ${name}`);
153
- }
154
- }
155
- catch (error) {
156
- frameworkLogger.log("mcps/testing-strategy", "tool", "error", { tool: name, error: String(error) });
157
- throw error;
158
- }
159
- });
82
+ required: ["sourceFile", "sourceContent", "exports", "testFilePath"],
83
+ },
84
+ },
85
+ ];
86
+ this.handlers = {
87
+ "analyze-test-coverage": async (args) => this.analyzeTestCoverage(args),
88
+ "design-test-strategy": async (args) => this.designTestStrategy(args),
89
+ "identify-test-gaps": async (args) => this.identifyTestGaps(args),
90
+ "optimize-test-coverage": async (args) => this.optimizeTestCoverage(args),
91
+ "generate-test-file": async (args) => this.generateTestFile(args),
92
+ };
93
+ this.setupToolHandlers();
160
94
  }
161
95
  async analyzeTestCoverage(args) {
162
96
  const { projectRoot, includeBreakdown = true, coverageThreshold = 80, } = args;
@@ -809,19 +743,10 @@ describe("${pathModule.basename(sourceFile, ".ts")}", () => {${testCases}
809
743
  ];
810
744
  return ignorePatterns.some((pattern) => pattern.test(filePath));
811
745
  }
812
- async run() {
813
- const transport = new StdioServerTransport();
814
- await this.server.connect(transport);
815
- // Use centralized shutdown handler
816
- createGracefulShutdown({
817
- serverName: "testing-strategy.server",
818
- server: this.server,
819
- });
820
- }
821
746
  }
822
747
  // Start the server if run directly
823
748
  if (import.meta.url === `file://${process.argv[1]}`) {
824
749
  const server = new XrayTestingStrategyServer();
825
- server.run().catch(() => { });
750
+ server.run("testing-strategy").catch((err) => { frameworkLogger.log("testing-strategy", "run", "error", { error: err instanceof Error ? err.message : String(err) }); });
826
751
  }
827
752
  export default XrayTestingStrategyServer;