@codeyam/codeyam-cli 0.1.0-staging.483fdc2 → 0.1.0-staging.4c0c3c9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/analyzer-template/.build-info.json +7 -7
- package/analyzer-template/log.txt +3 -3
- package/analyzer-template/package.json +4 -4
- package/analyzer-template/packages/ai/index.ts +1 -0
- package/analyzer-template/packages/ai/package.json +2 -2
- package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +23 -1
- package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
- package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +101 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +6 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +330 -9
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +11 -2
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +2 -2
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +20 -1
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +84 -19
- package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +33 -15
- package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
- package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +46 -5
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +38 -2
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +359 -142
- package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
- package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
- package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
- package/analyzer-template/packages/analyze/index.ts +2 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +69 -3
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +5 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1315 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +4 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +59 -26
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +194 -15
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +372 -57
- package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
- package/analyzer-template/packages/database/package.json +1 -1
- package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/kysely/db.ts +6 -0
- package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
- package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
- package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
- package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +3 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
- package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +7 -0
- package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
- package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +7 -0
- package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +7 -0
- package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +93 -2
- package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
- package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +108 -2
- package/analyzer-template/project/constructMockCode.ts +38 -3
- package/analyzer-template/project/writeMockDataTsx.ts +119 -17
- package/analyzer-template/project/writeScenarioComponents.ts +60 -12
- package/analyzer-template/project/writeSimpleRoot.ts +21 -11
- package/background/src/lib/local/createLocalAnalyzer.js +1 -1
- package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
- package/background/src/lib/virtualized/project/constructMockCode.js +32 -3
- package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
- package/background/src/lib/virtualized/project/writeMockDataTsx.js +102 -13
- package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
- package/background/src/lib/virtualized/project/writeScenarioComponents.js +60 -15
- package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
- package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
- package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
- package/codeyam-cli/scripts/apply-setup.js +44 -10
- package/codeyam-cli/scripts/apply-setup.js.map +1 -1
- package/codeyam-cli/src/cli.js +2 -0
- package/codeyam-cli/src/cli.js.map +1 -1
- package/codeyam-cli/src/codeyam-cli.js +18 -2
- package/codeyam-cli/src/codeyam-cli.js.map +1 -1
- package/codeyam-cli/src/commands/analyze.js +4 -2
- package/codeyam-cli/src/commands/analyze.js.map +1 -1
- package/codeyam-cli/src/commands/baseline.js +2 -0
- package/codeyam-cli/src/commands/baseline.js.map +1 -1
- package/codeyam-cli/src/commands/debug.js +2 -0
- package/codeyam-cli/src/commands/debug.js.map +1 -1
- package/codeyam-cli/src/commands/default.js +31 -20
- package/codeyam-cli/src/commands/default.js.map +1 -1
- package/codeyam-cli/src/commands/detect-universal-mocks.js +2 -0
- package/codeyam-cli/src/commands/detect-universal-mocks.js.map +1 -1
- package/codeyam-cli/src/commands/init.js +49 -257
- package/codeyam-cli/src/commands/init.js.map +1 -1
- package/codeyam-cli/src/commands/memory.js +17 -26
- package/codeyam-cli/src/commands/memory.js.map +1 -1
- package/codeyam-cli/src/commands/recapture.js +2 -0
- package/codeyam-cli/src/commands/recapture.js.map +1 -1
- package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
- package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
- package/codeyam-cli/src/commands/setup-simulations.js +284 -0
- package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
- package/codeyam-cli/src/commands/test-startup.js +2 -0
- package/codeyam-cli/src/commands/test-startup.js.map +1 -1
- package/codeyam-cli/src/commands/verify.js +14 -2
- package/codeyam-cli/src/commands/verify.js.map +1 -1
- package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +179 -0
- package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +128 -86
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
- package/codeyam-cli/src/utils/analyzer.js +7 -0
- package/codeyam-cli/src/utils/analyzer.js.map +1 -1
- package/codeyam-cli/src/utils/backgroundServer.js +90 -19
- package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/utils/generateReport.js +2 -2
- package/codeyam-cli/src/utils/install-skills.js +57 -54
- package/codeyam-cli/src/utils/install-skills.js.map +1 -1
- package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
- package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
- package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
- package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
- package/codeyam-cli/src/utils/progress.js +7 -0
- package/codeyam-cli/src/utils/progress.js.map +1 -1
- package/codeyam-cli/src/utils/queue/job.js +4 -0
- package/codeyam-cli/src/utils/queue/job.js.map +1 -1
- package/codeyam-cli/src/utils/requireSimulations.js +10 -0
- package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +230 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +75 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +378 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +115 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
- package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
- package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
- package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
- package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
- package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
- package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
- package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
- package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
- package/codeyam-cli/src/utils/rules/index.js +1 -0
- package/codeyam-cli/src/utils/rules/index.js.map +1 -1
- package/codeyam-cli/src/utils/rules/parser.js +2 -25
- package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
- package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
- package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
- package/codeyam-cli/src/utils/rules/staleness.js +16 -11
- package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
- package/codeyam-cli/src/utils/serverState.js +37 -10
- package/codeyam-cli/src/utils/serverState.js.map +1 -1
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +21 -44
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
- package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
- package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
- package/codeyam-cli/src/webserver/app/lib/database.js +15 -3
- package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
- package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
- package/codeyam-cli/src/webserver/backgroundServer.js +50 -0
- package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/webserver/bootstrap.js +11 -0
- package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/CopyButton-jNYXRRNI.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-bwuHPyTa.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-CvzqMxcu.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-BH0XDim7.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{InlineSpinner-C8lyxW9k.js → InlineSpinner-EhOseatT.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-aht4aafF.js → InteractivePreview-yjIHlOGa.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-Cq5o8jL4.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BvMu2i-g.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-kgBTLoJD.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-BzPgx-xO.js} +3 -8
- package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-CwZrv-Ok.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-BX2Ny2Qj.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-CDpEprKa.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-BRx8ZGZo.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-4S4yPfFw.js} +6 -11
- package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DHKuQSmR.js +17 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/book-open-D4IPYH_y.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-CG65viiV.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-DB3aFuEO.js} +12 -12
- package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-igfMr5DY.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/copy-Coc4o_8c.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-BdhJEx6B.js → createLucideIcon-D1zB-pYc.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{dev.empty-BBnGWYga.js → dev.empty-JTAjQ54M.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BJUiQqZF.js → entity._sha._-B0h9AqE6.js} +10 -10
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js → entity._sha.scenarios._scenarioId.fullscreen-DjLxr2JB.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.create-scenario-D1T4TGjf.js → entity._sha_.create-scenario-CtYowLOt.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-PePWg17F.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-I-Wo99C_.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-9sMMAiWJ.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{files-CJ6lTdTA.js → files-Co65J0s3.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{git-CPTZZ-JZ.js → git-BdHOxVfg.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/globals-CCgBKWy4.css +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-CUM5iXwc.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-_417gcQW.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/labs-BK0C1H1T.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-TzRHMVog.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-390cb8fa.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/memory-CzZySbBE.js +78 -0
- package/codeyam-cli/src/webserver/build/client/assets/pause-hjzB7t2z.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/root-DnbDhvTU.js +62 -0
- package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-DcAwD_Ln.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/settings-CclxrcPK.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{simulations-DwFIBT09.js → simulations-DVNJVQgD.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/terminal-DbEAHMbA.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-CAD5b1o_.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useCustomSizes-C1v1PQzo.js → useCustomSizes-BqgrAzs3.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-aSv48UbS.js → useLastLogLine-DAFqfEDH.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DYxHZQuP.js → useReportContext-DZlYx2c4.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-ihdMtlf6.js} +1 -1
- package/codeyam-cli/src/webserver/build/server/assets/{index-TD1f-DHV.js → index-CxaRxKVt.js} +1 -1
- package/codeyam-cli/src/webserver/build/server/assets/server-build-D4DT0nM_.js +259 -0
- package/codeyam-cli/src/webserver/build/server/index.js +1 -1
- package/codeyam-cli/src/webserver/build-info.json +5 -5
- package/codeyam-cli/templates/{codeyam:debug.md → codeyam-debug.md} +1 -1
- package/codeyam-cli/templates/codeyam-diagnose.md +481 -0
- package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
- package/codeyam-cli/templates/{codeyam:memory.md → codeyam-memory.md} +26 -33
- package/codeyam-cli/templates/codeyam-new-rule.md +13 -0
- package/codeyam-cli/templates/{codeyam:setup.md → codeyam-setup.md} +13 -1
- package/codeyam-cli/templates/{codeyam:sim.md → codeyam-sim.md} +1 -1
- package/codeyam-cli/templates/{codeyam:test.md → codeyam-test.md} +1 -1
- package/codeyam-cli/templates/{codeyam:verify.md → codeyam-verify.md} +1 -1
- package/codeyam-cli/templates/rule-notification-hook.py +56 -0
- package/codeyam-cli/templates/rule-reflection-hook.py +554 -88
- package/codeyam-cli/templates/rules-instructions.md +54 -48
- package/package.json +9 -9
- package/packages/ai/index.js +1 -1
- package/packages/ai/index.js.map +1 -1
- package/packages/ai/src/lib/analyzeScope.js +21 -1
- package/packages/ai/src/lib/analyzeScope.js.map +1 -1
- package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
- package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
- package/packages/ai/src/lib/astScopes/processExpression.js +78 -1
- package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
- package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
- package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +262 -8
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +11 -2
- package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +2 -2
- package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
- package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
- package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
- package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +15 -1
- package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +78 -17
- package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
- package/packages/ai/src/lib/dataStructureChunking.js +26 -11
- package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
- package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
- package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
- package/packages/ai/src/lib/generateEntityScenarioData.js +32 -3
- package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlows.js +16 -2
- package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +242 -81
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
- package/packages/ai/src/lib/isolateScopes.js +39 -3
- package/packages/ai/src/lib/isolateScopes.js.map +1 -1
- package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
- package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
- package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
- package/packages/analyze/index.js +1 -0
- package/packages/analyze/index.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +52 -2
- package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +3 -0
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +880 -0
- package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
- package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +5 -1
- package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +51 -14
- package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +116 -13
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +310 -45
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
- package/packages/analyze/src/lib/index.js +1 -0
- package/packages/analyze/src/lib/index.js.map +1 -1
- package/packages/database/src/lib/analysisBranchToDb.js +1 -1
- package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
- package/packages/database/src/lib/analysisToDb.js +1 -1
- package/packages/database/src/lib/analysisToDb.js.map +1 -1
- package/packages/database/src/lib/branchToDb.js +1 -1
- package/packages/database/src/lib/branchToDb.js.map +1 -1
- package/packages/database/src/lib/commitBranchToDb.js +1 -1
- package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
- package/packages/database/src/lib/commitToDb.js +1 -1
- package/packages/database/src/lib/commitToDb.js.map +1 -1
- package/packages/database/src/lib/fileToDb.js +1 -1
- package/packages/database/src/lib/fileToDb.js.map +1 -1
- package/packages/database/src/lib/kysely/db.js +3 -0
- package/packages/database/src/lib/kysely/db.js.map +1 -1
- package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
- package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
- package/packages/database/src/lib/projectToDb.js +1 -1
- package/packages/database/src/lib/projectToDb.js.map +1 -1
- package/packages/database/src/lib/saveFiles.js +1 -1
- package/packages/database/src/lib/saveFiles.js.map +1 -1
- package/packages/database/src/lib/scenarioToDb.js +1 -1
- package/packages/database/src/lib/scenarioToDb.js.map +1 -1
- package/packages/utils/src/lib/fs/rsyncCopy.js +93 -2
- package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
- package/scripts/finalize-analyzer.cjs +8 -76
- package/codeyam-cli/src/utils/reviewedRules.js +0 -92
- package/codeyam-cli/src/utils/reviewedRules.js.map +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/globals-CX9f-5xM.css +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-bba56ec1.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/memory-DuTFSyJ2.js +0 -92
- package/codeyam-cli/src/webserver/build/client/assets/root-DTfSQARG.js +0 -62
- package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
- package/codeyam-cli/src/webserver/build/server/assets/server-build-BQ-1XyEa.js +0 -258
- package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
- package/codeyam-cli/templates/codeyam:new-rule.md +0 -52
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
import { execSync } from 'child_process';
|
|
2
|
+
import * as fs from 'fs';
|
|
3
|
+
import * as path from 'path';
|
|
4
|
+
/** Resolve the absolute path to the `claude` binary once at module load. */
|
|
5
|
+
function findClaude() {
|
|
6
|
+
try {
|
|
7
|
+
return execSync('which claude', { encoding: 'utf-8' }).trim();
|
|
8
|
+
}
|
|
9
|
+
catch {
|
|
10
|
+
// Fallback: check common locations
|
|
11
|
+
const homeDir = process.env.HOME || process.env.USERPROFILE || '';
|
|
12
|
+
const candidates = [
|
|
13
|
+
path.join(homeDir, '.local', 'bin', 'claude'),
|
|
14
|
+
'/usr/local/bin/claude',
|
|
15
|
+
];
|
|
16
|
+
for (const p of candidates) {
|
|
17
|
+
if (fs.existsSync(p))
|
|
18
|
+
return p;
|
|
19
|
+
}
|
|
20
|
+
return 'claude'; // fall through and let execSync fail with a clear error
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
const CLAUDE_BIN = findClaude();
|
|
24
|
+
/**
|
|
25
|
+
* Run `claude -p` synchronously and capture the result.
|
|
26
|
+
* Mirrors the production invocation from rule-reflection-hook.py.
|
|
27
|
+
*/
|
|
28
|
+
export function runClaude(options) {
|
|
29
|
+
const { prompt, cwd, model = 'haiku', timeoutMs = 180000, allowedTools = ['Read', 'Edit', 'Write', 'Bash', 'Glob', 'Grep'], saveOutput, } = options;
|
|
30
|
+
const args = [
|
|
31
|
+
CLAUDE_BIN,
|
|
32
|
+
'-p',
|
|
33
|
+
prompt,
|
|
34
|
+
'--model',
|
|
35
|
+
model,
|
|
36
|
+
'--output-format',
|
|
37
|
+
'stream-json',
|
|
38
|
+
'--verbose',
|
|
39
|
+
'--allowedTools',
|
|
40
|
+
allowedTools.join(','),
|
|
41
|
+
];
|
|
42
|
+
let result;
|
|
43
|
+
try {
|
|
44
|
+
const stdout = execSync(args.map(shellEscape).join(' '), {
|
|
45
|
+
cwd,
|
|
46
|
+
timeout: timeoutMs,
|
|
47
|
+
encoding: 'utf-8',
|
|
48
|
+
env: {
|
|
49
|
+
...process.env,
|
|
50
|
+
CODEYAM_RULE_AGENT: '1',
|
|
51
|
+
},
|
|
52
|
+
stdio: ['ignore', 'pipe', 'pipe'],
|
|
53
|
+
maxBuffer: 10 * 1024 * 1024, // 10MB
|
|
54
|
+
});
|
|
55
|
+
result = { exitCode: 0, stdout, stderr: '' };
|
|
56
|
+
}
|
|
57
|
+
catch (err) {
|
|
58
|
+
const error = err;
|
|
59
|
+
result = {
|
|
60
|
+
exitCode: error.status ?? 1,
|
|
61
|
+
stdout: error.stdout ?? '',
|
|
62
|
+
stderr: error.stderr ?? error.message ?? '',
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
if (saveOutput) {
|
|
66
|
+
fs.mkdirSync(saveOutput.dir, { recursive: true });
|
|
67
|
+
const parts = [];
|
|
68
|
+
parts.push(`# Rule Reflection Conversation Log\n`);
|
|
69
|
+
parts.push(`**Exit code:** ${result.exitCode}\n`);
|
|
70
|
+
if (result.stderr) {
|
|
71
|
+
parts.push(`**Stderr:**\n\`\`\`\n${result.stderr.slice(0, 2000)}\n\`\`\`\n`);
|
|
72
|
+
}
|
|
73
|
+
if (!result.stdout.trim()) {
|
|
74
|
+
parts.push(`**No stdout from claude CLI.**\n`);
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
parts.push(formatConversation(result.stdout));
|
|
78
|
+
}
|
|
79
|
+
const outPath = path.join(saveOutput.dir, `${saveOutput.label}.md`);
|
|
80
|
+
fs.writeFileSync(outPath, parts.join('\n'));
|
|
81
|
+
console.log(`\n💬 Conversation log (exit=${result.exitCode}): ${outPath}\n`);
|
|
82
|
+
}
|
|
83
|
+
return result;
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Parse stream-json stdout into a readable markdown conversation log.
|
|
87
|
+
*
|
|
88
|
+
* Stream-json format (one JSON object per line):
|
|
89
|
+
* - {"type":"system","subtype":"init",...}
|
|
90
|
+
* - {"type":"assistant","message":{"content":[{"type":"text","text":"..."}]}}
|
|
91
|
+
* - {"type":"assistant","message":{"content":[{"type":"tool_use","name":"...","input":{...}}]}}
|
|
92
|
+
* - {"type":"user","message":{"content":[{"type":"tool_result","content":"..."}]}}
|
|
93
|
+
* - {"type":"result","result":"..."}
|
|
94
|
+
*/
|
|
95
|
+
function formatConversation(stdout) {
|
|
96
|
+
const lines = [];
|
|
97
|
+
for (const rawLine of stdout.split('\n')) {
|
|
98
|
+
if (!rawLine.trim())
|
|
99
|
+
continue;
|
|
100
|
+
let event;
|
|
101
|
+
try {
|
|
102
|
+
event = JSON.parse(rawLine);
|
|
103
|
+
}
|
|
104
|
+
catch {
|
|
105
|
+
continue;
|
|
106
|
+
}
|
|
107
|
+
const type = event.type;
|
|
108
|
+
const message = event.message;
|
|
109
|
+
const contentBlocks = (message?.content ?? []);
|
|
110
|
+
if (type === 'assistant' && message) {
|
|
111
|
+
for (const block of contentBlocks) {
|
|
112
|
+
if (block.type === 'text') {
|
|
113
|
+
lines.push(`\n**Assistant:**\n${String(block.text)}\n`);
|
|
114
|
+
}
|
|
115
|
+
else if (block.type === 'tool_use') {
|
|
116
|
+
const name = block.name;
|
|
117
|
+
const input = block.input;
|
|
118
|
+
lines.push(`\n---\n**Tool: ${name}**`);
|
|
119
|
+
if (input) {
|
|
120
|
+
for (const [k, v] of Object.entries(input)) {
|
|
121
|
+
const val = typeof v === 'string' ? v : JSON.stringify(v);
|
|
122
|
+
const display = val.length > 300 ? val.slice(0, 300) + '...' : val;
|
|
123
|
+
lines.push(`- ${k}: \`${display}\``);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
else if (type === 'user' && message) {
|
|
130
|
+
for (const block of contentBlocks) {
|
|
131
|
+
if (block.type === 'tool_result') {
|
|
132
|
+
const content = String(block.content ?? '').slice(0, 500);
|
|
133
|
+
if (content) {
|
|
134
|
+
lines.push(`\n> Result (${content.length >= 500 ? 'truncated' : 'full'}):\n> ${content.replace(/\n/g, '\n> ')}${String(block.content ?? '').length > 500 ? '...' : ''}`);
|
|
135
|
+
}
|
|
136
|
+
lines.push('\n---\n');
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
else if (type === 'result') {
|
|
141
|
+
const text = String(event.result ?? '');
|
|
142
|
+
if (text) {
|
|
143
|
+
lines.push(`\n## Final Result\n\n${text}`);
|
|
144
|
+
}
|
|
145
|
+
const cost = event.total_cost_usd;
|
|
146
|
+
const turns = event.num_turns;
|
|
147
|
+
const duration = event.duration_ms;
|
|
148
|
+
if (cost || turns || duration) {
|
|
149
|
+
lines.push(`\n---\n*Turns: ${turns} | Duration: ${Number(duration) / 1000}s | Cost: $${Number(cost).toFixed(4)}*`);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
return lines.join('\n');
|
|
154
|
+
}
|
|
155
|
+
function shellEscape(arg) {
|
|
156
|
+
// If the arg contains special chars, wrap in single quotes
|
|
157
|
+
if (/[^a-zA-Z0-9_\-./:=,]/.test(arg)) {
|
|
158
|
+
return `'${arg.replace(/'/g, "'\\''")}'`;
|
|
159
|
+
}
|
|
160
|
+
return arg;
|
|
161
|
+
}
|
|
162
|
+
//# sourceMappingURL=runClaude.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runClaude.js","sourceRoot":"","sources":["../../../../../../../../src/utils/ruleReflection/__tests__/integration/helpers/runClaude.ts"],"names":[],"mappings":"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"}
|
package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js
ADDED
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import * as fs from 'fs';
|
|
2
|
+
import * as path from 'path';
|
|
3
|
+
import * as os from 'os';
|
|
4
|
+
import { execSync } from 'child_process';
|
|
5
|
+
/**
|
|
6
|
+
* Create a temporary project directory with the structure expected by rule reflection:
|
|
7
|
+
* - .claude/rules/ (with optional pre-existing rules)
|
|
8
|
+
* - .codeyam/rules/instructions.md
|
|
9
|
+
* - Source files
|
|
10
|
+
* - Git initialized with initial commit
|
|
11
|
+
*/
|
|
12
|
+
export function setupTempProject(options = {}) {
|
|
13
|
+
const dir = fs.mkdtempSync(path.join(os.tmpdir(), 'codeyam-rule-test-'));
|
|
14
|
+
const rulesDir = path.join(dir, '.claude', 'rules');
|
|
15
|
+
const codeyamRulesDir = path.join(dir, '.codeyam', 'rules');
|
|
16
|
+
// Create directories
|
|
17
|
+
fs.mkdirSync(rulesDir, { recursive: true });
|
|
18
|
+
fs.mkdirSync(codeyamRulesDir, { recursive: true });
|
|
19
|
+
// Write instructions.md
|
|
20
|
+
fs.writeFileSync(path.join(codeyamRulesDir, 'instructions.md'), [
|
|
21
|
+
'# Claude Rules Guide',
|
|
22
|
+
'',
|
|
23
|
+
'Rules provide context-specific guidance.',
|
|
24
|
+
'',
|
|
25
|
+
'## Required Frontmatter',
|
|
26
|
+
'',
|
|
27
|
+
'```yaml',
|
|
28
|
+
'---',
|
|
29
|
+
'paths:',
|
|
30
|
+
" - 'specific/path/to/file.ts'",
|
|
31
|
+
'timestamp: 2026-01-30T00:00:00Z',
|
|
32
|
+
'---',
|
|
33
|
+
'```',
|
|
34
|
+
'',
|
|
35
|
+
'## Content Guidelines',
|
|
36
|
+
'',
|
|
37
|
+
'- One concept per rule',
|
|
38
|
+
'- Be concise',
|
|
39
|
+
'- Focus on non-obvious knowledge',
|
|
40
|
+
].join('\n'));
|
|
41
|
+
// Write existing rules
|
|
42
|
+
for (const [filename, content] of Object.entries(options.existingRules || {})) {
|
|
43
|
+
const filePath = path.join(rulesDir, filename);
|
|
44
|
+
fs.mkdirSync(path.dirname(filePath), { recursive: true });
|
|
45
|
+
fs.writeFileSync(filePath, content);
|
|
46
|
+
}
|
|
47
|
+
// Write source files
|
|
48
|
+
for (const [relPath, content] of Object.entries(options.sourceFiles || {})) {
|
|
49
|
+
const filePath = path.join(dir, relPath);
|
|
50
|
+
fs.mkdirSync(path.dirname(filePath), { recursive: true });
|
|
51
|
+
fs.writeFileSync(filePath, content);
|
|
52
|
+
}
|
|
53
|
+
// Initialize git repo
|
|
54
|
+
execSync('git init', { cwd: dir, stdio: 'ignore' });
|
|
55
|
+
execSync('git add -A', { cwd: dir, stdio: 'ignore' });
|
|
56
|
+
execSync('git commit -m "initial commit" --allow-empty', {
|
|
57
|
+
cwd: dir,
|
|
58
|
+
stdio: 'ignore',
|
|
59
|
+
env: {
|
|
60
|
+
...process.env,
|
|
61
|
+
GIT_AUTHOR_NAME: 'Test',
|
|
62
|
+
GIT_AUTHOR_EMAIL: 'test@test.com',
|
|
63
|
+
GIT_COMMITTER_NAME: 'Test',
|
|
64
|
+
GIT_COMMITTER_EMAIL: 'test@test.com',
|
|
65
|
+
},
|
|
66
|
+
});
|
|
67
|
+
return {
|
|
68
|
+
dir,
|
|
69
|
+
rulesDir,
|
|
70
|
+
cleanup: () => {
|
|
71
|
+
fs.rmSync(dir, { recursive: true, force: true });
|
|
72
|
+
},
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=setupTempProject.js.map
|
package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"setupTempProject.js","sourceRoot":"","sources":["../../../../../../../../src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AACzB,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AACzB,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAazC;;;;;;GAMG;AACH,MAAM,UAAU,gBAAgB,CAC9B,UAA8B,EAAE;IAEhC,MAAM,GAAG,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE,oBAAoB,CAAC,CAAC,CAAC;IACzE,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;IACpD,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;IAE5D,qBAAqB;IACrB,EAAE,CAAC,SAAS,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC5C,EAAE,CAAC,SAAS,CAAC,eAAe,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAEnD,wBAAwB;IACxB,EAAE,CAAC,aAAa,CACd,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,iBAAiB,CAAC,EAC7C;QACE,sBAAsB;QACtB,EAAE;QACF,0CAA0C;QAC1C,EAAE;QACF,yBAAyB;QACzB,EAAE;QACF,SAAS;QACT,KAAK;QACL,QAAQ;QACR,gCAAgC;QAChC,iCAAiC;QACjC,KAAK;QACL,KAAK;QACL,EAAE;QACF,uBAAuB;QACvB,EAAE;QACF,wBAAwB;QACxB,cAAc;QACd,kCAAkC;KACnC,CAAC,IAAI,CAAC,IAAI,CAAC,CACb,CAAC;IAEF,uBAAuB;IACvB,KAAK,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CAC9C,OAAO,CAAC,aAAa,IAAI,EAAE,CAC5B,EAAE,CAAC;QACF,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAC/C,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC1D,EAAE,CAAC,aAAa,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IACtC,CAAC;IAED,qBAAqB;IACrB,KAAK,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC,EAAE,CAAC;QAC3E,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;QACzC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC1D,EAAE,CAAC,aAAa,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IACtC,CAAC;IAED,sBAAsB;IACtB,QAAQ,CAAC,UAAU,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;IACpD,QAAQ,CAAC,YAAY,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;IACtD,QAAQ,CAAC,8CAA8C,EAAE;QACvD,GAAG,EAAE,GAAG;QACR,KAAK,EAAE,QAAQ;QACf,GAAG,EAAE;YACH,GAAG,OAAO,CAAC,GAAG;YACd,eAAe,EAAE,MAAM;YACvB,gBAAgB,EAAE,eAAe;YACjC,kBAAkB,EAAE,MAAM;YAC1B,mBAAmB,EAAE,eAAe;SACrC;KACF,CAAC,CAAC;IAEH,OAAO;QACL,GAAG;QACH,QAAQ;QACR,OAAO,EAAE,GAAG,EAAE;YACZ,EAAE,CAAC,MAAM,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QACnD,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,378 @@
|
|
|
1
|
+
import * as fs from 'fs';
|
|
2
|
+
import * as path from 'path';
|
|
3
|
+
import { setupTempProject } from "./helpers/setupTempProject.js";
|
|
4
|
+
import { snapshotRules, getRulesChanges, assertValidFrontmatter, } from "./helpers/assertRules.js";
|
|
5
|
+
import { runClaude } from "./helpers/runClaude.js";
|
|
6
|
+
import { buildStaleRulesContext, buildConversationContext, } from "../../contextBuilder.js";
|
|
7
|
+
import { buildStaleRulesPrompt, buildConversationPrompt, } from "../../promptBuilder.js";
|
|
8
|
+
import { loadCapturedFixture, } from "./helpers/loadCapturedFixture.js";
|
|
9
|
+
/**
|
|
10
|
+
* Extract conversation snippets from a captured fixture's context.md.
|
|
11
|
+
* The context contains a `### Session transcript` section with lines like:
|
|
12
|
+
* [role]: content
|
|
13
|
+
*/
|
|
14
|
+
function extractSnippetsFromFixture(fixture) {
|
|
15
|
+
if (!fixture.context)
|
|
16
|
+
return [];
|
|
17
|
+
const marker = '### Session transcript\n';
|
|
18
|
+
const idx = fixture.context.indexOf(marker);
|
|
19
|
+
if (idx === -1)
|
|
20
|
+
return [];
|
|
21
|
+
const transcriptSection = fixture.context.slice(idx + marker.length).trim();
|
|
22
|
+
const snippets = [];
|
|
23
|
+
for (const line of transcriptSection.split('\n')) {
|
|
24
|
+
const match = line.match(/^\[(\w+)\]:\s*(.+)$/);
|
|
25
|
+
if (match) {
|
|
26
|
+
snippets.push({ role: match[1], content: match[2] });
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
return snippets;
|
|
30
|
+
}
|
|
31
|
+
const SKIP = !process.env.CODEYAM_RUN_INTEGRATION;
|
|
32
|
+
const OUTPUT_DIR = path.resolve(__dirname, 'output');
|
|
33
|
+
(SKIP ? describe.skip : describe)('Rule Reflection E2E', () => {
|
|
34
|
+
let tempProject;
|
|
35
|
+
afterEach(() => {
|
|
36
|
+
if (tempProject) {
|
|
37
|
+
tempProject.cleanup();
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
it('updates timestamp for stale rule with empty diff', async () => {
|
|
41
|
+
const existingRule = [
|
|
42
|
+
'---',
|
|
43
|
+
'paths:',
|
|
44
|
+
" - 'src/config.ts'",
|
|
45
|
+
'timestamp: 2026-01-01T00:00:00Z',
|
|
46
|
+
'---',
|
|
47
|
+
'',
|
|
48
|
+
'# Build Configuration',
|
|
49
|
+
'',
|
|
50
|
+
'Use `npm run build:prod` for production builds.',
|
|
51
|
+
].join('\n');
|
|
52
|
+
tempProject = setupTempProject({
|
|
53
|
+
existingRules: { 'build-config.md': existingRule },
|
|
54
|
+
sourceFiles: {
|
|
55
|
+
'src/config.ts': 'export const config = { debug: false };',
|
|
56
|
+
},
|
|
57
|
+
});
|
|
58
|
+
const staleRules = [
|
|
59
|
+
{
|
|
60
|
+
name: 'build-config.md',
|
|
61
|
+
last_audited: '2026-01-01T00:00:00Z',
|
|
62
|
+
newest_file: 'src/config.ts',
|
|
63
|
+
file_modified: '2026-02-01T00:00:00Z',
|
|
64
|
+
diff: '',
|
|
65
|
+
rule_content: '# Build Configuration\n\nUse `npm run build:prod` for production builds.',
|
|
66
|
+
},
|
|
67
|
+
];
|
|
68
|
+
const contextContent = buildStaleRulesContext(staleRules);
|
|
69
|
+
const contextFile = path.join(tempProject.dir, '.context.md');
|
|
70
|
+
fs.writeFileSync(contextFile, contextContent);
|
|
71
|
+
const notificationFile = path.join(tempProject.dir, 'rule-notification-stale.md');
|
|
72
|
+
const before = await snapshotRules(tempProject.rulesDir);
|
|
73
|
+
const prompt = buildStaleRulesPrompt(contextFile, tempProject.dir, notificationFile);
|
|
74
|
+
runClaude({
|
|
75
|
+
prompt,
|
|
76
|
+
cwd: tempProject.dir,
|
|
77
|
+
saveOutput: { dir: OUTPUT_DIR, label: 'stale-rule-empty-diff' },
|
|
78
|
+
});
|
|
79
|
+
const after = await snapshotRules(tempProject.rulesDir);
|
|
80
|
+
const changes = getRulesChanges(before, after);
|
|
81
|
+
// The rule should be modified (timestamp updated) or unchanged
|
|
82
|
+
// Either way the file should still exist and have valid frontmatter
|
|
83
|
+
const ruleContent = after.files.get('build-config.md') || before.files.get('build-config.md');
|
|
84
|
+
expect(ruleContent).toBeDefined();
|
|
85
|
+
if (changes.modified.includes('build-config.md')) {
|
|
86
|
+
assertValidFrontmatter(ruleContent);
|
|
87
|
+
}
|
|
88
|
+
}, 180000);
|
|
89
|
+
it('creates new rule from user correction conversation', async () => {
|
|
90
|
+
tempProject = setupTempProject({
|
|
91
|
+
sourceFiles: {
|
|
92
|
+
'src/api/auth.ts': 'export function authenticate(req: Request) { /* JWT auth */ }',
|
|
93
|
+
'src/api/session.ts': 'export function createSession() { /* session tokens */ }',
|
|
94
|
+
},
|
|
95
|
+
});
|
|
96
|
+
const snippets = [
|
|
97
|
+
{
|
|
98
|
+
role: 'user',
|
|
99
|
+
content: 'Update the API endpoint to use the new authentication flow',
|
|
100
|
+
},
|
|
101
|
+
{
|
|
102
|
+
role: 'assistant',
|
|
103
|
+
content: "I'll modify the authentication to use session tokens instead of JWT.",
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
role: 'user',
|
|
107
|
+
content: "No, that's not right. We need to keep JWT for the API but add session tokens for the web interface. They work together, not replace each other.",
|
|
108
|
+
},
|
|
109
|
+
{
|
|
110
|
+
role: 'assistant',
|
|
111
|
+
content: 'I understand now. The JWT tokens remain for API authentication while session tokens are added for the web interface.',
|
|
112
|
+
},
|
|
113
|
+
];
|
|
114
|
+
const modifiedFiles = new Set([
|
|
115
|
+
['src/api/auth.ts', 'Edit'],
|
|
116
|
+
['src/api/session.ts', 'Write'],
|
|
117
|
+
]);
|
|
118
|
+
const contextContent = buildConversationContext(snippets, modifiedFiles);
|
|
119
|
+
const contextFile = path.join(tempProject.dir, '.context.md');
|
|
120
|
+
fs.writeFileSync(contextFile, contextContent);
|
|
121
|
+
const notificationFile = path.join(tempProject.dir, 'rule-notification-conversation.md');
|
|
122
|
+
const before = await snapshotRules(tempProject.rulesDir);
|
|
123
|
+
const prompt = buildConversationPrompt(contextFile, tempProject.dir, notificationFile);
|
|
124
|
+
runClaude({
|
|
125
|
+
prompt,
|
|
126
|
+
cwd: tempProject.dir,
|
|
127
|
+
saveOutput: { dir: OUTPUT_DIR, label: 'user-correction-conversation' },
|
|
128
|
+
});
|
|
129
|
+
const after = await snapshotRules(tempProject.rulesDir);
|
|
130
|
+
const changes = getRulesChanges(before, after);
|
|
131
|
+
// Should have created at least one new rule about the auth pattern
|
|
132
|
+
expect(changes.created.length).toBeGreaterThan(0);
|
|
133
|
+
// New rule(s) should have valid frontmatter
|
|
134
|
+
for (const created of changes.created) {
|
|
135
|
+
const content = after.files.get(created);
|
|
136
|
+
assertValidFrontmatter(content);
|
|
137
|
+
}
|
|
138
|
+
}, 180000);
|
|
139
|
+
it('handles stale rules and conversation as separate agents', async () => {
|
|
140
|
+
const existingRule = [
|
|
141
|
+
'---',
|
|
142
|
+
'paths:',
|
|
143
|
+
" - 'src/api/auth.ts'",
|
|
144
|
+
'timestamp: 2026-01-15T00:00:00Z',
|
|
145
|
+
'---',
|
|
146
|
+
'',
|
|
147
|
+
'# API Auth',
|
|
148
|
+
'',
|
|
149
|
+
'All API endpoints use JWT authentication.',
|
|
150
|
+
].join('\n');
|
|
151
|
+
tempProject = setupTempProject({
|
|
152
|
+
existingRules: { 'api-auth.md': existingRule },
|
|
153
|
+
sourceFiles: {
|
|
154
|
+
'src/api/auth.ts': 'export function authenticate() {}',
|
|
155
|
+
'src/utils/helpers.ts': 'export function helper() {}',
|
|
156
|
+
},
|
|
157
|
+
});
|
|
158
|
+
const staleRules = [
|
|
159
|
+
{
|
|
160
|
+
name: 'api-auth.md',
|
|
161
|
+
last_audited: '2026-01-15T00:00:00Z',
|
|
162
|
+
newest_file: 'src/api/auth.ts',
|
|
163
|
+
file_modified: '2026-02-01T00:00:00Z',
|
|
164
|
+
diff: '@@ -1 +1,2 @@\n+import { validateSession } from "./session.js"\n export function authenticate() {}',
|
|
165
|
+
rule_content: '# API Auth\n\nAll API endpoints use JWT authentication.',
|
|
166
|
+
},
|
|
167
|
+
];
|
|
168
|
+
const snippets = [
|
|
169
|
+
{
|
|
170
|
+
role: 'user',
|
|
171
|
+
content: 'The helpers module needs to be imported before auth because of initialization order',
|
|
172
|
+
},
|
|
173
|
+
{
|
|
174
|
+
role: 'assistant',
|
|
175
|
+
content: 'I see, there is an initialization dependency between helpers and auth.',
|
|
176
|
+
},
|
|
177
|
+
];
|
|
178
|
+
const notificationFileStale = path.join(tempProject.dir, 'rule-notification-stale.md');
|
|
179
|
+
const notificationFileConv = path.join(tempProject.dir, 'rule-notification-conversation.md');
|
|
180
|
+
// Run stale rules agent
|
|
181
|
+
const staleContext = buildStaleRulesContext(staleRules);
|
|
182
|
+
const staleContextFile = path.join(tempProject.dir, '.context-stale.md');
|
|
183
|
+
fs.writeFileSync(staleContextFile, staleContext);
|
|
184
|
+
const before = await snapshotRules(tempProject.rulesDir);
|
|
185
|
+
const stalePrompt = buildStaleRulesPrompt(staleContextFile, tempProject.dir, notificationFileStale);
|
|
186
|
+
runClaude({
|
|
187
|
+
prompt: stalePrompt,
|
|
188
|
+
cwd: tempProject.dir,
|
|
189
|
+
saveOutput: { dir: OUTPUT_DIR, label: 'combined-stale' },
|
|
190
|
+
});
|
|
191
|
+
// Run conversation agent
|
|
192
|
+
const convContext = buildConversationContext(snippets, new Set());
|
|
193
|
+
const convContextFile = path.join(tempProject.dir, '.context-conversation.md');
|
|
194
|
+
fs.writeFileSync(convContextFile, convContext);
|
|
195
|
+
const convPrompt = buildConversationPrompt(convContextFile, tempProject.dir, notificationFileConv);
|
|
196
|
+
runClaude({
|
|
197
|
+
prompt: convPrompt,
|
|
198
|
+
cwd: tempProject.dir,
|
|
199
|
+
saveOutput: { dir: OUTPUT_DIR, label: 'combined-conversation' },
|
|
200
|
+
});
|
|
201
|
+
const after = await snapshotRules(tempProject.rulesDir);
|
|
202
|
+
const changes = getRulesChanges(before, after);
|
|
203
|
+
// Existing rule should still be present
|
|
204
|
+
expect(after.files.has('api-auth.md')).toBe(true);
|
|
205
|
+
// Total changes (stale rule update + potential new rule) should be > 0
|
|
206
|
+
expect(changes.modified.length + changes.created.length).toBeGreaterThan(0);
|
|
207
|
+
}, 300000);
|
|
208
|
+
it('writes notification file when rules change', async () => {
|
|
209
|
+
tempProject = setupTempProject({
|
|
210
|
+
sourceFiles: {
|
|
211
|
+
'src/index.ts': 'console.log("hello");',
|
|
212
|
+
},
|
|
213
|
+
});
|
|
214
|
+
const snippets = [
|
|
215
|
+
{
|
|
216
|
+
role: 'user',
|
|
217
|
+
content: "No, that's wrong. You must always run the linter before committing. The pre-commit hook checks this.",
|
|
218
|
+
},
|
|
219
|
+
{
|
|
220
|
+
role: 'assistant',
|
|
221
|
+
content: 'I see, the pre-commit hook enforces linting. I will run the linter first.',
|
|
222
|
+
},
|
|
223
|
+
];
|
|
224
|
+
const contextContent = buildConversationContext(snippets, new Set());
|
|
225
|
+
const contextFile = path.join(tempProject.dir, '.context.md');
|
|
226
|
+
fs.writeFileSync(contextFile, contextContent);
|
|
227
|
+
const notificationFile = path.join(tempProject.dir, 'rule-notification-conversation.md');
|
|
228
|
+
const prompt = buildConversationPrompt(contextFile, tempProject.dir, notificationFile);
|
|
229
|
+
runClaude({
|
|
230
|
+
prompt,
|
|
231
|
+
cwd: tempProject.dir,
|
|
232
|
+
saveOutput: { dir: OUTPUT_DIR, label: 'notification-file' },
|
|
233
|
+
});
|
|
234
|
+
const after = await snapshotRules(tempProject.rulesDir);
|
|
235
|
+
// If rules were created, notification should exist
|
|
236
|
+
if (after.files.size > 0) {
|
|
237
|
+
expect(fs.existsSync(notificationFile)).toBe(true);
|
|
238
|
+
const notification = fs.readFileSync(notificationFile, 'utf-8');
|
|
239
|
+
expect(notification.length).toBeGreaterThan(0);
|
|
240
|
+
}
|
|
241
|
+
}, 180000);
|
|
242
|
+
describe('captured fixtures', () => {
|
|
243
|
+
const FIXTURES_DIR = path.resolve(__dirname, '../fixtures/captured');
|
|
244
|
+
it('does not create rules from routine implementation conversation (fe1a8b55)', async () => {
|
|
245
|
+
// This fixture captured a session where the user asked to reorder search
|
|
246
|
+
// results in the memory audit section. It was purely implementation work
|
|
247
|
+
// with no user corrections, confusion, or architectural decisions.
|
|
248
|
+
// The agent incorrectly created a rule about search ordering.
|
|
249
|
+
//
|
|
250
|
+
// We rebuild the context using the CURRENT guidance template + the
|
|
251
|
+
// fixture's transcript so that guidance improvements are tested.
|
|
252
|
+
tempProject = setupTempProject({
|
|
253
|
+
sourceFiles: {
|
|
254
|
+
'src/webserver/app/components/memory/MemoryAuditSection.tsx': 'export function MemoryAuditSection() { return <div />; }',
|
|
255
|
+
'src/webserver/app/lib/memory/types.ts': 'export interface AuditData { topPaths: any[]; allSourceFiles: string[]; }',
|
|
256
|
+
'src/webserver/app/routes/api.memory.ts': 'export async function loader() { return Response.json({}); }',
|
|
257
|
+
},
|
|
258
|
+
});
|
|
259
|
+
// Transcript from the captured fixture — the user gave clear
|
|
260
|
+
// implementation requirements, no corrections or confusion.
|
|
261
|
+
const snippets = [
|
|
262
|
+
{
|
|
263
|
+
role: 'user',
|
|
264
|
+
content: 'Ok can we order the results by path that start with the search string, followed by paths that contain the search string? Within those matches it should be alphabetic. The search results order should not be impacted by the rule count or token count at all. All files in the repo should be included in the search',
|
|
265
|
+
},
|
|
266
|
+
{
|
|
267
|
+
role: 'assistant',
|
|
268
|
+
content: 'Let me look at the current data flow to understand what needs to change.',
|
|
269
|
+
},
|
|
270
|
+
{
|
|
271
|
+
role: 'assistant',
|
|
272
|
+
content: "The API only returns files that have matching rules. I need to also return all source files so search can cover everything. But sending full coverage data for every file would be heavy — I'll return the source file list separately and build search results client-side.",
|
|
273
|
+
},
|
|
274
|
+
{
|
|
275
|
+
role: 'assistant',
|
|
276
|
+
content: 'Now update the search suggestions to use all source files with proper sorting, and build `PathCoverage` entries on the fly for files without rule coverage.',
|
|
277
|
+
},
|
|
278
|
+
{
|
|
279
|
+
role: 'assistant',
|
|
280
|
+
content: "Builds clean. Here's what changed: 1. All files searchable: API now returns allSourceFiles 2. Sorting: Prefix matches first, then contains — alphabetical within each group 3. No rule/token bias: Sorting is purely by path 4. Overflow fix: Removed overflow-hidden so the dropdown isn't clipped",
|
|
281
|
+
},
|
|
282
|
+
];
|
|
283
|
+
const modifiedFiles = new Set([
|
|
284
|
+
['src/webserver/app/components/memory/MemoryAuditSection.tsx', 'Edit'],
|
|
285
|
+
['src/webserver/app/lib/memory/types.ts', 'Edit'],
|
|
286
|
+
['src/webserver/app/routes/api.memory.ts', 'Edit'],
|
|
287
|
+
]);
|
|
288
|
+
const contextContent = buildConversationContext(snippets, modifiedFiles);
|
|
289
|
+
const contextFile = path.join(tempProject.dir, '.context.md');
|
|
290
|
+
fs.writeFileSync(contextFile, contextContent);
|
|
291
|
+
const notificationFile = path.join(tempProject.dir, 'rule-notification-conversation.md');
|
|
292
|
+
const before = await snapshotRules(tempProject.rulesDir);
|
|
293
|
+
const prompt = buildConversationPrompt(contextFile, tempProject.dir, notificationFile);
|
|
294
|
+
runClaude({
|
|
295
|
+
prompt,
|
|
296
|
+
cwd: tempProject.dir,
|
|
297
|
+
saveOutput: { dir: OUTPUT_DIR, label: 'fixture-fe1a8b55-no-rule' },
|
|
298
|
+
});
|
|
299
|
+
const after = await snapshotRules(tempProject.rulesDir);
|
|
300
|
+
const changes = getRulesChanges(before, after);
|
|
301
|
+
// No rules should be created — this was routine implementation work.
|
|
302
|
+
// The user gave clear instructions about search ordering; there were
|
|
303
|
+
// no corrections, confusion, or non-obvious architectural decisions.
|
|
304
|
+
expect(changes.created.length).toBe(0);
|
|
305
|
+
}, 180000);
|
|
306
|
+
it('does not create rules for a bug fix that is now protected by code and tests (b4e050b8)', async () => {
|
|
307
|
+
// This fixture captured a session where a crash in ScopeDataStructure.ts
|
|
308
|
+
// was debugged and fixed: addComplexSourcePathVariables crashed when a
|
|
309
|
+
// usage equivalency referenced an HTML intrinsic element (<input>) that
|
|
310
|
+
// has no scope node. The fix added null guards and a reproduction test.
|
|
311
|
+
//
|
|
312
|
+
// The agent incorrectly created a rule about "HTML Elements and Scope
|
|
313
|
+
// Nodes" — but the fix is now in the code (null guards) and verified by
|
|
314
|
+
// a test, so the rule is redundant. Per guidance: "The specific bug
|
|
315
|
+
// being fixed (it will be resolved; the rule would be immediately stale)"
|
|
316
|
+
// and "Any requirements or information that can now be identified by
|
|
317
|
+
// the code."
|
|
318
|
+
//
|
|
319
|
+
// We rebuild the context using the CURRENT guidance template + the
|
|
320
|
+
// fixture's transcript so that guidance improvements are tested.
|
|
321
|
+
const fixture = loadCapturedFixture('b4e050b8-conv');
|
|
322
|
+
const snippets = extractSnippetsFromFixture(fixture);
|
|
323
|
+
tempProject = setupTempProject({
|
|
324
|
+
sourceFiles: {
|
|
325
|
+
'packages/ai/src/lib/dataStructure/ScopeDataStructure.ts': [
|
|
326
|
+
'export class ScopeDataStructure {',
|
|
327
|
+
' addComplexSourcePathVariables() {',
|
|
328
|
+
' // Guard: HTML elements create equivalencies but have no scope node',
|
|
329
|
+
' const usageScopeNode = this.getScopeOrFunctionCallInfo(scopeNodeName);',
|
|
330
|
+
' if (!usageScopeNode) continue;',
|
|
331
|
+
' }',
|
|
332
|
+
' captureComplexSourcePaths() {',
|
|
333
|
+
' const usageScopeNode = this.getScopeOrFunctionCallInfo(scopeNodeName);',
|
|
334
|
+
' if (!usageScopeNode) continue;',
|
|
335
|
+
' }',
|
|
336
|
+
'}',
|
|
337
|
+
].join('\n'),
|
|
338
|
+
'packages/ai/src/lib/dataStructure/__tests__/analyzeScopeNoAI_memoryAudit.test.ts': [
|
|
339
|
+
"describe('MemoryAuditSection', () => {",
|
|
340
|
+
" it('handles HTML element equivalencies without crashing', () => {",
|
|
341
|
+
' // Reproduction test for HTML intrinsic elements like <input>',
|
|
342
|
+
' // that create equivalencies but never register as scope nodes',
|
|
343
|
+
' expect(result).toBeDefined();',
|
|
344
|
+
' });',
|
|
345
|
+
'});',
|
|
346
|
+
].join('\n'),
|
|
347
|
+
},
|
|
348
|
+
});
|
|
349
|
+
const modifiedFiles = new Set([
|
|
350
|
+
['packages/ai/src/lib/dataStructure/ScopeDataStructure.ts', 'Edit'],
|
|
351
|
+
[
|
|
352
|
+
'packages/ai/src/lib/dataStructure/__tests__/analyzeScopeNoAI_memoryAudit.test.ts',
|
|
353
|
+
'Write',
|
|
354
|
+
],
|
|
355
|
+
]);
|
|
356
|
+
const contextContent = buildConversationContext(snippets, modifiedFiles);
|
|
357
|
+
const contextFile = path.join(tempProject.dir, '.context.md');
|
|
358
|
+
fs.writeFileSync(contextFile, contextContent);
|
|
359
|
+
const notificationFile = path.join(tempProject.dir, 'rule-notification-conversation.md');
|
|
360
|
+
const before = await snapshotRules(tempProject.rulesDir);
|
|
361
|
+
const prompt = buildConversationPrompt(contextFile, tempProject.dir, notificationFile);
|
|
362
|
+
runClaude({
|
|
363
|
+
prompt,
|
|
364
|
+
cwd: tempProject.dir,
|
|
365
|
+
saveOutput: { dir: OUTPUT_DIR, label: 'fixture-b4e050b8-no-rule' },
|
|
366
|
+
});
|
|
367
|
+
const after = await snapshotRules(tempProject.rulesDir);
|
|
368
|
+
const changes = getRulesChanges(before, after);
|
|
369
|
+
// No rules should be created — this was a bug fix session.
|
|
370
|
+
// The null guards and reproduction test are now in the code,
|
|
371
|
+
// so the information is fully discernible from reading the source.
|
|
372
|
+
// The guidance explicitly says not to document "the specific bug
|
|
373
|
+
// being fixed" or information "that can now be identified by the code."
|
|
374
|
+
expect(changes.created.length).toBe(0);
|
|
375
|
+
}, 180000);
|
|
376
|
+
});
|
|
377
|
+
});
|
|
378
|
+
//# sourceMappingURL=ruleReflectionE2E.test.js.map
|
package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ruleReflectionE2E.test.js","sourceRoot":"","sources":["../../../../../../../src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.ts"],"names":[],"mappings":"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"}
|