@stackmemoryai/stackmemory 0.3.8 → 0.3.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. package/README.md +53 -0
  2. package/dist/agents/core/agent-task-manager.js +12 -1
  3. package/dist/agents/core/agent-task-manager.js.map +3 -3
  4. package/dist/agents/testing-agent.js +610 -0
  5. package/dist/agents/testing-agent.js.map +7 -0
  6. package/dist/cli/claude-sm.js +2 -2
  7. package/dist/cli/claude-sm.js.map +2 -2
  8. package/dist/cli/codex-sm.js +2 -2
  9. package/dist/cli/codex-sm.js.map +2 -2
  10. package/dist/cli/commands/handoff.js +65 -18
  11. package/dist/cli/commands/handoff.js.map +3 -3
  12. package/dist/cli/commands/onboard.js +3 -3
  13. package/dist/cli/commands/onboard.js.map +2 -2
  14. package/dist/cli/commands/quality.js +2 -2
  15. package/dist/cli/commands/quality.js.map +2 -2
  16. package/dist/cli/commands/skills.js +113 -28
  17. package/dist/cli/commands/skills.js.map +2 -2
  18. package/dist/cli/commands/test.js +282 -0
  19. package/dist/cli/commands/test.js.map +7 -0
  20. package/dist/cli/commands/worktree.js +28 -10
  21. package/dist/cli/commands/worktree.js.map +2 -2
  22. package/dist/cli/index.js +2 -0
  23. package/dist/cli/index.js.map +2 -2
  24. package/dist/core/config/config-manager.js +26 -0
  25. package/dist/core/config/config-manager.js.map +3 -3
  26. package/dist/core/context/frame-manager.js +139 -0
  27. package/dist/core/context/frame-manager.js.map +2 -2
  28. package/dist/core/context/recursive-context-manager.js +582 -0
  29. package/dist/core/context/recursive-context-manager.js.map +7 -0
  30. package/dist/core/context/refactored-frame-manager.js +180 -1
  31. package/dist/core/context/refactored-frame-manager.js.map +2 -2
  32. package/dist/core/execution/parallel-executor.js +254 -0
  33. package/dist/core/execution/parallel-executor.js.map +7 -0
  34. package/dist/core/utils/update-checker.js +2 -2
  35. package/dist/core/utils/update-checker.js.map +2 -2
  36. package/dist/integrations/anthropic/client.js +259 -0
  37. package/dist/integrations/anthropic/client.js.map +7 -0
  38. package/dist/integrations/claude-code/subagent-client-stub.js +16 -0
  39. package/dist/integrations/claude-code/subagent-client-stub.js.map +7 -0
  40. package/dist/integrations/claude-code/subagent-client.js +404 -0
  41. package/dist/integrations/claude-code/subagent-client.js.map +7 -0
  42. package/dist/skills/claude-skills.js +191 -0
  43. package/dist/skills/claude-skills.js.map +2 -2
  44. package/dist/skills/recursive-agent-orchestrator.js +559 -0
  45. package/dist/skills/recursive-agent-orchestrator.js.map +7 -0
  46. package/dist/skills/security-secrets-scanner.js +280 -0
  47. package/dist/skills/security-secrets-scanner.js.map +7 -0
  48. package/dist/skills/unified-rlm-orchestrator.js +400 -0
  49. package/dist/skills/unified-rlm-orchestrator.js.map +7 -0
  50. package/package.json +3 -2
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/cli/commands/skills.ts"],
4
- "sourcesContent": ["#!/usr/bin/env node\n/**\n * Claude Skills CLI Commands\n * Integrates Claude skills into the stackmemory CLI\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport {\n ClaudeSkillsManager,\n type SkillContext,\n} from '../../skills/claude-skills.js';\nimport { DualStackManager } from '../../core/context/dual-stack-manager.js';\nimport { FrameHandoffManager } from '../../core/context/frame-handoff-manager.js';\nimport { ContextRetriever } from '../../core/retrieval/context-retriever.js';\nimport { SQLiteAdapter } from '../../core/database/sqlite-adapter.js';\nimport { ConfigManager } from '../../core/config/config-manager.js';\nimport * as path from 'path';\nimport * as os from 'os';\n// Type-safe environment variable access\nfunction getEnv(key: string, defaultValue?: string): string {\n const value = process.env[key];\n if (value === undefined) {\n if (defaultValue !== undefined) return defaultValue;\n throw new Error(`Environment variable ${key} is required`);\n }\n return value;\n}\n\nfunction getOptionalEnv(key: string): string | undefined {\n return process.env[key];\n}\n\nasync function initializeSkillContext(): Promise<SkillContext> {\n const config = ConfigManager.getInstance();\n const projectId = config.get('project.id');\n const userId = config.get('user.id') || process.env['USER'] || 'default';\n\n const dbPath = path.join(\n os.homedir(),\n '.stackmemory',\n 'data',\n projectId,\n 'stackmemory.db'\n );\n\n const database = new SQLiteAdapter(projectId, { dbPath });\n await database.connect();\n\n const dualStackManager = new DualStackManager(database, projectId, userId);\n const handoffManager = new FrameHandoffManager(dualStackManager);\n const contextRetriever = new ContextRetriever(database);\n\n return {\n projectId,\n userId,\n dualStackManager,\n handoffManager,\n contextRetriever,\n database,\n };\n}\n\nexport function createSkillsCommand(): Command {\n const skillsCmd = new Command('skills').description(\n 'Execute Claude skills for enhanced workflow'\n );\n\n // Handoff skill command\n skillsCmd\n .command('handoff <targetUser> <message>')\n .description('Streamline frame handoffs between team members')\n .option(\n '-p, --priority <level>',\n 'Set priority (low, medium, high, critical)',\n 'medium'\n )\n .option('-f, --frames <frames...>', 'Specific frames to handoff')\n .option('--no-auto-detect', 'Disable auto-detection of frames')\n .action(async (targetUser, message, options) => {\n const spinner = ora('Initiating handoff...').start();\n\n try {\n const context = await initializeSkillContext();\n const skillsManager = new ClaudeSkillsManager(context);\n\n const result = await skillsManager.executeSkill(\n 'handoff',\n [targetUser, message],\n {\n priority: options.priority,\n frames: options.frames,\n autoDetect: options.autoDetect !== false,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nHandoff Details:'));\n console.log(` ID: ${result.data.handoffId}`);\n console.log(` Frames: ${result.data.frameCount}`);\n console.log(` Priority: ${result.data.priority}`);\n if (result.data.actionItems?.length > 0) {\n console.log(chalk.yellow('\\n Action Items:'));\n result.data.actionItems.forEach((item) => {\n console.log(` \u2022 ${item}`);\n });\n }\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Checkpoint skill commands\n const checkpointCmd = skillsCmd\n .command('checkpoint')\n .description('Create and manage recovery points');\n\n checkpointCmd\n .command('create <description>')\n .description('Create a new checkpoint')\n .option('--files <files...>', 'Include specific files in checkpoint')\n .option('--auto-detect-risky', 'Auto-detect risky operations')\n .action(async (description, options) => {\n const spinner = ora('Creating checkpoint...').start();\n\n try {\n const context = await initializeSkillContext();\n const skillsManager = new ClaudeSkillsManager(context);\n\n const result = await skillsManager.executeSkill(\n 'checkpoint',\n ['create', description],\n {\n includeFiles: options.files,\n autoDetectRisky: options.autoDetectRisky,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nCheckpoint Info:'));\n console.log(` ID: ${result.data.checkpointId}`);\n console.log(` Time: ${result.data.timestamp}`);\n console.log(` Frames: ${result.data.frameCount}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('restore <checkpointId>')\n .description('Restore from a checkpoint')\n .action(async (checkpointId) => {\n const spinner = ora('Restoring checkpoint...').start();\n\n try {\n const context = await initializeSkillContext();\n const skillsManager = new ClaudeSkillsManager(context);\n\n const result = await skillsManager.executeSkill('checkpoint', [\n 'restore',\n checkpointId,\n ]);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nRestored:'));\n console.log(` Frames: ${result.data.frameCount}`);\n console.log(` Files: ${result.data.filesRestored}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('list')\n .description('List available checkpoints')\n .option('-l, --limit <number>', 'Limit number of results', '10')\n .option('-s, --since <date>', 'Show checkpoints since date')\n .action(async (options) => {\n const spinner = ora('Loading checkpoints...').start();\n\n try {\n const context = await initializeSkillContext();\n const skillsManager = new ClaudeSkillsManager(context);\n\n const result = await skillsManager.executeSkill(\n 'checkpoint',\n ['list'],\n {\n limit: parseInt(options.limit),\n since: options.since ? new Date(options.since) : undefined,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.cyan('Available Checkpoints:\\n'));\n if (result.data && result.data.length > 0) {\n result.data.forEach((cp: any) => {\n const riskIndicator = cp.risky ? chalk.yellow(' [RISKY]') : '';\n console.log(`${chalk.bold(cp.id)}${riskIndicator}`);\n console.log(` ${cp.description}`);\n console.log(\n chalk.gray(` ${cp.timestamp} (${cp.frameCount} frames)\\n`)\n );\n });\n } else {\n console.log(chalk.gray('No checkpoints found'));\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('diff <checkpoint1> <checkpoint2>')\n .description('Show differences between two checkpoints')\n .action(async (checkpoint1, checkpoint2) => {\n const spinner = ora('Comparing checkpoints...').start();\n\n try {\n const context = await initializeSkillContext();\n const skillsManager = new ClaudeSkillsManager(context);\n\n const result = await skillsManager.executeSkill('checkpoint', [\n 'diff',\n checkpoint1,\n checkpoint2,\n ]);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.cyan('Checkpoint Diff:\\n'));\n if (result.data) {\n console.log(` Time difference: ${result.data.timeDiff}`);\n console.log(` Frame difference: ${result.data.framesDiff}`);\n console.log(` New frames: ${result.data.newFrames}`);\n console.log(` Removed frames: ${result.data.removedFrames}`);\n console.log(` Modified frames: ${result.data.modifiedFrames}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Context Archaeologist skill command\n skillsCmd\n .command('dig <query>')\n .description('Deep historical context retrieval')\n .option(\n '-d, --depth <depth>',\n 'Search depth (e.g., 30days, 6months, all)',\n '30days'\n )\n .option('--patterns', 'Extract patterns from results')\n .option('--decisions', 'Extract key decisions')\n .option('--timeline', 'Generate activity timeline')\n .action(async (query, options) => {\n const spinner = ora('Digging through context...').start();\n\n try {\n const context = await initializeSkillContext();\n const skillsManager = new ClaudeSkillsManager(context);\n\n const result = await skillsManager.executeSkill('dig', [query], {\n depth: options.depth,\n patterns: options.patterns,\n decisions: options.decisions,\n timeline: options.timeline,\n });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n\n if (result.data) {\n console.log(\n chalk.cyan(\n `\\nSearched ${result.data.timeRange.from} to ${result.data.timeRange.to}`\n )\n );\n\n if (result.data.summary) {\n console.log('\\n' + result.data.summary);\n } else {\n // Display top results\n if (result.data.topResults?.length > 0) {\n console.log(chalk.cyan('\\nTop Results:'));\n result.data.topResults.forEach((r: any) => {\n console.log(\n ` ${chalk.yellow(`[${r.score.toFixed(2)}]`)} ${r.summary}`\n );\n });\n }\n\n // Display patterns if found\n if (result.data.patterns?.length > 0) {\n console.log(chalk.cyan('\\nDetected Patterns:'));\n result.data.patterns.forEach((p: any) => {\n console.log(` ${p.name}: ${p.count} occurrences`);\n });\n }\n\n // Display decisions if found\n if (result.data.decisions?.length > 0) {\n console.log(chalk.cyan('\\nKey Decisions:'));\n result.data.decisions.slice(0, 5).forEach((d: any) => {\n console.log(\n ` ${chalk.gray(new Date(d.timestamp).toLocaleDateString())}: ${d.decision}`\n );\n });\n }\n\n // Display timeline if generated\n if (result.data.timeline?.length > 0) {\n console.log(chalk.cyan('\\nActivity Timeline:'));\n result.data.timeline.slice(0, 5).forEach((t: any) => {\n console.log(` ${t.date}: ${t.itemCount} activities`);\n });\n }\n }\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Help command for skills\n skillsCmd\n .command('help [skill]')\n .description('Show help for a specific skill')\n .action(async (skill) => {\n const context = await initializeSkillContext();\n const skillsManager = new ClaudeSkillsManager(context);\n\n if (skill) {\n console.log(skillsManager.getSkillHelp(skill));\n } else {\n console.log(chalk.cyan('Available Claude Skills:\\n'));\n console.log(\n ' handoff - Streamline frame handoffs between team members'\n );\n console.log(' checkpoint - Create and manage recovery points');\n console.log(' dig - Deep historical context retrieval\\n');\n console.log(\n 'Use \"stackmemory skills help <skill>\" for detailed help on each skill'\n );\n }\n\n await context.database.disconnect();\n });\n\n return skillsCmd;\n}\n"],
5
- "mappings": ";AAMA,SAAS,eAAe;AACxB,OAAO,WAAW;AAClB,OAAO,SAAS;AAChB;AAAA,EACE;AAAA,OAEK;AACP,SAAS,wBAAwB;AACjC,SAAS,2BAA2B;AACpC,SAAS,wBAAwB;AACjC,SAAS,qBAAqB;AAC9B,SAAS,qBAAqB;AAC9B,YAAY,UAAU;AACtB,YAAY,QAAQ;AAEpB,SAAS,OAAO,KAAa,cAA+B;AAC1D,QAAM,QAAQ,QAAQ,IAAI,GAAG;AAC7B,MAAI,UAAU,QAAW;AACvB,QAAI,iBAAiB,OAAW,QAAO;AACvC,UAAM,IAAI,MAAM,wBAAwB,GAAG,cAAc;AAAA,EAC3D;AACA,SAAO;AACT;AAEA,SAAS,eAAe,KAAiC;AACvD,SAAO,QAAQ,IAAI,GAAG;AACxB;AAEA,eAAe,yBAAgD;AAC7D,QAAM,SAAS,cAAc,YAAY;AACzC,QAAM,YAAY,OAAO,IAAI,YAAY;AACzC,QAAM,SAAS,OAAO,IAAI,SAAS,KAAK,QAAQ,IAAI,MAAM,KAAK;AAE/D,QAAM,SAAS,KAAK;AAAA,IAClB,GAAG,QAAQ;AAAA,IACX;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAEA,QAAM,WAAW,IAAI,cAAc,WAAW,EAAE,OAAO,CAAC;AACxD,QAAM,SAAS,QAAQ;AAEvB,QAAM,mBAAmB,IAAI,iBAAiB,UAAU,WAAW,MAAM;AACzE,QAAM,iBAAiB,IAAI,oBAAoB,gBAAgB;AAC/D,QAAM,mBAAmB,IAAI,iBAAiB,QAAQ;AAEtD,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;AAEO,SAAS,sBAA+B;AAC7C,QAAM,YAAY,IAAI,QAAQ,QAAQ,EAAE;AAAA,IACtC;AAAA,EACF;AAGA,YACG,QAAQ,gCAAgC,EACxC,YAAY,gDAAgD,EAC5D;AAAA,IACC;AAAA,IACA;AAAA,IACA;AAAA,EACF,EACC,OAAO,4BAA4B,4BAA4B,EAC/D,OAAO,oBAAoB,kCAAkC,EAC7D,OAAO,OAAO,YAAY,SAAS,YAAY;AAC9C,UAAM,UAAU,IAAI,uBAAuB,EAAE,MAAM;AAEnD,QAAI;AACF,YAAM,UAAU,MAAM,uBAAuB;AAC7C,YAAM,gBAAgB,IAAI,oBAAoB,OAAO;AAErD,YAAM,SAAS,MAAM,cAAc;AAAA,QACjC;AAAA,QACA,CAAC,YAAY,OAAO;AAAA,QACpB;AAAA,UACE,UAAU,QAAQ;AAAA,UAClB,QAAQ,QAAQ;AAAA,UAChB,YAAY,QAAQ,eAAe;AAAA,QACrC;AAAA,MACF;AAEA,cAAQ,KAAK;AAEb,UAAI,OAAO,SAAS;AAClB,gBAAQ,IAAI,MAAM,MAAM,QAAG,GAAG,OAAO,OAAO;AAC5C,YAAI,OAAO,MAAM;AACf,kBAAQ,IAAI,MAAM,KAAK,oBAAoB,CAAC;AAC5C,kBAAQ,IAAI,SAAS,OAAO,KAAK,SAAS,EAAE;AAC5C,kBAAQ,IAAI,aAAa,OAAO,KAAK,UAAU,EAAE;AACjD,kBAAQ,IAAI,eAAe,OAAO,KAAK,QAAQ,EAAE;AACjD,cAAI,OAAO,KAAK,aAAa,SAAS,GAAG;AACvC,oBAAQ,IAAI,MAAM,OAAO,mBAAmB,CAAC;AAC7C,mBAAO,KAAK,YAAY,QAAQ,CAAC,SAAS;AACxC,sBAAQ,IAAI,cAAS,IAAI,EAAE;AAAA,YAC7B,CAAC;AAAA,UACH;AAAA,QACF;AAAA,MACF,OAAO;AACL,gBAAQ,IAAI,MAAM,IAAI,QAAG,GAAG,OAAO,OAAO;AAAA,MAC5C;AAEA,YAAM,QAAQ,SAAS,WAAW;AAAA,IACpC,SAAS,OAAgB;AACvB,cAAQ,KAAK;AACb,cAAQ,MAAM,MAAM,IAAI,QAAQ,GAAG,MAAM,OAAO;AAChD,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AAGH,QAAM,gBAAgB,UACnB,QAAQ,YAAY,EACpB,YAAY,mCAAmC;AAElD,gBACG,QAAQ,sBAAsB,EAC9B,YAAY,yBAAyB,EACrC,OAAO,sBAAsB,sCAAsC,EACnE,OAAO,uBAAuB,8BAA8B,EAC5D,OAAO,OAAO,aAAa,YAAY;AACtC,UAAM,UAAU,IAAI,wBAAwB,EAAE,MAAM;AAEpD,QAAI;AACF,YAAM,UAAU,MAAM,uBAAuB;AAC7C,YAAM,gBAAgB,IAAI,oBAAoB,OAAO;AAErD,YAAM,SAAS,MAAM,cAAc;AAAA,QACjC;AAAA,QACA,CAAC,UAAU,WAAW;AAAA,QACtB;AAAA,UACE,cAAc,QAAQ;AAAA,UACtB,iBAAiB,QAAQ;AAAA,QAC3B;AAAA,MACF;AAEA,cAAQ,KAAK;AAEb,UAAI,OAAO,SAAS;AAClB,gBAAQ,IAAI,MAAM,MAAM,QAAG,GAAG,OAAO,OAAO;AAC5C,YAAI,OAAO,MAAM;AACf,kBAAQ,IAAI,MAAM,KAAK,oBAAoB,CAAC;AAC5C,kBAAQ,IAAI,SAAS,OAAO,KAAK,YAAY,EAAE;AAC/C,kBAAQ,IAAI,WAAW,OAAO,KAAK,SAAS,EAAE;AAC9C,kBAAQ,IAAI,aAAa,OAAO,KAAK,UAAU,EAAE;AAAA,QACnD;AAAA,MACF,OAAO;AACL,gBAAQ,IAAI,MAAM,IAAI,QAAG,GAAG,OAAO,OAAO;AAAA,MAC5C;AAEA,YAAM,QAAQ,SAAS,WAAW;AAAA,IACpC,SAAS,OAAgB;AACvB,cAAQ,KAAK;AACb,cAAQ,MAAM,MAAM,IAAI,QAAQ,GAAG,MAAM,OAAO;AAChD,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AAEH,gBACG,QAAQ,wBAAwB,EAChC,YAAY,2BAA2B,EACvC,OAAO,OAAO,iBAAiB;AAC9B,UAAM,UAAU,IAAI,yBAAyB,EAAE,MAAM;AAErD,QAAI;AACF,YAAM,UAAU,MAAM,uBAAuB;AAC7C,YAAM,gBAAgB,IAAI,oBAAoB,OAAO;AAErD,YAAM,SAAS,MAAM,cAAc,aAAa,cAAc;AAAA,QAC5D;AAAA,QACA;AAAA,MACF,CAAC;AAED,cAAQ,KAAK;AAEb,UAAI,OAAO,SAAS;AAClB,gBAAQ,IAAI,MAAM,MAAM,QAAG,GAAG,OAAO,OAAO;AAC5C,YAAI,OAAO,MAAM;AACf,kBAAQ,IAAI,MAAM,KAAK,aAAa,CAAC;AACrC,kBAAQ,IAAI,aAAa,OAAO,KAAK,UAAU,EAAE;AACjD,kBAAQ,IAAI,YAAY,OAAO,KAAK,aAAa,EAAE;AAAA,QACrD;AAAA,MACF,OAAO;AACL,gBAAQ,IAAI,MAAM,IAAI,QAAG,GAAG,OAAO,OAAO;AAAA,MAC5C;AAEA,YAAM,QAAQ,SAAS,WAAW;AAAA,IACpC,SAAS,OAAgB;AACvB,cAAQ,KAAK;AACb,cAAQ,MAAM,MAAM,IAAI,QAAQ,GAAG,MAAM,OAAO;AAChD,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AAEH,gBACG,QAAQ,MAAM,EACd,YAAY,4BAA4B,EACxC,OAAO,wBAAwB,2BAA2B,IAAI,EAC9D,OAAO,sBAAsB,6BAA6B,EAC1D,OAAO,OAAO,YAAY;AACzB,UAAM,UAAU,IAAI,wBAAwB,EAAE,MAAM;AAEpD,QAAI;AACF,YAAM,UAAU,MAAM,uBAAuB;AAC7C,YAAM,gBAAgB,IAAI,oBAAoB,OAAO;AAErD,YAAM,SAAS,MAAM,cAAc;AAAA,QACjC;AAAA,QACA,CAAC,MAAM;AAAA,QACP;AAAA,UACE,OAAO,SAAS,QAAQ,KAAK;AAAA,UAC7B,OAAO,QAAQ,QAAQ,IAAI,KAAK,QAAQ,KAAK,IAAI;AAAA,QACnD;AAAA,MACF;AAEA,cAAQ,KAAK;AAEb,UAAI,OAAO,SAAS;AAClB,gBAAQ,IAAI,MAAM,KAAK,0BAA0B,CAAC;AAClD,YAAI,OAAO,QAAQ,OAAO,KAAK,SAAS,GAAG;AACzC,iBAAO,KAAK,QAAQ,CAAC,OAAY;AAC/B,kBAAM,gBAAgB,GAAG,QAAQ,MAAM,OAAO,UAAU,IAAI;AAC5D,oBAAQ,IAAI,GAAG,MAAM,KAAK,GAAG,EAAE,CAAC,GAAG,aAAa,EAAE;AAClD,oBAAQ,IAAI,KAAK,GAAG,WAAW,EAAE;AACjC,oBAAQ;AAAA,cACN,MAAM,KAAK,KAAK,GAAG,SAAS,KAAK,GAAG,UAAU;AAAA,CAAY;AAAA,YAC5D;AAAA,UACF,CAAC;AAAA,QACH,OAAO;AACL,kBAAQ,IAAI,MAAM,KAAK,sBAAsB,CAAC;AAAA,QAChD;AAAA,MACF,OAAO;AACL,gBAAQ,IAAI,MAAM,IAAI,QAAG,GAAG,OAAO,OAAO;AAAA,MAC5C;AAEA,YAAM,QAAQ,SAAS,WAAW;AAAA,IACpC,SAAS,OAAgB;AACvB,cAAQ,KAAK;AACb,cAAQ,MAAM,MAAM,IAAI,QAAQ,GAAG,MAAM,OAAO;AAChD,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AAEH,gBACG,QAAQ,kCAAkC,EAC1C,YAAY,0CAA0C,EACtD,OAAO,OAAO,aAAa,gBAAgB;AAC1C,UAAM,UAAU,IAAI,0BAA0B,EAAE,MAAM;AAEtD,QAAI;AACF,YAAM,UAAU,MAAM,uBAAuB;AAC7C,YAAM,gBAAgB,IAAI,oBAAoB,OAAO;AAErD,YAAM,SAAS,MAAM,cAAc,aAAa,cAAc;AAAA,QAC5D;AAAA,QACA;AAAA,QACA;AAAA,MACF,CAAC;AAED,cAAQ,KAAK;AAEb,UAAI,OAAO,SAAS;AAClB,gBAAQ,IAAI,MAAM,KAAK,oBAAoB,CAAC;AAC5C,YAAI,OAAO,MAAM;AACf,kBAAQ,IAAI,sBAAsB,OAAO,KAAK,QAAQ,EAAE;AACxD,kBAAQ,IAAI,uBAAuB,OAAO,KAAK,UAAU,EAAE;AAC3D,kBAAQ,IAAI,iBAAiB,OAAO,KAAK,SAAS,EAAE;AACpD,kBAAQ,IAAI,qBAAqB,OAAO,KAAK,aAAa,EAAE;AAC5D,kBAAQ,IAAI,sBAAsB,OAAO,KAAK,cAAc,EAAE;AAAA,QAChE;AAAA,MACF,OAAO;AACL,gBAAQ,IAAI,MAAM,IAAI,QAAG,GAAG,OAAO,OAAO;AAAA,MAC5C;AAEA,YAAM,QAAQ,SAAS,WAAW;AAAA,IACpC,SAAS,OAAgB;AACvB,cAAQ,KAAK;AACb,cAAQ,MAAM,MAAM,IAAI,QAAQ,GAAG,MAAM,OAAO;AAChD,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AAGH,YACG,QAAQ,aAAa,EACrB,YAAY,mCAAmC,EAC/C;AAAA,IACC;AAAA,IACA;AAAA,IACA;AAAA,EACF,EACC,OAAO,cAAc,+BAA+B,EACpD,OAAO,eAAe,uBAAuB,EAC7C,OAAO,cAAc,4BAA4B,EACjD,OAAO,OAAO,OAAO,YAAY;AAChC,UAAM,UAAU,IAAI,4BAA4B,EAAE,MAAM;AAExD,QAAI;AACF,YAAM,UAAU,MAAM,uBAAuB;AAC7C,YAAM,gBAAgB,IAAI,oBAAoB,OAAO;AAErD,YAAM,SAAS,MAAM,cAAc,aAAa,OAAO,CAAC,KAAK,GAAG;AAAA,QAC9D,OAAO,QAAQ;AAAA,QACf,UAAU,QAAQ;AAAA,QAClB,WAAW,QAAQ;AAAA,QACnB,UAAU,QAAQ;AAAA,MACpB,CAAC;AAED,cAAQ,KAAK;AAEb,UAAI,OAAO,SAAS;AAClB,gBAAQ,IAAI,MAAM,MAAM,QAAG,GAAG,OAAO,OAAO;AAE5C,YAAI,OAAO,MAAM;AACf,kBAAQ;AAAA,YACN,MAAM;AAAA,cACJ;AAAA,WAAc,OAAO,KAAK,UAAU,IAAI,OAAO,OAAO,KAAK,UAAU,EAAE;AAAA,YACzE;AAAA,UACF;AAEA,cAAI,OAAO,KAAK,SAAS;AACvB,oBAAQ,IAAI,OAAO,OAAO,KAAK,OAAO;AAAA,UACxC,OAAO;AAEL,gBAAI,OAAO,KAAK,YAAY,SAAS,GAAG;AACtC,sBAAQ,IAAI,MAAM,KAAK,gBAAgB,CAAC;AACxC,qBAAO,KAAK,WAAW,QAAQ,CAAC,MAAW;AACzC,wBAAQ;AAAA,kBACN,KAAK,MAAM,OAAO,IAAI,EAAE,MAAM,QAAQ,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO;AAAA,gBAC3D;AAAA,cACF,CAAC;AAAA,YACH;AAGA,gBAAI,OAAO,KAAK,UAAU,SAAS,GAAG;AACpC,sBAAQ,IAAI,MAAM,KAAK,sBAAsB,CAAC;AAC9C,qBAAO,KAAK,SAAS,QAAQ,CAAC,MAAW;AACvC,wBAAQ,IAAI,KAAK,EAAE,IAAI,KAAK,EAAE,KAAK,cAAc;AAAA,cACnD,CAAC;AAAA,YACH;AAGA,gBAAI,OAAO,KAAK,WAAW,SAAS,GAAG;AACrC,sBAAQ,IAAI,MAAM,KAAK,kBAAkB,CAAC;AAC1C,qBAAO,KAAK,UAAU,MAAM,GAAG,CAAC,EAAE,QAAQ,CAAC,MAAW;AACpD,wBAAQ;AAAA,kBACN,KAAK,MAAM,KAAK,IAAI,KAAK,EAAE,SAAS,EAAE,mBAAmB,CAAC,CAAC,KAAK,EAAE,QAAQ;AAAA,gBAC5E;AAAA,cACF,CAAC;AAAA,YACH;AAGA,gBAAI,OAAO,KAAK,UAAU,SAAS,GAAG;AACpC,sBAAQ,IAAI,MAAM,KAAK,sBAAsB,CAAC;AAC9C,qBAAO,KAAK,SAAS,MAAM,GAAG,CAAC,EAAE,QAAQ,CAAC,MAAW;AACnD,wBAAQ,IAAI,KAAK,EAAE,IAAI,KAAK,EAAE,SAAS,aAAa;AAAA,cACtD,CAAC;AAAA,YACH;AAAA,UACF;AAAA,QACF;AAAA,MACF,OAAO;AACL,gBAAQ,IAAI,MAAM,IAAI,QAAG,GAAG,OAAO,OAAO;AAAA,MAC5C;AAEA,YAAM,QAAQ,SAAS,WAAW;AAAA,IACpC,SAAS,OAAgB;AACvB,cAAQ,KAAK;AACb,cAAQ,MAAM,MAAM,IAAI,QAAQ,GAAG,MAAM,OAAO;AAChD,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AAGH,YACG,QAAQ,cAAc,EACtB,YAAY,gCAAgC,EAC5C,OAAO,OAAO,UAAU;AACvB,UAAM,UAAU,MAAM,uBAAuB;AAC7C,UAAM,gBAAgB,IAAI,oBAAoB,OAAO;AAErD,QAAI,OAAO;AACT,cAAQ,IAAI,cAAc,aAAa,KAAK,CAAC;AAAA,IAC/C,OAAO;AACL,cAAQ,IAAI,MAAM,KAAK,4BAA4B,CAAC;AACpD,cAAQ;AAAA,QACN;AAAA,MACF;AACA,cAAQ,IAAI,kDAAkD;AAC9D,cAAQ,IAAI,oDAAoD;AAChE,cAAQ;AAAA,QACN;AAAA,MACF;AAAA,IACF;AAEA,UAAM,QAAQ,SAAS,WAAW;AAAA,EACpC,CAAC;AAEH,SAAO;AACT;",
4
+ "sourcesContent": ["#!/usr/bin/env node\n/**\n * Claude Skills CLI Commands\n * Integrates Claude skills into the stackmemory CLI\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport {\n ClaudeSkillsManager,\n type SkillContext,\n} from '../../skills/claude-skills.js';\nimport { \n UnifiedRLMOrchestrator, \n initializeUnifiedOrchestrator \n} from '../../skills/unified-rlm-orchestrator.js';\nimport { DualStackManager } from '../../core/context/dual-stack-manager.js';\nimport { FrameHandoffManager } from '../../core/context/frame-handoff-manager.js';\nimport { FrameManager } from '../../core/context/frame-manager.js';\nimport { ContextRetriever } from '../../core/retrieval/context-retriever.js';\nimport { SQLiteAdapter } from '../../core/database/sqlite-adapter.js';\nimport { PebblesTaskStore } from '../../features/tasks/pebbles-task-store.js';\nimport { ConfigManager } from '../../core/config/config-manager.js';\nimport * as path from 'path';\nimport * as os from 'os';\n// Type-safe environment variable access\nfunction getEnv(key: string, defaultValue?: string): string {\n const value = process.env[key];\n if (value === undefined) {\n if (defaultValue !== undefined) return defaultValue;\n throw new Error(`Environment variable ${key} is required`);\n }\n return value;\n}\n\nfunction getOptionalEnv(key: string): string | undefined {\n return process.env[key];\n}\n\nasync function initializeSkillContext(): Promise<{ \n context: SkillContext;\n unifiedOrchestrator: UnifiedRLMOrchestrator;\n}> {\n const config = ConfigManager.getInstance();\n const projectId = config.get('project.id') || 'default-project';\n const userId = config.get('user.id') || process.env['USER'] || 'default';\n\n const dbPath = path.join(\n os.homedir(),\n '.stackmemory',\n 'data',\n projectId,\n 'stackmemory.db'\n );\n\n const database = new SQLiteAdapter(projectId, { dbPath });\n await database.connect();\n\n const dualStackManager = new DualStackManager(database, projectId, userId);\n const handoffManager = new FrameHandoffManager(dualStackManager);\n const contextRetriever = new ContextRetriever(database);\n const frameManager = new FrameManager(database);\n const taskStore = new PebblesTaskStore();\n\n const context: SkillContext = {\n projectId,\n userId,\n dualStackManager,\n handoffManager,\n contextRetriever,\n database,\n };\n \n // Initialize unified RLM orchestrator\n const unifiedOrchestrator = initializeUnifiedOrchestrator(\n frameManager,\n dualStackManager,\n contextRetriever,\n taskStore,\n context\n );\n\n return { context, unifiedOrchestrator };\n}\n\nexport function createSkillsCommand(): Command {\n const skillsCmd = new Command('skills').description(\n 'Execute Claude skills for enhanced workflow'\n );\n\n // Handoff skill command\n skillsCmd\n .command('handoff <targetUser> <message>')\n .description('Streamline frame handoffs between team members')\n .option(\n '-p, --priority <level>',\n 'Set priority (low, medium, high, critical)',\n 'medium'\n )\n .option('-f, --frames <frames...>', 'Specific frames to handoff')\n .option('--no-auto-detect', 'Disable auto-detection of frames')\n .action(async (targetUser, message, options) => {\n const spinner = ora('Initiating handoff...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n // Use unified RLM orchestrator for RLM-first execution\n const result = await unifiedOrchestrator.executeSkill(\n 'handoff',\n [targetUser, message],\n {\n priority: options.priority,\n frames: options.frames,\n autoDetect: options.autoDetect !== false,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nHandoff Details:'));\n console.log(` ID: ${result.data.handoffId}`);\n console.log(` Frames: ${result.data.frameCount}`);\n console.log(` Priority: ${result.data.priority}`);\n if (result.data.actionItems?.length > 0) {\n console.log(chalk.yellow('\\n Action Items:'));\n result.data.actionItems.forEach((item) => {\n console.log(` \u2022 ${item}`);\n });\n }\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Checkpoint skill commands\n const checkpointCmd = skillsCmd\n .command('checkpoint')\n .description('Create and manage recovery points');\n\n checkpointCmd\n .command('create <description>')\n .description('Create a new checkpoint')\n .option('--files <files...>', 'Include specific files in checkpoint')\n .option('--auto-detect-risky', 'Auto-detect risky operations')\n .action(async (description, options) => {\n const spinner = ora('Creating checkpoint...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill(\n 'checkpoint',\n ['create', description],\n {\n includeFiles: options.files,\n autoDetectRisky: options.autoDetectRisky,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nCheckpoint Info:'));\n console.log(` ID: ${result.data.checkpointId}`);\n console.log(` Time: ${result.data.timestamp}`);\n console.log(` Frames: ${result.data.frameCount}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('restore <checkpointId>')\n .description('Restore from a checkpoint')\n .action(async (checkpointId) => {\n const spinner = ora('Restoring checkpoint...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill('checkpoint', [\n 'restore',\n checkpointId,\n ]);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nRestored:'));\n console.log(` Frames: ${result.data.frameCount}`);\n console.log(` Files: ${result.data.filesRestored}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('list')\n .description('List available checkpoints')\n .option('-l, --limit <number>', 'Limit number of results', '10')\n .option('-s, --since <date>', 'Show checkpoints since date')\n .action(async (options) => {\n const spinner = ora('Loading checkpoints...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill(\n 'checkpoint',\n ['list'],\n {\n limit: parseInt(options.limit),\n since: options.since ? new Date(options.since) : undefined,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.cyan('Available Checkpoints:\\n'));\n if (result.data && result.data.length > 0) {\n result.data.forEach((cp: any) => {\n const riskIndicator = cp.risky ? chalk.yellow(' [RISKY]') : '';\n console.log(`${chalk.bold(cp.id)}${riskIndicator}`);\n console.log(` ${cp.description}`);\n console.log(\n chalk.gray(` ${cp.timestamp} (${cp.frameCount} frames)\\n`)\n );\n });\n } else {\n console.log(chalk.gray('No checkpoints found'));\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('diff <checkpoint1> <checkpoint2>')\n .description('Show differences between two checkpoints')\n .action(async (checkpoint1, checkpoint2) => {\n const spinner = ora('Comparing checkpoints...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill('checkpoint', [\n 'diff',\n checkpoint1,\n checkpoint2,\n ]);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.cyan('Checkpoint Diff:\\n'));\n if (result.data) {\n console.log(` Time difference: ${result.data.timeDiff}`);\n console.log(` Frame difference: ${result.data.framesDiff}`);\n console.log(` New frames: ${result.data.newFrames}`);\n console.log(` Removed frames: ${result.data.removedFrames}`);\n console.log(` Modified frames: ${result.data.modifiedFrames}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Context Archaeologist skill command\n skillsCmd\n .command('dig <query>')\n .description('Deep historical context retrieval')\n .option(\n '-d, --depth <depth>',\n 'Search depth (e.g., 30days, 6months, all)',\n '30days'\n )\n .option('--patterns', 'Extract patterns from results')\n .option('--decisions', 'Extract key decisions')\n .option('--timeline', 'Generate activity timeline')\n .action(async (query, options) => {\n const spinner = ora('Digging through context...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill('dig', [query], {\n depth: options.depth,\n patterns: options.patterns,\n decisions: options.decisions,\n timeline: options.timeline,\n });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n\n if (result.data) {\n console.log(\n chalk.cyan(\n `\\nSearched ${result.data.timeRange.from} to ${result.data.timeRange.to}`\n )\n );\n\n if (result.data.summary) {\n console.log('\\n' + result.data.summary);\n } else {\n // Display top results\n if (result.data.topResults?.length > 0) {\n console.log(chalk.cyan('\\nTop Results:'));\n result.data.topResults.forEach((r: any) => {\n console.log(\n ` ${chalk.yellow(`[${r.score.toFixed(2)}]`)} ${r.summary}`\n );\n });\n }\n\n // Display patterns if found\n if (result.data.patterns?.length > 0) {\n console.log(chalk.cyan('\\nDetected Patterns:'));\n result.data.patterns.forEach((p: any) => {\n console.log(` ${p.name}: ${p.count} occurrences`);\n });\n }\n\n // Display decisions if found\n if (result.data.decisions?.length > 0) {\n console.log(chalk.cyan('\\nKey Decisions:'));\n result.data.decisions.slice(0, 5).forEach((d: any) => {\n console.log(\n ` ${chalk.gray(new Date(d.timestamp).toLocaleDateString())}: ${d.decision}`\n );\n });\n }\n\n // Display timeline if generated\n if (result.data.timeline?.length > 0) {\n console.log(chalk.cyan('\\nActivity Timeline:'));\n result.data.timeline.slice(0, 5).forEach((t: any) => {\n console.log(` ${t.date}: ${t.itemCount} activities`);\n });\n }\n }\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // RLM (Recursive Language Model) skill command\n skillsCmd\n .command('rlm <task>')\n .description('Execute complex tasks with recursive agent orchestration')\n .option('--max-parallel <number>', 'Maximum concurrent subagents', '5')\n .option('--max-recursion <number>', 'Maximum recursion depth', '4')\n .option('--max-tokens-per-agent <number>', 'Token budget per subagent', '30000')\n .option('--review-stages <number>', 'Number of review iterations', '3')\n .option('--quality-threshold <number>', 'Target quality score (0-1)', '0.85')\n .option('--test-mode <mode>', 'Test generation mode (unit/integration/e2e/all)', 'all')\n .option('--verbose', 'Show all recursive operations', false)\n .option('--share-context-realtime', 'Share discoveries between agents', true)\n .option('--retry-failed-agents', 'Retry on failure', true)\n .option('--timeout-per-agent <number>', 'Timeout in seconds', '300')\n .action(async (task, options) => {\n const spinner = ora('Initializing RLM orchestrator...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n spinner.text = 'Decomposing task...';\n \n const result = await unifiedOrchestrator.executeSkill('rlm', [task], {\n maxParallel: parseInt(options.maxParallel),\n maxRecursionDepth: parseInt(options.maxRecursion),\n maxTokensPerAgent: parseInt(options.maxTokensPerAgent),\n reviewStages: parseInt(options.reviewStages),\n qualityThreshold: parseFloat(options.qualityThreshold),\n testGenerationMode: options.testMode,\n verboseLogging: options.verbose,\n shareContextRealtime: options.shareContextRealtime,\n retryFailedAgents: options.retryFailedAgents,\n timeoutPerAgent: parseInt(options.timeoutPerAgent) * 1000,\n });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), 'RLM execution completed');\n \n if (result.data) {\n console.log(chalk.cyan('\\nExecution Summary:'));\n console.log(` Total tokens: ${result.data.totalTokens}`);\n console.log(` Estimated cost: $${result.data.totalCost.toFixed(2)}`);\n console.log(` Duration: ${result.data.duration}ms`);\n console.log(` Tests generated: ${result.data.testsGenerated}`);\n console.log(` Issues found: ${result.data.issuesFound}`);\n console.log(` Issues fixed: ${result.data.issuesFixed}`);\n \n if (result.data.improvements?.length > 0) {\n console.log(chalk.cyan('\\nImprovements:'));\n result.data.improvements.forEach((imp: string) => {\n console.log(` \u2022 ${imp}`);\n });\n }\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Help command for skills\n skillsCmd\n .command('help [skill]')\n .description('Show help for a specific skill')\n .action(async (skill) => {\n if (skill) {\n // Show specific skill help\n switch (skill) {\n case 'lint':\n console.log(`\nlint (RLM-Orchestrated)\nPrimary Agent: linting\nSecondary Agents: improve\n\nComprehensive linting of code: Check syntax, types, formatting, security, performance, and dead code. Provide fixes.\n\nThis skill is executed through RLM orchestration for:\n- Automatic task decomposition\n- Parallel agent execution\n- Multi-stage quality review\n- Comprehensive result aggregation\n\nUsage:\n stackmemory skills lint # Lint current directory\n stackmemory skills lint src/ # Lint specific directory\n stackmemory skills lint src/file.ts # Lint specific file\n\nOptions:\n --fix Automatically fix issues where possible\n --format Focus on formatting issues\n --security Focus on security vulnerabilities\n --performance Focus on performance issues\n --verbose Show detailed output\n`);\n break;\n default:\n console.log(`Unknown skill: ${skill}. Use \"stackmemory skills help\" to see all available skills.`);\n }\n } else {\n console.log(chalk.cyan('Available Claude Skills (RLM-Orchestrated):\\n'));\n console.log(\n ' handoff - Streamline frame handoffs between team members'\n );\n console.log(' checkpoint - Create and manage recovery points');\n console.log(' dig - Deep historical context retrieval');\n console.log(' lint - Comprehensive code linting and quality checks');\n console.log(' test - Generate comprehensive test suites');\n console.log(' review - Multi-stage code review and improvements');\n console.log(' refactor - Refactor code for better architecture');\n console.log(' publish - Prepare and execute releases');\n console.log(' rlm - Direct recursive agent orchestration\\n');\n console.log(chalk.yellow('\\nAll skills now use RLM orchestration for intelligent task decomposition'));\n console.log(\n 'Use \"stackmemory skills help <skill>\" for detailed help on each skill'\n );\n }\n });\n\n return skillsCmd;\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -0,0 +1,282 @@
1
+ #!/usr/bin/env node
2
+ import { Command } from "commander";
3
+ import { TestingAgent } from "../../agents/testing-agent.js";
4
+ import { logger } from "../../core/monitoring/logger.js";
5
+ import { join } from "path";
6
+ import chalk from "chalk";
7
+ import ora from "ora";
8
+ function createTestCommand() {
9
+ const testCmd = new Command("test").description("Generate and execute automated tests").option("--verbose", "Show detailed output").option("--dry-run", "Preview generated tests without saving");
10
+ testCmd.command("generate <target>").description("Generate tests for target file/module").option("--type <type>", "Test type: unit|integration|e2e|perf", "unit").option("--coverage", "Include coverage report").option("--edge-cases", "Generate comprehensive edge case tests").option("--output <path>", "Output directory for generated tests").action(async (target, options) => {
11
+ const spinner = ora("Generating tests...").start();
12
+ try {
13
+ const agent = new TestingAgent();
14
+ const targetPath = join(process.cwd(), target);
15
+ let testSuite;
16
+ switch (options.type) {
17
+ case "unit":
18
+ spinner.text = "Generating unit tests...";
19
+ testSuite = await agent.generateUnitTests(targetPath);
20
+ break;
21
+ case "integration":
22
+ spinner.text = "Generating integration tests...";
23
+ testSuite = await agent.generateIntegrationTests(targetPath);
24
+ break;
25
+ case "perf":
26
+ spinner.text = "Generating performance benchmarks...";
27
+ const funcName = options.function || "main";
28
+ const perfReport = await agent.benchmarkPerformance(targetPath, funcName);
29
+ spinner.succeed("Performance benchmark generated");
30
+ console.log(chalk.cyan("\n\u{1F4CA} Performance Report:"));
31
+ console.log(chalk.gray(" Average:"), perfReport.averageTime.toFixed(2), "ms");
32
+ console.log(chalk.gray(" Min:"), perfReport.minTime.toFixed(2), "ms");
33
+ console.log(chalk.gray(" Max:"), perfReport.maxTime.toFixed(2), "ms");
34
+ return;
35
+ default:
36
+ spinner.text = "Generating unit tests...";
37
+ testSuite = await agent.generateUnitTests(targetPath);
38
+ }
39
+ if (options.edgeCases && testSuite) {
40
+ spinner.text = "Adding edge case tests...";
41
+ const functions = await getFunctionsFromFile(targetPath);
42
+ for (const func of functions) {
43
+ const edgeCases = await agent.generateEdgeCaseTests(targetPath, func);
44
+ testSuite.tests.push(...edgeCases);
45
+ }
46
+ }
47
+ if (options.coverage) {
48
+ spinner.text = "Analyzing code coverage...";
49
+ const coverage = await agent.analyzeCodeCoverage(targetPath);
50
+ console.log(chalk.cyan("\n\u{1F4C8} Coverage Report:"));
51
+ console.log(chalk.gray(" Lines:"), `${coverage.lines.percentage}%`);
52
+ console.log(chalk.gray(" Branches:"), `${coverage.branches.percentage}%`);
53
+ console.log(chalk.gray(" Functions:"), `${coverage.functions.percentage}%`);
54
+ if (coverage.uncoveredLines.length > 0) {
55
+ console.log(chalk.yellow(" Uncovered lines:"), coverage.uncoveredLines.join(", "));
56
+ }
57
+ }
58
+ if (options.dryRun) {
59
+ spinner.succeed("Test generation complete (dry run)");
60
+ console.log(chalk.cyan("\n\u{1F50D} Preview of generated tests:"));
61
+ console.log(chalk.gray("\u2500".repeat(50)));
62
+ console.log(formatTestPreview(testSuite));
63
+ } else {
64
+ await agent.saveTestSuite(testSuite);
65
+ spinner.succeed(`Tests saved to ${testSuite.filePath}`);
66
+ console.log(chalk.green("\n\u2728 Test Generation Summary:"));
67
+ console.log(chalk.gray(" Type:"), options.type);
68
+ console.log(chalk.gray(" Target:"), target);
69
+ console.log(chalk.gray(" Tests generated:"), testSuite.tests.length);
70
+ console.log(chalk.gray(" Output:"), testSuite.filePath);
71
+ }
72
+ } catch (error) {
73
+ spinner.fail("Test generation failed");
74
+ logger.error("Failed to generate tests", { error, target, options });
75
+ console.error(chalk.red("Error:"), error.message);
76
+ process.exit(1);
77
+ }
78
+ });
79
+ testCmd.command("coverage").description("Analyze coverage and generate missing tests").option("--generate-missing", "Generate tests for uncovered code").option("--threshold <percent>", "Coverage threshold percentage", "80").option("--target <path>", "Specific file or directory to analyze").action(async (options) => {
80
+ const spinner = ora("Analyzing code coverage...").start();
81
+ try {
82
+ const agent = new TestingAgent();
83
+ const targetPath = options.target ? join(process.cwd(), options.target) : process.cwd();
84
+ const coverage = await agent.analyzeCodeCoverage(targetPath);
85
+ spinner.succeed("Coverage analysis complete");
86
+ console.log(chalk.cyan("\n\u{1F4CA} Code Coverage Report:"));
87
+ console.log(chalk.gray("\u2500".repeat(50)));
88
+ displayCoverageReport(coverage);
89
+ const threshold = parseInt(options.threshold);
90
+ const passed = coverage.lines.percentage >= threshold;
91
+ if (passed) {
92
+ console.log(chalk.green(`
93
+ \u2705 Coverage meets threshold (${threshold}%)`));
94
+ } else {
95
+ console.log(chalk.yellow(`
96
+ \u26A0\uFE0F Coverage below threshold (${threshold}%)`));
97
+ if (options.generateMissing) {
98
+ spinner.start("Generating tests for uncovered code...");
99
+ const testSuite = await agent.generateUnitTests(targetPath);
100
+ testSuite.tests = testSuite.tests.filter((test) => {
101
+ return true;
102
+ });
103
+ await agent.saveTestSuite(testSuite);
104
+ spinner.succeed(`Generated ${testSuite.tests.length} tests for uncovered code`);
105
+ }
106
+ }
107
+ } catch (error) {
108
+ spinner.fail("Coverage analysis failed");
109
+ logger.error("Failed to analyze coverage", { error, options });
110
+ console.error(chalk.red("Error:"), error.message);
111
+ process.exit(1);
112
+ }
113
+ });
114
+ testCmd.command("run [pattern]").description("Execute tests matching pattern").option("--watch", "Run tests in watch mode").option("--coverage", "Generate coverage report").option("--reporter <type>", "Test reporter type", "default").action(async (pattern = "**/*.test.ts", options) => {
115
+ const spinner = ora("Running tests...").start();
116
+ try {
117
+ const agent = new TestingAgent();
118
+ const results = await agent.executeTests(pattern);
119
+ if (results.failed === 0) {
120
+ spinner.succeed(`All tests passed (${results.passed} tests)`);
121
+ console.log(chalk.green("\n\u2705 Test Results:"));
122
+ } else {
123
+ spinner.fail(`${results.failed} tests failed`);
124
+ console.log(chalk.red("\n\u274C Test Results:"));
125
+ }
126
+ console.log(chalk.gray(" Passed:"), results.passed);
127
+ console.log(chalk.gray(" Failed:"), results.failed);
128
+ console.log(chalk.gray(" Skipped:"), results.skipped);
129
+ console.log(chalk.gray(" Duration:"), `${results.duration}ms`);
130
+ if (results.failures.length > 0) {
131
+ console.log(chalk.red("\n\u{1F4CB} Failed Tests:"));
132
+ results.failures.forEach((failure) => {
133
+ console.log(chalk.red(` \u2022 ${failure.test}`));
134
+ console.log(chalk.gray(` ${failure.error}`));
135
+ });
136
+ }
137
+ process.exit(results.failed > 0 ? 1 : 0);
138
+ } catch (error) {
139
+ spinner.fail("Test execution failed");
140
+ logger.error("Failed to execute tests", { error, pattern, options });
141
+ console.error(chalk.red("Error:"), error.message);
142
+ process.exit(1);
143
+ }
144
+ });
145
+ testCmd.command("mock <schema>").description("Generate mock data from schema").option("--count <n>", "Number of mock items to generate", "1").option("--output <path>", "Output file for mock data").action(async (schemaPath, options) => {
146
+ const spinner = ora("Generating mock data...").start();
147
+ try {
148
+ const agent = new TestingAgent();
149
+ const schema = require(join(process.cwd(), schemaPath));
150
+ const mocks = [];
151
+ for (let i = 0; i < parseInt(options.count); i++) {
152
+ mocks.push(agent.generateMockData(schema));
153
+ }
154
+ spinner.succeed(`Generated ${mocks.length} mock items`);
155
+ if (options.output) {
156
+ const { writeFileSync } = await import("fs");
157
+ writeFileSync(
158
+ join(process.cwd(), options.output),
159
+ JSON.stringify(mocks, null, 2)
160
+ );
161
+ console.log(chalk.green(`
162
+ \u2705 Mock data saved to ${options.output}`));
163
+ } else {
164
+ console.log(chalk.cyan("\n\u{1F4E6} Mock Data:"));
165
+ console.log(JSON.stringify(mocks, null, 2));
166
+ }
167
+ } catch (error) {
168
+ spinner.fail("Mock generation failed");
169
+ logger.error("Failed to generate mock data", { error, schemaPath, options });
170
+ console.error(chalk.red("Error:"), error.message);
171
+ process.exit(1);
172
+ }
173
+ });
174
+ testCmd.command("fixtures <component>").description("Create test fixtures for component").option("--output <path>", "Output directory for fixtures").action(async (component, options) => {
175
+ const spinner = ora("Creating test fixtures...").start();
176
+ try {
177
+ const agent = new TestingAgent();
178
+ const fixtures = agent.createTestFixtures(component);
179
+ spinner.succeed(`Created ${fixtures.length} fixtures for ${component}`);
180
+ if (options.output) {
181
+ const { writeFileSync, mkdirSync } = await import("fs");
182
+ const outputDir = join(process.cwd(), options.output);
183
+ mkdirSync(outputDir, { recursive: true });
184
+ fixtures.forEach((fixture) => {
185
+ const filePath = join(outputDir, `${fixture.name}.fixture.json`);
186
+ writeFileSync(filePath, JSON.stringify(fixture.data, null, 2));
187
+ console.log(chalk.gray(` \u2022 ${fixture.name} \u2192 ${filePath}`));
188
+ });
189
+ console.log(chalk.green(`
190
+ \u2705 Fixtures saved to ${options.output}`));
191
+ } else {
192
+ console.log(chalk.cyan("\n\u{1F527} Test Fixtures:"));
193
+ fixtures.forEach((fixture) => {
194
+ console.log(chalk.yellow(`
195
+ ${fixture.name}:`));
196
+ console.log(JSON.stringify(fixture.data, null, 2));
197
+ });
198
+ }
199
+ } catch (error) {
200
+ spinner.fail("Fixture creation failed");
201
+ logger.error("Failed to create fixtures", { error, component, options });
202
+ console.error(chalk.red("Error:"), error.message);
203
+ process.exit(1);
204
+ }
205
+ });
206
+ testCmd.command("benchmark <target>").description("Run performance benchmarks").option("--function <name>", "Specific function to benchmark").option("--iterations <n>", "Number of iterations", "1000").option("--threshold <ms>", "Performance threshold in milliseconds").action(async (target, options) => {
207
+ const spinner = ora("Running performance benchmarks...").start();
208
+ try {
209
+ const agent = new TestingAgent();
210
+ const targetPath = join(process.cwd(), target);
211
+ const functionName = options.function || "default";
212
+ const report = await agent.benchmarkPerformance(targetPath, functionName);
213
+ spinner.succeed("Benchmark complete");
214
+ console.log(chalk.cyan("\n\u26A1 Performance Benchmark Report:"));
215
+ console.log(chalk.gray("\u2500".repeat(50)));
216
+ console.log(chalk.gray(" Function:"), report.function);
217
+ console.log(chalk.gray(" Average:"), `${report.averageTime.toFixed(3)}ms`);
218
+ console.log(chalk.gray(" Min:"), `${report.minTime.toFixed(3)}ms`);
219
+ console.log(chalk.gray(" Max:"), `${report.maxTime.toFixed(3)}ms`);
220
+ console.log(chalk.gray(" Iterations:"), report.iterations);
221
+ console.log(chalk.gray(" Memory:"), `${(report.memoryUsage / 1024 / 1024).toFixed(2)}MB`);
222
+ if (options.threshold) {
223
+ const threshold = parseFloat(options.threshold);
224
+ if (report.averageTime <= threshold) {
225
+ console.log(chalk.green(`
226
+ \u2705 Performance within threshold (${threshold}ms)`));
227
+ } else {
228
+ console.log(chalk.red(`
229
+ \u274C Performance exceeds threshold (${threshold}ms)`));
230
+ process.exit(1);
231
+ }
232
+ }
233
+ } catch (error) {
234
+ spinner.fail("Benchmark failed");
235
+ logger.error("Failed to run benchmark", { error, target, options });
236
+ console.error(chalk.red("Error:"), error.message);
237
+ process.exit(1);
238
+ }
239
+ });
240
+ return testCmd;
241
+ }
242
+ async function getFunctionsFromFile(filePath) {
243
+ return ["main", "helper", "util"];
244
+ }
245
+ function formatTestPreview(testSuite) {
246
+ const preview = [`File: ${testSuite.filePath}`, `Describe: ${testSuite.describe}`, ""];
247
+ testSuite.tests.forEach((test) => {
248
+ preview.push(` \u2713 ${test.name}`);
249
+ });
250
+ return preview.join("\n");
251
+ }
252
+ function displayCoverageReport(coverage) {
253
+ const formatPercent = (percent) => {
254
+ if (percent >= 80) return chalk.green(`${percent}%`);
255
+ if (percent >= 60) return chalk.yellow(`${percent}%`);
256
+ return chalk.red(`${percent}%`);
257
+ };
258
+ console.log(
259
+ chalk.gray(" Lines:"),
260
+ formatPercent(coverage.lines.percentage),
261
+ `(${coverage.lines.covered}/${coverage.lines.total})`
262
+ );
263
+ console.log(
264
+ chalk.gray(" Branches:"),
265
+ formatPercent(coverage.branches.percentage),
266
+ `(${coverage.branches.covered}/${coverage.branches.total})`
267
+ );
268
+ console.log(
269
+ chalk.gray(" Functions:"),
270
+ formatPercent(coverage.functions.percentage),
271
+ `(${coverage.functions.covered}/${coverage.functions.total})`
272
+ );
273
+ }
274
+ if (import.meta.url === `file://${process.argv[1]}`) {
275
+ const program = new Command();
276
+ program.addCommand(createTestCommand());
277
+ program.parse(process.argv);
278
+ }
279
+ export {
280
+ createTestCommand
281
+ };
282
+ //# sourceMappingURL=test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/cli/commands/test.ts"],
4
+ "sourcesContent": ["#!/usr/bin/env node\n/**\n * Testing command - Generate and execute automated tests\n */\n\nimport { Command } from 'commander';\nimport { TestingAgent } from '../../agents/testing-agent.js';\nimport { logger } from '../../core/monitoring/logger.js';\nimport { join } from 'path';\nimport chalk from 'chalk';\nimport ora from 'ora';\n\nexport function createTestCommand(): Command {\n const testCmd = new Command('test')\n .description('Generate and execute automated tests')\n .option('--verbose', 'Show detailed output')\n .option('--dry-run', 'Preview generated tests without saving');\n\n /**\n * Generate tests for target file/module\n */\n testCmd\n .command('generate <target>')\n .description('Generate tests for target file/module')\n .option('--type <type>', 'Test type: unit|integration|e2e|perf', 'unit')\n .option('--coverage', 'Include coverage report')\n .option('--edge-cases', 'Generate comprehensive edge case tests')\n .option('--output <path>', 'Output directory for generated tests')\n .action(async (target: string, options: any) => {\n const spinner = ora('Generating tests...').start();\n \n try {\n const agent = new TestingAgent();\n const targetPath = join(process.cwd(), target);\n \n // Generate tests based on type\n let testSuite;\n switch (options.type) {\n case 'unit':\n spinner.text = 'Generating unit tests...';\n testSuite = await agent.generateUnitTests(targetPath);\n break;\n \n case 'integration':\n spinner.text = 'Generating integration tests...';\n testSuite = await agent.generateIntegrationTests(targetPath);\n break;\n \n case 'perf':\n spinner.text = 'Generating performance benchmarks...';\n // For performance, we generate benchmarks instead\n const funcName = options.function || 'main';\n const perfReport = await agent.benchmarkPerformance(targetPath, funcName);\n spinner.succeed('Performance benchmark generated');\n console.log(chalk.cyan('\\n\uD83D\uDCCA Performance Report:'));\n console.log(chalk.gray(' Average:'), perfReport.averageTime.toFixed(2), 'ms');\n console.log(chalk.gray(' Min:'), perfReport.minTime.toFixed(2), 'ms');\n console.log(chalk.gray(' Max:'), perfReport.maxTime.toFixed(2), 'ms');\n return;\n \n default:\n spinner.text = 'Generating unit tests...';\n testSuite = await agent.generateUnitTests(targetPath);\n }\n \n // Add edge cases if requested\n if (options.edgeCases && testSuite) {\n spinner.text = 'Adding edge case tests...';\n const functions = await getFunctionsFromFile(targetPath);\n for (const func of functions) {\n const edgeCases = await agent.generateEdgeCaseTests(targetPath, func);\n testSuite.tests.push(...edgeCases);\n }\n }\n \n // Check coverage if requested\n if (options.coverage) {\n spinner.text = 'Analyzing code coverage...';\n const coverage = await agent.analyzeCodeCoverage(targetPath);\n console.log(chalk.cyan('\\n\uD83D\uDCC8 Coverage Report:'));\n console.log(chalk.gray(' Lines:'), `${coverage.lines.percentage}%`);\n console.log(chalk.gray(' Branches:'), `${coverage.branches.percentage}%`);\n console.log(chalk.gray(' Functions:'), `${coverage.functions.percentage}%`);\n \n if (coverage.uncoveredLines.length > 0) {\n console.log(chalk.yellow(' Uncovered lines:'), coverage.uncoveredLines.join(', '));\n }\n }\n \n // Save or preview tests\n if (options.dryRun) {\n spinner.succeed('Test generation complete (dry run)');\n console.log(chalk.cyan('\\n\uD83D\uDD0D Preview of generated tests:'));\n console.log(chalk.gray('\u2500'.repeat(50)));\n console.log(formatTestPreview(testSuite));\n } else {\n await agent.saveTestSuite(testSuite);\n spinner.succeed(`Tests saved to ${testSuite.filePath}`);\n \n // Show summary\n console.log(chalk.green('\\n\u2728 Test Generation Summary:'));\n console.log(chalk.gray(' Type:'), options.type);\n console.log(chalk.gray(' Target:'), target);\n console.log(chalk.gray(' Tests generated:'), testSuite.tests.length);\n console.log(chalk.gray(' Output:'), testSuite.filePath);\n }\n \n } catch (error) {\n spinner.fail('Test generation failed');\n logger.error('Failed to generate tests', { error, target, options });\n console.error(chalk.red('Error:'), (error as Error).message);\n process.exit(1);\n }\n });\n\n /**\n * Analyze coverage and generate missing tests\n */\n testCmd\n .command('coverage')\n .description('Analyze coverage and generate missing tests')\n .option('--generate-missing', 'Generate tests for uncovered code')\n .option('--threshold <percent>', 'Coverage threshold percentage', '80')\n .option('--target <path>', 'Specific file or directory to analyze')\n .action(async (options: any) => {\n const spinner = ora('Analyzing code coverage...').start();\n \n try {\n const agent = new TestingAgent();\n const targetPath = options.target ? join(process.cwd(), options.target) : process.cwd();\n \n // Get coverage report\n const coverage = await agent.analyzeCodeCoverage(targetPath);\n spinner.succeed('Coverage analysis complete');\n \n // Display coverage\n console.log(chalk.cyan('\\n\uD83D\uDCCA Code Coverage Report:'));\n console.log(chalk.gray('\u2500'.repeat(50)));\n displayCoverageReport(coverage);\n \n // Check threshold\n const threshold = parseInt(options.threshold);\n const passed = coverage.lines.percentage >= threshold;\n \n if (passed) {\n console.log(chalk.green(`\\n\u2705 Coverage meets threshold (${threshold}%)`));\n } else {\n console.log(chalk.yellow(`\\n\u26A0\uFE0F Coverage below threshold (${threshold}%)`));\n \n if (options.generateMissing) {\n spinner.start('Generating tests for uncovered code...');\n \n // Generate tests for uncovered lines\n const testSuite = await agent.generateUnitTests(targetPath);\n \n // Focus on uncovered areas\n testSuite.tests = testSuite.tests.filter(test => {\n // Filter to focus on uncovered code\n return true; // This would need more sophisticated logic\n });\n \n await agent.saveTestSuite(testSuite);\n spinner.succeed(`Generated ${testSuite.tests.length} tests for uncovered code`);\n }\n }\n \n } catch (error) {\n spinner.fail('Coverage analysis failed');\n logger.error('Failed to analyze coverage', { error, options });\n console.error(chalk.red('Error:'), (error as Error).message);\n process.exit(1);\n }\n });\n\n /**\n * Execute tests\n */\n testCmd\n .command('run [pattern]')\n .description('Execute tests matching pattern')\n .option('--watch', 'Run tests in watch mode')\n .option('--coverage', 'Generate coverage report')\n .option('--reporter <type>', 'Test reporter type', 'default')\n .action(async (pattern: string = '**/*.test.ts', options: any) => {\n const spinner = ora('Running tests...').start();\n \n try {\n const agent = new TestingAgent();\n \n // Execute tests\n const results = await agent.executeTests(pattern);\n \n if (results.failed === 0) {\n spinner.succeed(`All tests passed (${results.passed} tests)`);\n console.log(chalk.green('\\n\u2705 Test Results:'));\n } else {\n spinner.fail(`${results.failed} tests failed`);\n console.log(chalk.red('\\n\u274C Test Results:'));\n }\n \n // Display results\n console.log(chalk.gray(' Passed:'), results.passed);\n console.log(chalk.gray(' Failed:'), results.failed);\n console.log(chalk.gray(' Skipped:'), results.skipped);\n console.log(chalk.gray(' Duration:'), `${results.duration}ms`);\n \n // Show failures\n if (results.failures.length > 0) {\n console.log(chalk.red('\\n\uD83D\uDCCB Failed Tests:'));\n results.failures.forEach(failure => {\n console.log(chalk.red(` \u2022 ${failure.test}`));\n console.log(chalk.gray(` ${failure.error}`));\n });\n }\n \n process.exit(results.failed > 0 ? 1 : 0);\n \n } catch (error) {\n spinner.fail('Test execution failed');\n logger.error('Failed to execute tests', { error, pattern, options });\n console.error(chalk.red('Error:'), (error as Error).message);\n process.exit(1);\n }\n });\n\n /**\n * Generate mock data\n */\n testCmd\n .command('mock <schema>')\n .description('Generate mock data from schema')\n .option('--count <n>', 'Number of mock items to generate', '1')\n .option('--output <path>', 'Output file for mock data')\n .action(async (schemaPath: string, options: any) => {\n const spinner = ora('Generating mock data...').start();\n \n try {\n const agent = new TestingAgent();\n const schema = require(join(process.cwd(), schemaPath));\n \n const mocks = [];\n for (let i = 0; i < parseInt(options.count); i++) {\n mocks.push(agent.generateMockData(schema));\n }\n \n spinner.succeed(`Generated ${mocks.length} mock items`);\n \n if (options.output) {\n const { writeFileSync } = await import('fs');\n writeFileSync(\n join(process.cwd(), options.output),\n JSON.stringify(mocks, null, 2)\n );\n console.log(chalk.green(`\\n\u2705 Mock data saved to ${options.output}`));\n } else {\n console.log(chalk.cyan('\\n\uD83D\uDCE6 Mock Data:'));\n console.log(JSON.stringify(mocks, null, 2));\n }\n \n } catch (error) {\n spinner.fail('Mock generation failed');\n logger.error('Failed to generate mock data', { error, schemaPath, options });\n console.error(chalk.red('Error:'), (error as Error).message);\n process.exit(1);\n }\n });\n\n /**\n * Create test fixtures\n */\n testCmd\n .command('fixtures <component>')\n .description('Create test fixtures for component')\n .option('--output <path>', 'Output directory for fixtures')\n .action(async (component: string, options: any) => {\n const spinner = ora('Creating test fixtures...').start();\n \n try {\n const agent = new TestingAgent();\n const fixtures = agent.createTestFixtures(component);\n \n spinner.succeed(`Created ${fixtures.length} fixtures for ${component}`);\n \n // Save fixtures\n if (options.output) {\n const { writeFileSync, mkdirSync } = await import('fs');\n const outputDir = join(process.cwd(), options.output);\n mkdirSync(outputDir, { recursive: true });\n \n fixtures.forEach(fixture => {\n const filePath = join(outputDir, `${fixture.name}.fixture.json`);\n writeFileSync(filePath, JSON.stringify(fixture.data, null, 2));\n console.log(chalk.gray(` \u2022 ${fixture.name} \u2192 ${filePath}`));\n });\n \n console.log(chalk.green(`\\n\u2705 Fixtures saved to ${options.output}`));\n } else {\n console.log(chalk.cyan('\\n\uD83D\uDD27 Test Fixtures:'));\n fixtures.forEach(fixture => {\n console.log(chalk.yellow(`\\n${fixture.name}:`));\n console.log(JSON.stringify(fixture.data, null, 2));\n });\n }\n \n } catch (error) {\n spinner.fail('Fixture creation failed');\n logger.error('Failed to create fixtures', { error, component, options });\n console.error(chalk.red('Error:'), (error as Error).message);\n process.exit(1);\n }\n });\n\n /**\n * Benchmark performance\n */\n testCmd\n .command('benchmark <target>')\n .description('Run performance benchmarks')\n .option('--function <name>', 'Specific function to benchmark')\n .option('--iterations <n>', 'Number of iterations', '1000')\n .option('--threshold <ms>', 'Performance threshold in milliseconds')\n .action(async (target: string, options: any) => {\n const spinner = ora('Running performance benchmarks...').start();\n \n try {\n const agent = new TestingAgent();\n const targetPath = join(process.cwd(), target);\n const functionName = options.function || 'default';\n \n const report = await agent.benchmarkPerformance(targetPath, functionName);\n spinner.succeed('Benchmark complete');\n \n // Display report\n console.log(chalk.cyan('\\n\u26A1 Performance Benchmark Report:'));\n console.log(chalk.gray('\u2500'.repeat(50)));\n console.log(chalk.gray(' Function:'), report.function);\n console.log(chalk.gray(' Average:'), `${report.averageTime.toFixed(3)}ms`);\n console.log(chalk.gray(' Min:'), `${report.minTime.toFixed(3)}ms`);\n console.log(chalk.gray(' Max:'), `${report.maxTime.toFixed(3)}ms`);\n console.log(chalk.gray(' Iterations:'), report.iterations);\n console.log(chalk.gray(' Memory:'), `${(report.memoryUsage / 1024 / 1024).toFixed(2)}MB`);\n \n // Check threshold\n if (options.threshold) {\n const threshold = parseFloat(options.threshold);\n if (report.averageTime <= threshold) {\n console.log(chalk.green(`\\n\u2705 Performance within threshold (${threshold}ms)`));\n } else {\n console.log(chalk.red(`\\n\u274C Performance exceeds threshold (${threshold}ms)`));\n process.exit(1);\n }\n }\n \n } catch (error) {\n spinner.fail('Benchmark failed');\n logger.error('Failed to run benchmark', { error, target, options });\n console.error(chalk.red('Error:'), (error as Error).message);\n process.exit(1);\n }\n });\n\n return testCmd;\n}\n\n// Helper functions\n\nasync function getFunctionsFromFile(filePath: string): Promise<string[]> {\n // This would use TypeScript compiler API to extract function names\n // For now, return a placeholder\n return ['main', 'helper', 'util'];\n}\n\nfunction formatTestPreview(testSuite: any): string {\n const preview = [`File: ${testSuite.filePath}`, `Describe: ${testSuite.describe}`, ''];\n \n testSuite.tests.forEach((test: any) => {\n preview.push(` \u2713 ${test.name}`);\n });\n \n return preview.join('\\n');\n}\n\nfunction displayCoverageReport(coverage: any): void {\n const formatPercent = (percent: number) => {\n if (percent >= 80) return chalk.green(`${percent}%`);\n if (percent >= 60) return chalk.yellow(`${percent}%`);\n return chalk.red(`${percent}%`);\n };\n \n console.log(chalk.gray(' Lines:'), formatPercent(coverage.lines.percentage), \n `(${coverage.lines.covered}/${coverage.lines.total})`);\n console.log(chalk.gray(' Branches:'), formatPercent(coverage.branches.percentage),\n `(${coverage.branches.covered}/${coverage.branches.total})`);\n console.log(chalk.gray(' Functions:'), formatPercent(coverage.functions.percentage),\n `(${coverage.functions.covered}/${coverage.functions.total})`);\n}\n\n// Export for CLI\nif (import.meta.url === `file://${process.argv[1]}`) {\n const program = new Command();\n program.addCommand(createTestCommand());\n program.parse(process.argv);\n}"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -6,7 +6,11 @@ import chalk from "chalk";
6
6
  import Table from "cli-table3";
7
7
  import { existsSync } from "fs";
8
8
  import Database from "better-sqlite3";
9
- import { execSync } from "child_process";
9
+ import { execFileSync } from "child_process";
10
+ import { z } from "zod";
11
+ const BranchNameSchema = z.string().min(1, "Branch name cannot be empty").max(100, "Branch name too long").regex(/^[a-zA-Z0-9._/-]+$/, "Branch name contains invalid characters").refine((name) => !name.includes(".."), 'Branch name cannot contain ".."').refine((name) => !name.includes(";"), 'Branch name cannot contain ";"').refine((name) => !name.includes("&"), 'Branch name cannot contain "&"').refine((name) => !name.includes("|"), 'Branch name cannot contain "|"').refine((name) => !name.includes("$"), 'Branch name cannot contain "$"').refine((name) => !name.includes("`"), 'Branch name cannot contain "`"');
12
+ const PathSchema = z.string().min(1, "Path cannot be empty").max(500, "Path too long").regex(/^[a-zA-Z0-9._/-]+$/, "Path contains invalid characters").refine((path) => !path.includes(".."), 'Path cannot contain ".."');
13
+ const CommitSchema = z.string().min(1, "Commit reference cannot be empty").max(100, "Commit reference too long").regex(/^[a-zA-Z0-9._/-]+$/, "Commit reference contains invalid characters");
10
14
  function registerWorktreeCommands(program) {
11
15
  const worktree = program.command("worktree").alias("wt").description("Manage StackMemory across git worktrees");
12
16
  worktree.command("enable").description("Enable worktree support").option(
@@ -154,14 +158,21 @@ Detected ${worktrees.length} worktree(s):`));
154
158
  const manager = WorktreeManager.getInstance();
155
159
  const projectManager = ProjectManager.getInstance();
156
160
  try {
161
+ const validatedBranch = BranchNameSchema.parse(branch);
157
162
  const project = await projectManager.detectProject();
158
- const worktreePath = options.path || `../${project.name}-${branch}`;
159
- let gitCommand = `git worktree add -b ${branch} ${worktreePath}`;
163
+ const worktreePath = options.path || `../${project.name}-${validatedBranch}`;
164
+ if (options.path) {
165
+ PathSchema.parse(options.path);
166
+ }
167
+ if (options.from) {
168
+ CommitSchema.parse(options.from);
169
+ }
170
+ const gitArgs = ["worktree", "add", "-b", validatedBranch, worktreePath];
160
171
  if (options.from) {
161
- gitCommand += ` ${options.from}`;
172
+ gitArgs.push(options.from);
162
173
  }
163
- console.log(chalk.gray(`Creating worktree: ${gitCommand}`));
164
- execSync(gitCommand, { stdio: "inherit" });
174
+ console.log(chalk.gray(`Creating worktree: git ${gitArgs.join(" ")}`));
175
+ execFileSync("git", gitArgs, { stdio: "inherit" });
165
176
  console.log(chalk.green(`\u2713 Created worktree at ${worktreePath}`));
166
177
  if (manager.isEnabled()) {
167
178
  const context = manager.getWorktreeContext(worktreePath);
@@ -182,10 +193,17 @@ Detected ${worktrees.length} worktree(s):`));
182
193
  }
183
194
  console.log(chalk.gray(" # Start working in isolated context"));
184
195
  } catch (error) {
185
- console.error(
186
- chalk.red("Failed to create worktree:"),
187
- error.message
188
- );
196
+ if (error instanceof z.ZodError) {
197
+ console.error(chalk.red("Invalid input:"));
198
+ error.errors.forEach((err) => {
199
+ console.error(chalk.red(` ${err.path.join(".")}: ${err.message}`));
200
+ });
201
+ } else {
202
+ console.error(
203
+ chalk.red("Failed to create worktree:"),
204
+ error.message
205
+ );
206
+ }
189
207
  process.exit(1);
190
208
  }
191
209
  });