workflow-agent-cli 2.22.9 → 2.22.11

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.
@@ -214,6 +214,7 @@ async function recordSuccessfulFixes(cwd, result) {
214
214
  frameworkVersion
215
215
  );
216
216
  console.log(chalk.dim(` \u2713 Recorded: ${patternName}`));
217
+ console.log(chalk.dim(` Path: .workflow/patterns/fixes/${newPattern.id}.json`));
217
218
  }
218
219
  }
219
220
  }
@@ -235,4 +236,4 @@ async function recordSuccessfulFixes(cwd, result) {
235
236
  export {
236
237
  verifyCommand
237
238
  };
238
- //# sourceMappingURL=chunk-3ARRW423.js.map
239
+ //# sourceMappingURL=chunk-D36IFZUZ.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/cli/commands/verify.ts"],"sourcesContent":["import chalk from \"chalk\";\nimport {\n runAllChecks,\n hasUncommittedChanges,\n stageAllChanges,\n type RunAllChecksResult,\n} from \"../../utils/check-runner.js\";\nimport { execa } from \"execa\";\nimport {\n PatternStore,\n TelemetryCollector,\n ContributorManager,\n type FixPattern,\n} from \"@hawkinside_out/workflow-improvement-tracker\";\n\ninterface VerifyOptions {\n fix?: boolean;\n maxRetries?: string;\n commit?: boolean;\n dryRun?: boolean;\n learn?: boolean;\n}\n\n/**\n * Verify command - Run all quality checks with fix-and-revalidate pattern\n *\n * Pattern: Run check → If fails, fix → Re-run ALL checks from start\n * This ensures fixes don't introduce new issues in earlier checks.\n */\nexport async function verifyCommand(options: VerifyOptions) {\n const cwd = process.cwd();\n const maxRetries = options.maxRetries ? parseInt(options.maxRetries, 10) : 10;\n const autoFix = options.fix ?? false;\n const shouldCommit = options.commit ?? false;\n const dryRun = options.dryRun ?? false;\n const learnFromFixes = options.learn ?? false;\n\n console.log(chalk.bold.cyan(\"\\n🔍 Workflow Agent Quality Verification\\n\"));\n\n if (dryRun) {\n console.log(chalk.yellow(\"📋 DRY-RUN MODE: No changes will be applied\\n\"));\n }\n\n console.log(chalk.dim(` Auto-fix: ${autoFix ? \"enabled\" : \"disabled\"}`));\n console.log(chalk.dim(` Max retries: ${maxRetries}`));\n console.log(chalk.dim(` Commit on success: ${shouldCommit ? \"yes\" : \"no\"}`));\n console.log(chalk.dim(` Dry-run: ${dryRun ? \"yes\" : \"no\"}`));\n console.log(\n chalk.dim(` Learn from fixes: ${learnFromFixes ? \"yes\" : \"no\"}`),\n );\n\n const startTime = Date.now();\n\n const result = await runAllChecks(cwd, {\n maxRetries,\n autoFix,\n dryRun,\n });\n\n const totalTime = ((Date.now() - startTime) / 1000).toFixed(2);\n\n console.log(`\\n${\"━\".repeat(50)}`);\n\n if (result.success) {\n console.log(chalk.bold.green(\"\\n✅ ALL QUALITY CHECKS PASSED!\\n\"));\n console.log(chalk.dim(` Total time: ${totalTime}s`));\n console.log(chalk.dim(` Validation cycles: ${result.totalAttempts}`));\n console.log(chalk.dim(` Fixes applied: ${result.fixesApplied}`));\n\n // Auto-record successful fix patterns if learning is enabled\n if (learnFromFixes && result.fixesApplied > 0 && !dryRun) {\n await recordSuccessfulFixes(cwd, result);\n }\n\n // Handle commit if requested\n if (shouldCommit) {\n const hasChanges = await hasUncommittedChanges(cwd);\n\n if (hasChanges) {\n console.log(chalk.cyan(\"\\n📦 Staging and committing changes...\\n\"));\n\n const staged = await stageAllChanges(cwd);\n if (!staged) {\n console.log(chalk.red(\"❌ Failed to stage changes\"));\n process.exit(1);\n }\n\n try {\n await execa(\n \"git\",\n [\"commit\", \"-m\", \"chore: auto-fix quality issues\"],\n { cwd },\n );\n console.log(chalk.green(\"✅ Changes committed successfully\"));\n } catch (error) {\n console.log(chalk.red(\"❌ Failed to commit changes\"));\n console.log(chalk.dim((error as Error).message));\n process.exit(1);\n }\n } else {\n console.log(chalk.dim(\"\\n No changes to commit.\"));\n }\n }\n\n console.log(chalk.cyan(\"\\n💡 Next steps:\\n\"));\n console.log(chalk.dim(\" 1. git add .\"));\n console.log(\n chalk.dim(' 2. git commit -m \"<type>(<scope>): <description>\"'),\n );\n console.log(chalk.dim(\" 3. git push origin <branch-name>\"));\n console.log(\"\");\n\n process.exit(0);\n } else {\n console.log(chalk.bold.red(\"\\n❌ QUALITY CHECKS FAILED\\n\"));\n console.log(chalk.dim(` Total time: ${totalTime}s`));\n console.log(chalk.dim(` Validation cycles: ${result.totalAttempts}`));\n console.log(chalk.dim(` Fixes applied: ${result.fixesApplied}`));\n\n if (result.pendingFixes && result.pendingFixes.length > 0) {\n console.log(chalk.yellow(\"\\n📋 Pending fixes (dry-run):\"));\n for (const fix of result.pendingFixes) {\n console.log(chalk.dim(` • ${fix.check.displayName}: ${fix.command}`));\n }\n }\n\n console.log(\n chalk.yellow(\"\\n⚠️ Please fix the errors above and run again.\"),\n );\n console.log(\n chalk.dim(\" Run with --fix to auto-fix lint and format issues.\"),\n );\n console.log(\"\");\n\n process.exit(1);\n }\n}\n\n// ============================================\n// Auto-Record Learning Pattern\n// ============================================\n\n/**\n * Record successful fix patterns for learning\n * Called after verify succeeds with auto-fixes applied\n */\nasync function recordSuccessfulFixes(\n cwd: string,\n result: RunAllChecksResult,\n): Promise<void> {\n try {\n // Check if telemetry is enabled\n const contributorManager = new ContributorManager(cwd);\n const telemetryEnabled = await contributorManager.isTelemetryEnabled();\n\n if (!telemetryEnabled) {\n // Silently skip if telemetry is disabled\n return;\n }\n\n const store = new PatternStore(cwd);\n const telemetry = new TelemetryCollector(cwd);\n\n // Get package.json to determine framework\n let framework = \"unknown\";\n let frameworkVersion = \"0.0.0\";\n\n try {\n const fs = await import(\"node:fs\");\n const path = await import(\"node:path\");\n const packageJsonPath = path.join(cwd, \"package.json\");\n const packageJson = JSON.parse(\n await fs.promises.readFile(packageJsonPath, \"utf-8\"),\n );\n\n // Detect framework from dependencies\n const deps = {\n ...packageJson.dependencies,\n ...packageJson.devDependencies,\n };\n\n if (deps[\"next\"]) {\n framework = \"next\";\n frameworkVersion = deps[\"next\"].replace(/[\\^~]/, \"\");\n } else if (deps[\"react\"]) {\n framework = \"react\";\n frameworkVersion = deps[\"react\"].replace(/[\\^~]/, \"\");\n } else if (deps[\"vue\"]) {\n framework = \"vue\";\n frameworkVersion = deps[\"vue\"].replace(/[\\^~]/, \"\");\n } else if (deps[\"express\"]) {\n framework = \"express\";\n frameworkVersion = deps[\"express\"].replace(/[\\^~]/, \"\");\n }\n } catch {\n // Ignore package.json read errors\n }\n\n // Record telemetry for each fix applied\n if (result.appliedFixes && result.appliedFixes.length > 0) {\n console.log(\n chalk.cyan(\"\\n📚 Recording successful fixes for learning...\\n\"),\n );\n\n for (const fix of result.appliedFixes) {\n // Create or find existing pattern for this fix type\n const patternName = `Auto-fix: ${fix.displayName}`;\n const patternId = crypto.randomUUID();\n\n // Check if we already have a pattern for this fix type\n const existingPatterns = await store.listFixPatterns({\n tags: [{ category: \"tool\", name: fix.checkName }],\n });\n\n if (\n existingPatterns.success &&\n existingPatterns.data &&\n existingPatterns.data.length > 0\n ) {\n // Update metrics on existing pattern\n const existingPattern = existingPatterns.data[0];\n await store.updateFixMetrics(existingPattern.id, true);\n await telemetry.recordSuccess(\n existingPattern.id,\n \"fix\",\n framework,\n frameworkVersion,\n );\n console.log(chalk.dim(` ✓ Updated: ${existingPattern.name}`));\n } else {\n // Create new pattern\n const now = new Date().toISOString();\n const newPattern: FixPattern = {\n id: patternId,\n name: patternName,\n description: `Auto-fix pattern for ${fix.displayName} using command: ${fix.command}`,\n category: \"config\",\n tags: [\n { category: \"tool\", name: fix.checkName },\n { category: \"framework\", name: framework },\n ],\n trigger: {\n errorPattern: fix.checkName,\n errorMessage: `${fix.checkName} check failed`,\n filePattern: \"**/*\",\n },\n solution: {\n type: \"command\",\n steps: [\n {\n order: 1,\n action: \"run\",\n target: fix.command,\n description: `Run ${fix.command}`,\n },\n ],\n },\n compatibility: {\n framework,\n frameworkVersion: `>=${frameworkVersion}`,\n runtime: \"node\",\n runtimeVersion: \">=18.0.0\",\n dependencies: [],\n },\n metrics: {\n applications: 1,\n successes: 1,\n failures: 0,\n successRate: 100,\n lastUsed: now,\n lastSuccessful: now,\n },\n source: \"verify-fix\",\n isPrivate: true,\n createdAt: now,\n updatedAt: now,\n };\n\n const saveResult = await store.saveFixPattern(newPattern);\n if (saveResult.success) {\n await telemetry.recordSuccess(\n patternId,\n \"fix\",\n framework,\n frameworkVersion,\n );\n console.log(chalk.dim(` ✓ Recorded: ${patternName}`));\n }\n }\n }\n\n console.log(\n chalk.dim(`\\n Use 'workflow learn:list' to see recorded patterns.`),\n );\n }\n } catch (error) {\n // Don't fail the verify command if learning fails\n console.log(\n chalk.dim(\n `\\n Note: Could not record learning patterns: ${(error as Error).message}`,\n ),\n );\n }\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../src/cli/commands/verify.ts"],"sourcesContent":["import chalk from \"chalk\";\nimport {\n runAllChecks,\n hasUncommittedChanges,\n stageAllChanges,\n type RunAllChecksResult,\n} from \"../../utils/check-runner.js\";\nimport { execa } from \"execa\";\nimport {\n PatternStore,\n TelemetryCollector,\n ContributorManager,\n type FixPattern,\n} from \"@hawkinside_out/workflow-improvement-tracker\";\n\ninterface VerifyOptions {\n fix?: boolean;\n maxRetries?: string;\n commit?: boolean;\n dryRun?: boolean;\n learn?: boolean;\n}\n\n/**\n * Verify command - Run all quality checks with fix-and-revalidate pattern\n *\n * Pattern: Run check → If fails, fix → Re-run ALL checks from start\n * This ensures fixes don't introduce new issues in earlier checks.\n */\nexport async function verifyCommand(options: VerifyOptions) {\n const cwd = process.cwd();\n const maxRetries = options.maxRetries ? parseInt(options.maxRetries, 10) : 10;\n const autoFix = options.fix ?? false;\n const shouldCommit = options.commit ?? false;\n const dryRun = options.dryRun ?? false;\n const learnFromFixes = options.learn ?? false;\n\n console.log(chalk.bold.cyan(\"\\n🔍 Workflow Agent Quality Verification\\n\"));\n\n if (dryRun) {\n console.log(chalk.yellow(\"📋 DRY-RUN MODE: No changes will be applied\\n\"));\n }\n\n console.log(chalk.dim(` Auto-fix: ${autoFix ? \"enabled\" : \"disabled\"}`));\n console.log(chalk.dim(` Max retries: ${maxRetries}`));\n console.log(chalk.dim(` Commit on success: ${shouldCommit ? \"yes\" : \"no\"}`));\n console.log(chalk.dim(` Dry-run: ${dryRun ? \"yes\" : \"no\"}`));\n console.log(\n chalk.dim(` Learn from fixes: ${learnFromFixes ? \"yes\" : \"no\"}`),\n );\n\n const startTime = Date.now();\n\n const result = await runAllChecks(cwd, {\n maxRetries,\n autoFix,\n dryRun,\n });\n\n const totalTime = ((Date.now() - startTime) / 1000).toFixed(2);\n\n console.log(`\\n${\"━\".repeat(50)}`);\n\n if (result.success) {\n console.log(chalk.bold.green(\"\\n✅ ALL QUALITY CHECKS PASSED!\\n\"));\n console.log(chalk.dim(` Total time: ${totalTime}s`));\n console.log(chalk.dim(` Validation cycles: ${result.totalAttempts}`));\n console.log(chalk.dim(` Fixes applied: ${result.fixesApplied}`));\n\n // Auto-record successful fix patterns if learning is enabled\n if (learnFromFixes && result.fixesApplied > 0 && !dryRun) {\n await recordSuccessfulFixes(cwd, result);\n }\n\n // Handle commit if requested\n if (shouldCommit) {\n const hasChanges = await hasUncommittedChanges(cwd);\n\n if (hasChanges) {\n console.log(chalk.cyan(\"\\n📦 Staging and committing changes...\\n\"));\n\n const staged = await stageAllChanges(cwd);\n if (!staged) {\n console.log(chalk.red(\"❌ Failed to stage changes\"));\n process.exit(1);\n }\n\n try {\n await execa(\n \"git\",\n [\"commit\", \"-m\", \"chore: auto-fix quality issues\"],\n { cwd },\n );\n console.log(chalk.green(\"✅ Changes committed successfully\"));\n } catch (error) {\n console.log(chalk.red(\"❌ Failed to commit changes\"));\n console.log(chalk.dim((error as Error).message));\n process.exit(1);\n }\n } else {\n console.log(chalk.dim(\"\\n No changes to commit.\"));\n }\n }\n\n console.log(chalk.cyan(\"\\n💡 Next steps:\\n\"));\n console.log(chalk.dim(\" 1. git add .\"));\n console.log(\n chalk.dim(' 2. git commit -m \"<type>(<scope>): <description>\"'),\n );\n console.log(chalk.dim(\" 3. git push origin <branch-name>\"));\n console.log(\"\");\n\n process.exit(0);\n } else {\n console.log(chalk.bold.red(\"\\n❌ QUALITY CHECKS FAILED\\n\"));\n console.log(chalk.dim(` Total time: ${totalTime}s`));\n console.log(chalk.dim(` Validation cycles: ${result.totalAttempts}`));\n console.log(chalk.dim(` Fixes applied: ${result.fixesApplied}`));\n\n if (result.pendingFixes && result.pendingFixes.length > 0) {\n console.log(chalk.yellow(\"\\n📋 Pending fixes (dry-run):\"));\n for (const fix of result.pendingFixes) {\n console.log(chalk.dim(` • ${fix.check.displayName}: ${fix.command}`));\n }\n }\n\n console.log(\n chalk.yellow(\"\\n⚠️ Please fix the errors above and run again.\"),\n );\n console.log(\n chalk.dim(\" Run with --fix to auto-fix lint and format issues.\"),\n );\n console.log(\"\");\n\n process.exit(1);\n }\n}\n\n// ============================================\n// Auto-Record Learning Pattern\n// ============================================\n\n/**\n * Record successful fix patterns for learning\n * Called after verify succeeds with auto-fixes applied\n */\nasync function recordSuccessfulFixes(\n cwd: string,\n result: RunAllChecksResult,\n): Promise<void> {\n try {\n // Check if telemetry is enabled\n const contributorManager = new ContributorManager(cwd);\n const telemetryEnabled = await contributorManager.isTelemetryEnabled();\n\n if (!telemetryEnabled) {\n // Silently skip if telemetry is disabled\n return;\n }\n\n const store = new PatternStore(cwd);\n const telemetry = new TelemetryCollector(cwd);\n\n // Get package.json to determine framework\n let framework = \"unknown\";\n let frameworkVersion = \"0.0.0\";\n\n try {\n const fs = await import(\"node:fs\");\n const path = await import(\"node:path\");\n const packageJsonPath = path.join(cwd, \"package.json\");\n const packageJson = JSON.parse(\n await fs.promises.readFile(packageJsonPath, \"utf-8\"),\n );\n\n // Detect framework from dependencies\n const deps = {\n ...packageJson.dependencies,\n ...packageJson.devDependencies,\n };\n\n if (deps[\"next\"]) {\n framework = \"next\";\n frameworkVersion = deps[\"next\"].replace(/[\\^~]/, \"\");\n } else if (deps[\"react\"]) {\n framework = \"react\";\n frameworkVersion = deps[\"react\"].replace(/[\\^~]/, \"\");\n } else if (deps[\"vue\"]) {\n framework = \"vue\";\n frameworkVersion = deps[\"vue\"].replace(/[\\^~]/, \"\");\n } else if (deps[\"express\"]) {\n framework = \"express\";\n frameworkVersion = deps[\"express\"].replace(/[\\^~]/, \"\");\n }\n } catch {\n // Ignore package.json read errors\n }\n\n // Record telemetry for each fix applied\n if (result.appliedFixes && result.appliedFixes.length > 0) {\n console.log(\n chalk.cyan(\"\\n📚 Recording successful fixes for learning...\\n\"),\n );\n\n for (const fix of result.appliedFixes) {\n // Create or find existing pattern for this fix type\n const patternName = `Auto-fix: ${fix.displayName}`;\n const patternId = crypto.randomUUID();\n\n // Check if we already have a pattern for this fix type\n const existingPatterns = await store.listFixPatterns({\n tags: [{ category: \"tool\", name: fix.checkName }],\n });\n\n if (\n existingPatterns.success &&\n existingPatterns.data &&\n existingPatterns.data.length > 0\n ) {\n // Update metrics on existing pattern\n const existingPattern = existingPatterns.data[0];\n await store.updateFixMetrics(existingPattern.id, true);\n await telemetry.recordSuccess(\n existingPattern.id,\n \"fix\",\n framework,\n frameworkVersion,\n );\n console.log(chalk.dim(` ✓ Updated: ${existingPattern.name}`));\n } else {\n // Create new pattern\n const now = new Date().toISOString();\n const newPattern: FixPattern = {\n id: patternId,\n name: patternName,\n description: `Auto-fix pattern for ${fix.displayName} using command: ${fix.command}`,\n category: \"config\",\n tags: [\n { category: \"tool\", name: fix.checkName },\n { category: \"framework\", name: framework },\n ],\n trigger: {\n errorPattern: fix.checkName,\n errorMessage: `${fix.checkName} check failed`,\n filePattern: \"**/*\",\n },\n solution: {\n type: \"command\",\n steps: [\n {\n order: 1,\n action: \"run\",\n target: fix.command,\n description: `Run ${fix.command}`,\n },\n ],\n },\n compatibility: {\n framework,\n frameworkVersion: `>=${frameworkVersion}`,\n runtime: \"node\",\n runtimeVersion: \">=18.0.0\",\n dependencies: [],\n },\n metrics: {\n applications: 1,\n successes: 1,\n failures: 0,\n successRate: 100,\n lastUsed: now,\n lastSuccessful: now,\n },\n source: \"verify-fix\",\n isPrivate: true,\n createdAt: now,\n updatedAt: now,\n };\n\n const saveResult = await store.saveFixPattern(newPattern);\n if (saveResult.success) {\n await telemetry.recordSuccess(\n patternId,\n \"fix\",\n framework,\n frameworkVersion,\n );\n console.log(chalk.dim(` ✓ Recorded: ${patternName}`));\n console.log(chalk.dim(` Path: .workflow/patterns/fixes/${newPattern.id}.json`));\n }\n }\n }\n\n console.log(\n chalk.dim(`\\n Use 'workflow learn:list' to see recorded patterns.`),\n );\n }\n } catch (error) {\n // Don't fail the verify command if learning fails\n console.log(\n chalk.dim(\n `\\n Note: Could not record learning patterns: ${(error as Error).message}`,\n ),\n );\n }\n}\n"],"mappings":"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","names":[]}
package/dist/cli/index.js CHANGED
@@ -36,7 +36,7 @@ import {
36
36
  } from "../chunk-YELUGXOM.js";
37
37
  import {
38
38
  verifyCommand
39
- } from "../chunk-3ARRW423.js";
39
+ } from "../chunk-D36IFZUZ.js";
40
40
  import "../chunk-3ADL5QDN.js";
41
41
  import {
42
42
  syncCommand
@@ -5188,7 +5188,7 @@ async function testAction(options) {
5188
5188
  if (options.dryRun) {
5189
5189
  console.log(chalk17.bold.cyan("\n Dry-run hook simulation:\n"));
5190
5190
  console.log(chalk17.dim(" Simulating pre-commit hook..."));
5191
- const { verifyCommand: verifyCommand2 } = await import("../verify-XGCZKY7S.js");
5191
+ const { verifyCommand: verifyCommand2 } = await import("../verify-TX6LFMI6.js");
5192
5192
  try {
5193
5193
  await verifyCommand2({ fix: false, dryRun: true, maxRetries: "1" });
5194
5194
  } catch {
@@ -6619,6 +6619,7 @@ async function learnRecordCommand(options) {
6619
6619
  console.log(chalk20.dim(` ID: ${blueprint.id}`));
6620
6620
  console.log(chalk20.dim(` Name: ${name}`));
6621
6621
  console.log(chalk20.dim(` Framework: ${framework} ${version}`));
6622
+ console.log(chalk20.dim(` Path: .workflow/patterns/blueprints/${blueprint.id}.json`));
6622
6623
  } else {
6623
6624
  console.log(chalk20.red("\n\u274C Failed to record blueprint"));
6624
6625
  console.log(chalk20.dim(` Error: ${result.error}`));
@@ -7868,6 +7869,7 @@ async function learnCaptureCommand(paths, options) {
7868
7869
  console.log(chalk20.dim(`Name: ${name}`));
7869
7870
  console.log(chalk20.dim(`Files: ${files.length}`));
7870
7871
  console.log(chalk20.dim(`Tags: ${formatTags(uniqueTags)}`));
7872
+ console.log(chalk20.dim(`Path: .workflow/patterns/blueprints/${blueprint.id}.json`));
7871
7873
  console.log(chalk20.dim(`
7872
7874
  To apply this pattern:`));
7873
7875
  console.log(chalk20.cyan(` pnpm workflow:learn:apply ${blueprint.id}`));