@codeyam/codeyam-cli 0.1.0-staging.15d0f46 → 0.1.0-staging.1669d45
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/common/execAsync.ts +1 -1
- package/analyzer-template/log.txt +3 -3
- package/analyzer-template/package.json +9 -5
- package/analyzer-template/packages/ai/index.ts +5 -3
- package/analyzer-template/packages/ai/package.json +1 -1
- package/analyzer-template/packages/ai/src/lib/__mocks__/completionCall.ts +122 -0
- package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +152 -6
- package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +107 -1
- package/analyzer-template/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.ts +644 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +42 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.ts +18 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.ts +38 -1
- package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +301 -1
- package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +972 -106
- package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +232 -0
- package/analyzer-template/packages/ai/src/lib/checkAllAttributes.ts +29 -10
- package/analyzer-template/packages/ai/src/lib/completionCall.ts +18 -2
- package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +1409 -138
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +2 -1
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +771 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +233 -75
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +19 -1
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +39 -4
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +23 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.ts +98 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +42 -2
- package/analyzer-template/packages/ai/src/lib/deepEqual.ts +30 -0
- package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarioData.ts +74 -7
- package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarios.ts +89 -112
- package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +6 -0
- package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +486 -86
- package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +182 -104
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +201 -0
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +528 -0
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +1019 -0
- package/analyzer-template/packages/ai/src/lib/getConditionalUsagesFromCode.ts +143 -31
- package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromDescription.ts +8 -2
- package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +276 -3
- package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +33 -3
- package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +7 -0
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.ts +1 -1
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.ts +32 -102
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +71 -4
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.ts +14 -53
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.ts +58 -0
- package/analyzer-template/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.ts +28 -2
- package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +690 -0
- package/analyzer-template/packages/ai/src/lib/splitOutsideParentheses.ts +5 -1
- package/analyzer-template/packages/ai/src/lib/validateExecutionFlowPaths.ts +531 -0
- package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +102 -0
- package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +8 -1
- package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +14 -0
- package/analyzer-template/packages/analyze/src/lib/asts/nodes/index.ts +1 -0
- package/analyzer-template/packages/analyze/src/lib/asts/nodes/isAsyncFunction.ts +67 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +458 -267
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +18 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +3 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +31 -15
- package/analyzer-template/packages/analyze/src/lib/files/analyzeEntity.ts +11 -7
- package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +11 -12
- package/analyzer-template/packages/analyze/src/lib/files/enums/steps.ts +1 -1
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +196 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.ts +102 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +588 -52
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.ts +1 -1
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.ts +28 -62
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +299 -133
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +156 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarioData.ts +78 -83
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarios.ts +4 -8
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +384 -94
- package/analyzer-template/packages/aws/codebuild/index.ts +1 -0
- package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts +11 -1
- package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js +29 -18
- package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts +2 -2
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js +2 -2
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts +8 -18
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js +17 -61
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts +15 -0
- package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts.map +1 -0
- package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js +31 -0
- package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js.map +1 -0
- package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.d.ts.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js +8 -1
- package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js.map +1 -1
- package/analyzer-template/packages/aws/package.json +2 -2
- package/analyzer-template/packages/aws/s3/index.ts +1 -0
- package/analyzer-template/packages/aws/src/lib/codebuild/waitForBuild.ts +43 -19
- package/analyzer-template/packages/aws/src/lib/ecs/ecsDefineContainer.ts +3 -3
- package/analyzer-template/packages/aws/src/lib/ecs/ecsTaskFactory.ts +17 -69
- package/analyzer-template/packages/aws/src/lib/s3/checkS3ObjectExists.ts +47 -0
- package/analyzer-template/packages/aws/src/lib/s3/uploadFileToS3.ts +8 -1
- package/analyzer-template/packages/database/src/lib/kysely/db.ts +4 -4
- package/analyzer-template/packages/database/src/lib/kysely/tableRelations.ts +2 -2
- package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +36 -9
- package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +7 -3
- package/analyzer-template/packages/generate/index.ts +3 -0
- package/analyzer-template/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.ts +17 -1
- package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +193 -0
- package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.ts +73 -0
- package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +9 -4
- package/analyzer-template/packages/generate/src/lib/deepMerge.ts +26 -1
- package/analyzer-template/packages/generate/src/lib/scenarioComponentForServer.ts +114 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -2
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +2 -2
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.d.ts +2 -2
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts +1 -11
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +30 -7
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js +9 -3
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts +1 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +2 -6
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +7 -4
- package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/index.d.ts +3 -0
- package/analyzer-template/packages/github/dist/generate/index.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/generate/index.js +3 -0
- package/analyzer-template/packages/github/dist/generate/index.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +16 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts +9 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +189 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts +20 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts.map +1 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +8 -4
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js +27 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts +8 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts.map +1 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js +89 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js.map +1 -0
- package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js +10 -0
- package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js.map +1 -1
- package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js +3 -0
- package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js.map +1 -1
- package/analyzer-template/packages/github/dist/types/index.d.ts +2 -2
- package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/index.js.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +63 -13
- package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts +2 -0
- package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +11 -6
- package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +146 -0
- package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts +2 -0
- package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts.map +1 -1
- package/analyzer-template/packages/github/src/lib/loadOrCreateCommit.ts +14 -0
- package/analyzer-template/packages/github/src/lib/syncPrimaryBranch.ts +2 -0
- package/analyzer-template/packages/process/index.ts +2 -0
- package/analyzer-template/packages/process/package.json +12 -0
- package/analyzer-template/packages/process/tsconfig.json +8 -0
- package/analyzer-template/packages/types/index.ts +4 -0
- package/analyzer-template/packages/types/src/types/Analysis.ts +79 -13
- package/analyzer-template/packages/types/src/types/Entity.ts +2 -0
- package/analyzer-template/packages/types/src/types/Scenario.ts +11 -10
- package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +161 -0
- package/analyzer-template/packages/types/src/types/StatementInfo.ts +2 -0
- package/analyzer-template/packages/utils/dist/types/index.d.ts +2 -2
- package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/index.js.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +63 -13
- package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts +2 -0
- package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +11 -6
- package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +146 -0
- package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts +2 -0
- package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts.map +1 -1
- package/analyzer-template/playwright/capture.ts +37 -18
- package/analyzer-template/playwright/getCodeYamInfo.ts +12 -7
- package/analyzer-template/playwright/takeElementScreenshot.ts +26 -11
- package/analyzer-template/playwright/waitForServer.ts +21 -6
- package/analyzer-template/project/analyzeBaselineCommit.ts +4 -0
- package/analyzer-template/project/analyzeBranchCommit.ts +4 -0
- package/analyzer-template/project/analyzeFileEntities.ts +4 -0
- package/analyzer-template/project/analyzeRegularCommit.ts +4 -0
- package/analyzer-template/project/constructMockCode.ts +868 -132
- package/analyzer-template/project/controller/startController.ts +16 -1
- package/analyzer-template/project/executeLibraryFunctionDirect.ts +7 -3
- package/analyzer-template/project/mocks/analyzeFileMock.ts +8 -7
- package/analyzer-template/project/orchestrateCapture/KyselyAnalysisLoader.ts +3 -6
- package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +49 -33
- package/analyzer-template/project/orchestrateCapture.ts +10 -3
- package/analyzer-template/project/reconcileMockDataKeys.ts +102 -2
- package/analyzer-template/project/runAnalysis.ts +7 -0
- package/analyzer-template/project/serverOnlyModules.ts +127 -2
- package/analyzer-template/project/start.ts +26 -4
- package/analyzer-template/project/startScenarioCapture.ts +72 -40
- package/analyzer-template/project/writeMockDataTsx.ts +118 -55
- package/analyzer-template/project/writeScenarioClientWrapper.ts +21 -0
- package/analyzer-template/project/writeScenarioComponents.ts +263 -92
- package/analyzer-template/project/writeScenarioFiles.ts +26 -0
- package/analyzer-template/project/writeSimpleRoot.ts +13 -15
- package/analyzer-template/scripts/comboWorkerLoop.cjs +1 -0
- package/analyzer-template/scripts/defaultCmd.sh +9 -0
- package/analyzer-template/tsconfig.json +2 -1
- package/background/src/lib/local/createLocalAnalyzer.js +1 -29
- package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
- package/background/src/lib/local/execAsync.js +1 -1
- package/background/src/lib/local/execAsync.js.map +1 -1
- package/background/src/lib/virtualized/common/execAsync.js +1 -1
- package/background/src/lib/virtualized/common/execAsync.js.map +1 -1
- package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +2 -1
- package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
- package/background/src/lib/virtualized/project/analyzeBranchCommit.js +2 -1
- package/background/src/lib/virtualized/project/analyzeBranchCommit.js.map +1 -1
- package/background/src/lib/virtualized/project/analyzeFileEntities.js +2 -1
- package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
- package/background/src/lib/virtualized/project/analyzeRegularCommit.js +2 -1
- package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
- package/background/src/lib/virtualized/project/constructMockCode.js +799 -121
- package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
- package/background/src/lib/virtualized/project/controller/startController.js +11 -1
- package/background/src/lib/virtualized/project/controller/startController.js.map +1 -1
- package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js +6 -3
- package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js.map +1 -1
- package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js +7 -7
- package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js.map +1 -1
- package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js +3 -2
- package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js.map +1 -1
- package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +42 -28
- package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
- package/background/src/lib/virtualized/project/orchestrateCapture.js +7 -4
- package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
- package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +87 -2
- package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
- package/background/src/lib/virtualized/project/runAnalysis.js +6 -0
- package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
- package/background/src/lib/virtualized/project/serverOnlyModules.js +106 -3
- package/background/src/lib/virtualized/project/serverOnlyModules.js.map +1 -1
- package/background/src/lib/virtualized/project/start.js +21 -4
- package/background/src/lib/virtualized/project/start.js.map +1 -1
- package/background/src/lib/virtualized/project/startScenarioCapture.js +56 -30
- package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
- package/background/src/lib/virtualized/project/writeMockDataTsx.js +110 -48
- package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
- package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js +15 -0
- package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js.map +1 -0
- package/background/src/lib/virtualized/project/writeScenarioComponents.js +211 -75
- package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
- package/background/src/lib/virtualized/project/writeScenarioFiles.js +19 -0
- package/background/src/lib/virtualized/project/writeScenarioFiles.js.map +1 -1
- package/background/src/lib/virtualized/project/writeSimpleRoot.js +13 -13
- package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
- package/codeyam-cli/src/cli.js +5 -1
- package/codeyam-cli/src/cli.js.map +1 -1
- package/codeyam-cli/src/commands/analyze.js +1 -1
- package/codeyam-cli/src/commands/analyze.js.map +1 -1
- package/codeyam-cli/src/commands/baseline.js +174 -0
- package/codeyam-cli/src/commands/baseline.js.map +1 -0
- package/codeyam-cli/src/commands/debug.js +28 -18
- package/codeyam-cli/src/commands/debug.js.map +1 -1
- package/codeyam-cli/src/commands/default.js +0 -15
- package/codeyam-cli/src/commands/default.js.map +1 -1
- package/codeyam-cli/src/commands/recapture.js +44 -23
- package/codeyam-cli/src/commands/recapture.js.map +1 -1
- package/codeyam-cli/src/commands/report.js +72 -24
- package/codeyam-cli/src/commands/report.js.map +1 -1
- package/codeyam-cli/src/commands/start.js +8 -12
- package/codeyam-cli/src/commands/start.js.map +1 -1
- package/codeyam-cli/src/commands/status.js +23 -1
- package/codeyam-cli/src/commands/status.js.map +1 -1
- package/codeyam-cli/src/commands/test-startup.js +1 -1
- package/codeyam-cli/src/commands/test-startup.js.map +1 -1
- package/codeyam-cli/src/commands/wipe.js +108 -0
- package/codeyam-cli/src/commands/wipe.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js +81 -0
- package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +27 -27
- package/codeyam-cli/src/utils/analysisRunner.js +8 -13
- package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
- package/codeyam-cli/src/utils/backgroundServer.js +12 -2
- package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/utils/database.js +91 -5
- package/codeyam-cli/src/utils/database.js.map +1 -1
- package/codeyam-cli/src/utils/generateReport.js +253 -106
- package/codeyam-cli/src/utils/generateReport.js.map +1 -1
- package/codeyam-cli/src/utils/git.js +79 -0
- package/codeyam-cli/src/utils/git.js.map +1 -0
- package/codeyam-cli/src/utils/install-skills.js +11 -11
- package/codeyam-cli/src/utils/install-skills.js.map +1 -1
- package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +38 -0
- package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
- package/codeyam-cli/src/utils/queue/job.js +239 -16
- package/codeyam-cli/src/utils/queue/job.js.map +1 -1
- package/codeyam-cli/src/utils/queue/manager.js +19 -7
- package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
- package/codeyam-cli/src/utils/queue/persistence.js.map +1 -1
- package/codeyam-cli/src/utils/serverState.js.map +1 -1
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +5 -5
- package/codeyam-cli/src/utils/versionInfo.js +25 -19
- package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
- package/codeyam-cli/src/utils/wipe.js +128 -0
- package/codeyam-cli/src/utils/wipe.js.map +1 -0
- package/codeyam-cli/src/webserver/app/lib/database.js +96 -0
- 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 +2 -5
- package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/EntityItem-vauWK972.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DKdsUF7Y.js → EntityTypeBadge-COi5OvsN.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-BwdQv49w.js +41 -0
- package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-CEleMv_j.js +34 -0
- package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-D68KarMg.js +25 -0
- package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-L75Wvqgw.js +3 -0
- package/codeyam-cli/src/webserver/build/client/assets/LoadingDots-C53WM8qn.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/LogViewer-CrNkmy4i.js +3 -0
- package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-DzJRkCkr.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-CQifa1n-.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-CyaBFX7l.js +20 -0
- package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-CWjSsLqY.js → TruncatedFilePath-D36O1rzU.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/_index-Be83mo_j.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BN6wu6Y-.js +37 -0
- package/codeyam-cli/src/webserver/build/client/assets/chevron-down-DgTPh8H-.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/chunk-EPOLDU6W-DdQKK6on.js +51 -0
- package/codeyam-cli/src/webserver/build/client/assets/circle-check-Dmr2bb1R.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-Do4ZLUYa.js +21 -0
- package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-C1gnJVOL.svg → cy-logo-cli-CCKUIm0S.svg} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Bn6aCAy_.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-CbdFyxZh.js +23 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-B4iCfs5M.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-wDWZZO1W.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.edit._scenarioId-BMbl7MeQ.js +5 -0
- package/codeyam-cli/src/webserver/build/client/assets/entry.client-5wRKRIH9.js +29 -0
- package/codeyam-cli/src/webserver/build/client/assets/executionFlowCoverage-BWhdfn70.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-DD3SDH7t.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/files-DKyMFI90.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/git-zXjT7J0G.js +15 -0
- package/codeyam-cli/src/webserver/build/client/assets/globals-DTTQ3gY7.css +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/html2canvas-pro.esm-fmIEn3Bc.js +9 -0
- package/codeyam-cli/src/webserver/build/client/assets/index-DLbXwndH.js +9 -0
- package/codeyam-cli/src/webserver/build/client/assets/index-gPZ-lad1.js +3 -0
- package/codeyam-cli/src/webserver/build/client/assets/loader-circle-BsPXJ81F.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/manifest-22590fcf.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/preload-helper-ckwbz45p.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/root-BsAarjAM.js +57 -0
- package/codeyam-cli/src/webserver/build/client/assets/scenarioStatus-B_8jpV3e.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/search-P2FKIUql.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/settings-B2eDuBj8.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/simulations-L18M6-kN.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/triangle-alert-BDz7kbVA.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-29dDmbH8.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-CmrTPlIB.js → useLastLogLine-BUm0UVJm.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/useReportContext-CkIOKTrZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{useToast-C1ig_BmP.js → useToast-KKw5kTn-.js} +1 -1
- package/codeyam-cli/src/webserver/build/server/assets/index-BND5I5fv.js +1 -0
- package/codeyam-cli/src/webserver/build/server/assets/server-build-CFXnd7MG.js +228 -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/src/webserver/devServer.js +1 -3
- package/codeyam-cli/src/webserver/devServer.js.map +1 -1
- package/codeyam-cli/src/webserver/server.js +35 -25
- package/codeyam-cli/src/webserver/server.js.map +1 -1
- package/codeyam-cli/templates/{codeyam-debug-skill.md → codeyam:debug.md} +1 -1
- package/codeyam-cli/templates/codeyam:diagnose.md +625 -0
- package/codeyam-cli/templates/{codeyam-setup-skill.md → codeyam:setup.md} +139 -4
- package/codeyam-cli/templates/{codeyam-sim-skill.md → codeyam:sim.md} +1 -1
- package/codeyam-cli/templates/{codeyam-test-skill.md → codeyam:test.md} +1 -1
- package/codeyam-cli/templates/{codeyam-verify-skill.md → codeyam:verify.md} +1 -1
- package/package.json +8 -8
- package/packages/ai/index.js +2 -4
- package/packages/ai/index.js.map +1 -1
- package/packages/ai/src/lib/analyzeScope.js +107 -0
- package/packages/ai/src/lib/analyzeScope.js.map +1 -1
- package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +76 -1
- package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
- package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js +435 -0
- package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js.map +1 -0
- package/packages/ai/src/lib/astScopes/methodSemantics.js +29 -0
- package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
- package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js +8 -0
- package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js.map +1 -1
- package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js +23 -0
- package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js.map +1 -1
- package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +239 -1
- package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
- package/packages/ai/src/lib/astScopes/processExpression.js +728 -87
- package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
- package/packages/ai/src/lib/checkAllAttributes.js +24 -9
- package/packages/ai/src/lib/checkAllAttributes.js.map +1 -1
- package/packages/ai/src/lib/completionCall.js +17 -1
- package/packages/ai/src/lib/completionCall.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +1126 -82
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +2 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +482 -0
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -0
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +173 -55
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +16 -1
- package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +35 -2
- package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +20 -0
- package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js +86 -0
- package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js.map +1 -0
- package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +34 -3
- package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
- package/packages/ai/src/lib/deepEqual.js +32 -0
- package/packages/ai/src/lib/deepEqual.js.map +1 -0
- package/packages/ai/src/lib/generateChangesEntityScenarioData.js +62 -5
- package/packages/ai/src/lib/generateChangesEntityScenarioData.js.map +1 -1
- package/packages/ai/src/lib/generateChangesEntityScenarios.js +81 -90
- package/packages/ai/src/lib/generateChangesEntityScenarios.js.map +1 -1
- package/packages/ai/src/lib/generateEntityDataStructure.js +5 -0
- package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
- package/packages/ai/src/lib/generateEntityScenarioData.js +398 -81
- package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
- package/packages/ai/src/lib/generateEntityScenarios.js +168 -82
- package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlows.js +123 -0
- package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -0
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js +380 -0
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js.map +1 -0
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +742 -0
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -0
- package/packages/ai/src/lib/getConditionalUsagesFromCode.js +84 -14
- package/packages/ai/src/lib/getConditionalUsagesFromCode.js.map +1 -1
- package/packages/ai/src/lib/guessScenarioDataFromDescription.js +2 -1
- package/packages/ai/src/lib/guessScenarioDataFromDescription.js.map +1 -1
- package/packages/ai/src/lib/isolateScopes.js +231 -4
- package/packages/ai/src/lib/isolateScopes.js.map +1 -1
- package/packages/ai/src/lib/mergeStatements.js +26 -3
- package/packages/ai/src/lib/mergeStatements.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +6 -0
- package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js +1 -1
- package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js +21 -64
- package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +58 -4
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js +10 -34
- package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js +45 -0
- package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js.map +1 -0
- package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js +16 -3
- package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js.map +1 -1
- package/packages/ai/src/lib/resolvePathToControllable.js +563 -0
- package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -0
- package/packages/ai/src/lib/splitOutsideParentheses.js +3 -1
- package/packages/ai/src/lib/splitOutsideParentheses.js.map +1 -1
- package/packages/ai/src/lib/worker/SerializableDataStructure.js +22 -0
- package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
- package/packages/ai/src/lib/worker/analyzeScopeWorker.js +4 -0
- package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
- package/packages/analyze/src/lib/FileAnalyzer.js +15 -0
- package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
- package/packages/analyze/src/lib/asts/nodes/index.js +1 -0
- package/packages/analyze/src/lib/asts/nodes/index.js.map +1 -1
- package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js +52 -0
- package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js.map +1 -0
- package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +214 -50
- package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +10 -0
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +2 -0
- package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
- package/packages/analyze/src/lib/files/analyzeChange.js +21 -11
- package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
- package/packages/analyze/src/lib/files/analyzeEntity.js +9 -8
- package/packages/analyze/src/lib/files/analyzeEntity.js.map +1 -1
- package/packages/analyze/src/lib/files/analyzeInitial.js +9 -10
- package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
- package/packages/analyze/src/lib/files/enums/steps.js +1 -1
- package/packages/analyze/src/lib/files/enums/steps.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +159 -0
- package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -0
- package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js +85 -0
- package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js.map +1 -0
- package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +458 -48
- package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js +29 -34
- package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +235 -81
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +96 -0
- package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -0
- package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js +56 -69
- package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateScenarios.js +4 -8
- package/packages/analyze/src/lib/files/scenarios/generateScenarios.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +307 -89
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
- package/packages/aws/src/lib/ecs/ecsDefineContainer.js +2 -2
- package/packages/aws/src/lib/ecs/ecsDefineContainer.js.map +1 -1
- package/packages/aws/src/lib/ecs/ecsTaskFactory.js +17 -61
- package/packages/aws/src/lib/ecs/ecsTaskFactory.js.map +1 -1
- package/packages/database/src/lib/kysely/db.js +2 -2
- package/packages/database/src/lib/kysely/tables/debugReportsTable.js +9 -3
- package/packages/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
- package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +7 -4
- package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
- package/packages/generate/index.js +3 -0
- package/packages/generate/index.js.map +1 -1
- package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +16 -1
- package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -1
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +189 -0
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
- package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +8 -4
- package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
- package/packages/generate/src/lib/deepMerge.js +27 -1
- package/packages/generate/src/lib/deepMerge.js.map +1 -1
- package/packages/generate/src/lib/scenarioComponentForServer.js +89 -0
- package/packages/generate/src/lib/scenarioComponentForServer.js.map +1 -0
- package/packages/github/src/lib/loadOrCreateCommit.js +10 -0
- package/packages/github/src/lib/loadOrCreateCommit.js.map +1 -1
- package/packages/github/src/lib/syncPrimaryBranch.js +3 -0
- package/packages/github/src/lib/syncPrimaryBranch.js.map +1 -1
- package/packages/process/index.js +3 -0
- package/packages/process/index.js.map +1 -0
- package/packages/process/src/GlobalProcessManager.js.map +1 -0
- package/{background/src/lib/process → packages/process/src}/ProcessManager.js +1 -1
- package/packages/process/src/ProcessManager.js.map +1 -0
- package/packages/process/src/index.js.map +1 -0
- package/packages/process/src/managedExecAsync.js.map +1 -0
- package/packages/types/index.js.map +1 -1
- package/scripts/finalize-analyzer.cjs +3 -1
- package/analyzer-template/packages/ai/src/lib/findMatchingAttribute.ts +0 -102
- package/analyzer-template/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.ts +0 -197
- package/analyzer-template/packages/ai/src/lib/generateChangesEntityKeyAttributes.ts +0 -271
- package/analyzer-template/packages/ai/src/lib/generateEntityKeyAttributes.ts +0 -294
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.ts +0 -67
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.ts +0 -115
- package/analyzer-template/process/INTEGRATION_COMPLETE.md +0 -333
- package/analyzer-template/process/INTEGRATION_EXAMPLE.md +0 -525
- package/analyzer-template/process/README.md +0 -507
- package/background/src/lib/process/GlobalProcessManager.js.map +0 -1
- package/background/src/lib/process/ProcessManager.js.map +0 -1
- package/background/src/lib/process/index.js.map +0 -1
- package/background/src/lib/process/managedExecAsync.js.map +0 -1
- package/codeyam-cli/scripts/fixtures/cal.com/universal-mocks/packages/prisma/index.js +0 -238
- package/codeyam-cli/scripts/fixtures/cal.com/universal-mocks/packages/prisma/index.js.map +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/EntityItem-D0VW1-W7.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-BAk4S4pI.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-Y756iZxZ.js +0 -25
- package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-zzrrjW1p.js +0 -3
- package/codeyam-cli/src/webserver/build/client/assets/LogViewer-QMn7bJg6.js +0 -3
- package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-DmP5mRxX.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-BXwvsbLw.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-DAmUX_1y.js +0 -5
- package/codeyam-cli/src/webserver/build/client/assets/_index-Df-nk4J5.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-_ZUyFdie.js +0 -7
- package/codeyam-cli/src/webserver/build/client/assets/chevron-down-Eoh0PhcW.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/chunk-WWGJGFF6-CZgPLy5i.js +0 -26
- package/codeyam-cli/src/webserver/build/client/assets/circle-check-DI-p9ZLZ.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-DvyV2x6y.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-DURu2qlF.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-DDobn9Xh.js +0 -16
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-CGdWnLD_.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.edit._scenarioId-DgMmzrKs.js +0 -5
- package/codeyam-cli/src/webserver/build/client/assets/entry.client-DEVXuhkn.js +0 -13
- package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-WPRQyc68.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/files-B9u3lJer.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/git-YGnKIuHU.js +0 -11
- package/codeyam-cli/src/webserver/build/client/assets/globals-28lrWTTo.css +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/html2canvas-pro.esm-XQCGvadH.js +0 -5
- package/codeyam-cli/src/webserver/build/client/assets/index-CJ0uPJjV.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/index-CfqeA2XG.js +0 -3
- package/codeyam-cli/src/webserver/build/client/assets/loader-circle-DIjSvh6B.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-8125c15c.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/preload-helper-BXl3LOEh.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/root-C-g286WP.js +0 -16
- package/codeyam-cli/src/webserver/build/client/assets/search-xBKWfOxd.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/settings-DVY_wGOx.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/simulations-Be1pJo5A.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/triangle-alert-CR-FkSvx.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/useReportContext-DABetnSj.js +0 -1
- package/codeyam-cli/src/webserver/build/server/assets/index-DcR7DH9q.js +0 -1
- package/codeyam-cli/src/webserver/build/server/assets/server-build-BDBrfp7e.js +0 -175
- package/codeyam-cli/templates/debug-codeyam.md +0 -527
- package/packages/ai/src/lib/findMatchingAttribute.js +0 -77
- package/packages/ai/src/lib/findMatchingAttribute.js.map +0 -1
- package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js +0 -136
- package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js.map +0 -1
- package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js +0 -220
- package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js.map +0 -1
- package/packages/ai/src/lib/generateEntityKeyAttributes.js +0 -241
- package/packages/ai/src/lib/generateEntityKeyAttributes.js.map +0 -1
- package/packages/ai/src/lib/isFrontend.js +0 -5
- package/packages/ai/src/lib/isFrontend.js.map +0 -1
- package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js +0 -40
- package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js.map +0 -1
- package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js +0 -72
- package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js.map +0 -1
- /package/analyzer-template/{process → packages/process/src}/GlobalProcessManager.ts +0 -0
- /package/analyzer-template/{process → packages/process/src}/ProcessManager.ts +0 -0
- /package/analyzer-template/{process → packages/process/src}/index.ts +0 -0
- /package/analyzer-template/{process → packages/process/src}/managedExecAsync.ts +0 -0
- /package/{background/src/lib/process → packages/process/src}/GlobalProcessManager.js +0 -0
- /package/{background/src/lib/process → packages/process/src}/index.js +0 -0
- /package/{background/src/lib/process → packages/process/src}/managedExecAsync.js +0 -0
|
@@ -13,8 +13,8 @@ export enum ControllerPhase {
|
|
|
13
13
|
Startup = 'STARTUP',
|
|
14
14
|
RepoCheckout = 'REPO_CHECKOUT',
|
|
15
15
|
Analysis = 'ANALYSIS',
|
|
16
|
+
AnalysisProducing = 'ANALYSIS_PRODUCING',
|
|
16
17
|
Serving = 'SERVING',
|
|
17
|
-
Orchestrating = 'ORCHESTRATING',
|
|
18
18
|
Complete = 'COMPLETE',
|
|
19
19
|
}
|
|
20
20
|
|
|
@@ -30,6 +30,7 @@ type ControllerContext =
|
|
|
30
30
|
| { phase: ControllerPhase.Startup; info: null }
|
|
31
31
|
| { phase: ControllerPhase.RepoCheckout; info: null }
|
|
32
32
|
| { phase: ControllerPhase.Analysis; info: null }
|
|
33
|
+
| { phase: ControllerPhase.AnalysisProducing; info: null }
|
|
33
34
|
| { phase: ControllerPhase.Serving; info: ServingCodeYamInfo }
|
|
34
35
|
| { phase: ControllerPhase.Complete; info: null };
|
|
35
36
|
|
|
@@ -100,6 +101,11 @@ export class Controller extends EventEmitter {
|
|
|
100
101
|
this.setPhase({ phase: ControllerPhase.Analysis, info: null });
|
|
101
102
|
}
|
|
102
103
|
|
|
104
|
+
setAnalysisProducingPhase(): void {
|
|
105
|
+
this.setPhase({ phase: ControllerPhase.AnalysisProducing, info: null });
|
|
106
|
+
this.emit('analysisProducing');
|
|
107
|
+
}
|
|
108
|
+
|
|
103
109
|
setServingPhase(info: ServingCodeYamInfo): void {
|
|
104
110
|
this.setPhase({ phase: ControllerPhase.Serving, info });
|
|
105
111
|
}
|
|
@@ -116,6 +122,15 @@ export class Controller extends EventEmitter {
|
|
|
116
122
|
);
|
|
117
123
|
}
|
|
118
124
|
|
|
125
|
+
hasStartedProducing(): boolean {
|
|
126
|
+
// Analysis is producing once we've moved past the Analysis phase
|
|
127
|
+
return (
|
|
128
|
+
this.context.phase === ControllerPhase.AnalysisProducing ||
|
|
129
|
+
this.context.phase === ControllerPhase.Serving ||
|
|
130
|
+
this.context.phase === ControllerPhase.Complete
|
|
131
|
+
);
|
|
132
|
+
}
|
|
133
|
+
|
|
119
134
|
async close(): Promise<void> {
|
|
120
135
|
if (!this.server) return;
|
|
121
136
|
|
|
@@ -33,11 +33,15 @@ export default async function executeLibraryFunctionDirect(
|
|
|
33
33
|
// Generate the execution script
|
|
34
34
|
const script = directExecutionScript(file, entity, analysis, scenario);
|
|
35
35
|
|
|
36
|
+
// Use .ts extension for TypeScript source files so tsx can resolve TS imports
|
|
37
|
+
const isTypeScript = file.path.endsWith('.ts') || file.path.endsWith('.tsx');
|
|
38
|
+
const scriptExtension = isTypeScript ? '.ts' : '.mjs';
|
|
39
|
+
|
|
36
40
|
// Write the script to a temporary file
|
|
37
41
|
const scriptPath = path.join(
|
|
38
42
|
PROJECT_RELATIVE_PATH,
|
|
39
43
|
'.codeyam-execution',
|
|
40
|
-
`${entity.sha}_${scenario.id}
|
|
44
|
+
`${entity.sha}_${scenario.id}${scriptExtension}`,
|
|
41
45
|
);
|
|
42
46
|
|
|
43
47
|
await writeFile(scriptPath, script);
|
|
@@ -54,10 +58,10 @@ export default async function executeLibraryFunctionDirect(
|
|
|
54
58
|
command: 'npx',
|
|
55
59
|
args: ['tsx', scriptPath],
|
|
56
60
|
workingDir: PROJECT_RELATIVE_PATH,
|
|
57
|
-
onData:
|
|
61
|
+
onData: (data) => {
|
|
58
62
|
stdout += data;
|
|
59
63
|
},
|
|
60
|
-
onError:
|
|
64
|
+
onError: (data) => {
|
|
61
65
|
stderr += data;
|
|
62
66
|
},
|
|
63
67
|
processName: 'library-function-execution',
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/require-await */
|
|
1
2
|
import {
|
|
2
3
|
Analysis,
|
|
3
4
|
AnalysisMap,
|
|
@@ -47,7 +48,7 @@ const standaloneComponentAnalysis = {
|
|
|
47
48
|
'The counter is initialized at 0, with the ability to increment and decrement the count.',
|
|
48
49
|
metadata: {
|
|
49
50
|
dataMapping: {},
|
|
50
|
-
|
|
51
|
+
coveredFlows: [],
|
|
51
52
|
data: {
|
|
52
53
|
argumentsData: [],
|
|
53
54
|
mockData: {},
|
|
@@ -221,7 +222,7 @@ async function analyzeReturnsSimplePropsFile(): Promise<{
|
|
|
221
222
|
'A user who is under 18 years old and is currently active.',
|
|
222
223
|
metadata: {
|
|
223
224
|
dataMapping: {},
|
|
224
|
-
|
|
225
|
+
coveredFlows: [],
|
|
225
226
|
data: {
|
|
226
227
|
argumentsData: [
|
|
227
228
|
{
|
|
@@ -242,7 +243,7 @@ async function analyzeReturnsSimplePropsFile(): Promise<{
|
|
|
242
243
|
'A user who is between 18 and 39 years old and is currently active.',
|
|
243
244
|
metadata: {
|
|
244
245
|
dataMapping: {},
|
|
245
|
-
|
|
246
|
+
coveredFlows: [],
|
|
246
247
|
data: {
|
|
247
248
|
argumentsData: [
|
|
248
249
|
{
|
|
@@ -263,7 +264,7 @@ async function analyzeReturnsSimplePropsFile(): Promise<{
|
|
|
263
264
|
'A user who is 40 years or older and is currently active.',
|
|
264
265
|
metadata: {
|
|
265
266
|
dataMapping: {},
|
|
266
|
-
|
|
267
|
+
coveredFlows: [],
|
|
267
268
|
data: {
|
|
268
269
|
argumentsData: [
|
|
269
270
|
{
|
|
@@ -284,7 +285,7 @@ async function analyzeReturnsSimplePropsFile(): Promise<{
|
|
|
284
285
|
'A user who is under 18 years old and is currently inactive.',
|
|
285
286
|
metadata: {
|
|
286
287
|
dataMapping: {},
|
|
287
|
-
|
|
288
|
+
coveredFlows: [],
|
|
288
289
|
data: {
|
|
289
290
|
argumentsData: [
|
|
290
291
|
{
|
|
@@ -305,7 +306,7 @@ async function analyzeReturnsSimplePropsFile(): Promise<{
|
|
|
305
306
|
'A user who is between 18 and 39 years old and is currently inactive.',
|
|
306
307
|
metadata: {
|
|
307
308
|
dataMapping: {},
|
|
308
|
-
|
|
309
|
+
coveredFlows: [],
|
|
309
310
|
data: {
|
|
310
311
|
argumentsData: [
|
|
311
312
|
{
|
|
@@ -378,7 +379,7 @@ async function analyzeReturnsImportedComponentsFile(): Promise<{
|
|
|
378
379
|
description: 'Default scenario description',
|
|
379
380
|
metadata: {
|
|
380
381
|
dataMapping: {},
|
|
381
|
-
|
|
382
|
+
coveredFlows: [],
|
|
382
383
|
data: {
|
|
383
384
|
argumentsData: [],
|
|
384
385
|
mockData: {},
|
|
@@ -46,13 +46,10 @@ export default class KyselyAnalysisLoader implements AnalysisLoader {
|
|
|
46
46
|
'status',
|
|
47
47
|
])
|
|
48
48
|
// Base condition: readyToBeCaptured = true
|
|
49
|
-
// Use
|
|
49
|
+
// Use -> operator which works in both PostgreSQL and SQLite
|
|
50
|
+
// Both return a value that compares equal to string 'true'
|
|
50
51
|
.where((eb) =>
|
|
51
|
-
eb(
|
|
52
|
-
sql`json_extract(${sql.ref('status')}, '$.readyToBeCaptured')`,
|
|
53
|
-
'=',
|
|
54
|
-
sql`1`,
|
|
55
|
-
),
|
|
52
|
+
eb(sql`${sql.ref('status')} -> 'readyToBeCaptured'`, '=', 'true'),
|
|
56
53
|
)
|
|
57
54
|
// Project filter (always required)
|
|
58
55
|
.where('project_id', '=', this.config.project.id);
|
|
@@ -91,47 +91,59 @@ export default class SequentialCaptureTaskRunner implements CaptureTaskRunner {
|
|
|
91
91
|
|
|
92
92
|
// Derive paths
|
|
93
93
|
const parentDir = parentOfCodeyam;
|
|
94
|
-
const capturerPath = path.normalize(path.join(parentDir, 'capturer-1'));
|
|
95
94
|
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
95
|
+
// In CAPTURE_ONLY mode, run directly from the main project folder (skip rsync)
|
|
96
|
+
// This preserves any manual edits made to generated files
|
|
97
|
+
const captureOnly = process.env.CAPTURE_ONLY === 'true';
|
|
98
|
+
const capturerPath = captureOnly
|
|
99
|
+
? parentDir
|
|
100
|
+
: path.normalize(path.join(parentDir, 'capturer-1'));
|
|
102
101
|
|
|
103
|
-
|
|
104
|
-
// start.ts waits for repo checkout to complete before creating this runner
|
|
105
|
-
console.log('CodeYam: Copying codeyam/ and project/ to capturer-1/...');
|
|
106
|
-
await rsyncCopy({
|
|
107
|
-
sourcePath: parentDir,
|
|
108
|
-
destinationPath: capturerPath,
|
|
109
|
-
excludes: ['codeyam/log.txt', 'capturer-*'],
|
|
110
|
-
silent: false,
|
|
111
|
-
});
|
|
102
|
+
console.log(`CodeYam: Sequential runner using capturer at ${capturerPath}`);
|
|
112
103
|
|
|
113
|
-
|
|
114
|
-
const capturerProjectPath = path.join(capturerPath, 'project');
|
|
115
|
-
console.log('CodeYam: Sanitizing env files in capturer project...');
|
|
116
|
-
const sanitizeResult = sanitizeEnvFiles({
|
|
117
|
-
projectPath: capturerProjectPath,
|
|
118
|
-
log: (msg) => console.log(`CodeYam Sanitize: ${msg}`),
|
|
119
|
-
});
|
|
120
|
-
if (sanitizeResult.sanitizedFiles.length > 0) {
|
|
104
|
+
if (captureOnly) {
|
|
121
105
|
console.log(
|
|
122
|
-
|
|
106
|
+
'CodeYam: CAPTURE_ONLY mode - running from main project folder, skipping rsync',
|
|
123
107
|
);
|
|
124
|
-
}
|
|
108
|
+
} else {
|
|
109
|
+
// Create capturer base directory
|
|
110
|
+
if (!fs.existsSync(capturerPath)) {
|
|
111
|
+
fs.mkdirSync(capturerPath, { recursive: true });
|
|
112
|
+
}
|
|
125
113
|
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
console.log(
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
114
|
+
// Copy both codeyam/ and project/ into capturer-1/
|
|
115
|
+
// start.ts waits for repo checkout to complete before creating this runner
|
|
116
|
+
console.log('CodeYam: Copying codeyam/ and project/ to capturer-1/...');
|
|
117
|
+
await rsyncCopy({
|
|
118
|
+
sourcePath: parentDir,
|
|
119
|
+
destinationPath: capturerPath,
|
|
120
|
+
excludes: ['codeyam/log.txt', 'capturer-*'],
|
|
121
|
+
silent: false,
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
// Sanitize env files in capturer project (replaces real values with mock placeholders)
|
|
125
|
+
const capturerProjectPath = path.join(capturerPath, 'project');
|
|
126
|
+
console.log('CodeYam: Sanitizing env files in capturer project...');
|
|
127
|
+
const sanitizeResult = sanitizeEnvFiles({
|
|
133
128
|
projectPath: capturerProjectPath,
|
|
129
|
+
log: (msg) => console.log(`CodeYam Sanitize: ${msg}`),
|
|
134
130
|
});
|
|
131
|
+
if (sanitizeResult.sanitizedFiles.length > 0) {
|
|
132
|
+
console.log(
|
|
133
|
+
`CodeYam: Env files sanitized: ${sanitizeResult.sanitizedFiles.join(', ')}`,
|
|
134
|
+
);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
// Apply universal mocks to capturer project
|
|
138
|
+
if (context.universalMocks && context.universalMocks.length > 0) {
|
|
139
|
+
console.log(
|
|
140
|
+
`CodeYam: Applying ${context.universalMocks.length} universal mock(s) to capturer project...`,
|
|
141
|
+
);
|
|
142
|
+
await applyUniversalMocks({
|
|
143
|
+
mocks: context.universalMocks,
|
|
144
|
+
projectPath: capturerProjectPath,
|
|
145
|
+
});
|
|
146
|
+
}
|
|
135
147
|
}
|
|
136
148
|
|
|
137
149
|
const runner = new SequentialCaptureTaskRunner(
|
|
@@ -247,6 +259,10 @@ export default class SequentialCaptureTaskRunner implements CaptureTaskRunner {
|
|
|
247
259
|
READY_TO_BE_CAPTURED: 'true',
|
|
248
260
|
PROJECT_SLUG: this.config.projectSlug,
|
|
249
261
|
CODEYAM_LOG_PATH: capturerLogPath,
|
|
262
|
+
// Pass CAPTURE_ONLY through from parent process to skip file regeneration
|
|
263
|
+
...(process.env.CAPTURE_ONLY && {
|
|
264
|
+
CAPTURE_ONLY: process.env.CAPTURE_ONLY,
|
|
265
|
+
}),
|
|
250
266
|
},
|
|
251
267
|
workingDir: capturerCodeyamPath,
|
|
252
268
|
processName: 'project',
|
|
@@ -50,6 +50,9 @@ interface OrchestrateCaptureArgs {
|
|
|
50
50
|
taskRunner: CaptureTaskRunner;
|
|
51
51
|
analysisLoader?: AnalysisLoader;
|
|
52
52
|
pollingInterval?: number;
|
|
53
|
+
// Optional commit for metadata/progress tracking only (not filtering).
|
|
54
|
+
// Use when full=true but you still want capture progress updates on a commit.
|
|
55
|
+
metadataCommit?: Commit | null;
|
|
53
56
|
}
|
|
54
57
|
|
|
55
58
|
export default async function orchestrateCapture({
|
|
@@ -62,6 +65,7 @@ export default async function orchestrateCapture({
|
|
|
62
65
|
taskRunner,
|
|
63
66
|
analysisLoader,
|
|
64
67
|
pollingInterval = POLLING_INTERVAL,
|
|
68
|
+
metadataCommit,
|
|
65
69
|
}: OrchestrateCaptureArgs) {
|
|
66
70
|
if (!full && !analysisIds && !commit && !entityShas) {
|
|
67
71
|
throw new Error(
|
|
@@ -318,9 +322,12 @@ export default async function orchestrateCapture({
|
|
|
318
322
|
// console.log(
|
|
319
323
|
// `Codeyam Debug: All known analyses: ${Array.from(knownAnalyses).join(', ')}`,
|
|
320
324
|
// );
|
|
321
|
-
if
|
|
322
|
-
|
|
323
|
-
|
|
325
|
+
// Use metadataCommit if provided, otherwise fall back to commit.
|
|
326
|
+
// This allows progress tracking even when commit is null (e.g., full=true mode).
|
|
327
|
+
const trackingCommit = metadataCommit ?? commit;
|
|
328
|
+
if (trackingCommit) {
|
|
329
|
+
trackingCommit.metadata = await updateCommitMetadata({
|
|
330
|
+
commitId: trackingCommit.id,
|
|
324
331
|
runStatusUpdate: {
|
|
325
332
|
readyToBeCaptured: knownAnalyses.size,
|
|
326
333
|
capturesAttempted: capturedAnalysisIds.length + abandoned.length,
|
|
@@ -5,7 +5,10 @@
|
|
|
5
5
|
* (e.g., "eq('user_id', 'user-12345')") when the mock code expects variable
|
|
6
6
|
* references (e.g., "eq('user_id', user.id)").
|
|
7
7
|
*
|
|
8
|
-
*
|
|
8
|
+
* Keys are now original call signatures (e.g., "useFetcher<User>()", "db.select(query)").
|
|
9
|
+
*
|
|
10
|
+
* @param mockData The mock data object to reconcile
|
|
11
|
+
* @param expectedKeys The expected keys from the structure
|
|
9
12
|
*/
|
|
10
13
|
export function reconcileMockDataKeys(
|
|
11
14
|
mockData: Record<string, unknown>,
|
|
@@ -26,7 +29,7 @@ export function reconcileMockDataKeys(
|
|
|
26
29
|
continue;
|
|
27
30
|
}
|
|
28
31
|
|
|
29
|
-
// Try to find closest match
|
|
32
|
+
// Try to find closest match using existing logic
|
|
30
33
|
const closestKey = findClosestKey(key, expectedKeys);
|
|
31
34
|
if (closestKey) {
|
|
32
35
|
result[closestKey] = reconciledValue;
|
|
@@ -47,9 +50,15 @@ export function reconcileMockDataKeys(
|
|
|
47
50
|
* - Ignore the last argument value (could be literal or variable)
|
|
48
51
|
* - Match based on the common prefix
|
|
49
52
|
* - If key has no parentheses, try matching with "()" appended
|
|
53
|
+
* - If key is "funcName()" (empty args), match expected key "funcName({...})" by function name
|
|
54
|
+
* - If key has object arguments (like useQuery({...})), match by function name
|
|
55
|
+
* - If key has single argument with literal value, match by function name
|
|
50
56
|
*
|
|
51
57
|
* e.g., "eq('user_id', 'user-12345')" matches "eq('user_id', user.id)"
|
|
52
58
|
* e.g., "getAll" matches "getAll()"
|
|
59
|
+
* e.g., "getSurveysAction()" matches "getSurveysAction({ environmentId, ... })"
|
|
60
|
+
* e.g., "useQuery({ id: 123 })" matches "useQuery({ id: Number(id) })"
|
|
61
|
+
* e.g., "useCustomSizes('example-slug')" matches "useCustomSizes(projectSlug)"
|
|
53
62
|
*/
|
|
54
63
|
function findClosestKey(key: string, expectedKeys: string[]): string | null {
|
|
55
64
|
const keyBase = extractKeyBase(key);
|
|
@@ -73,9 +82,100 @@ function findClosestKey(key: string, expectedKeys: string[]): string | null {
|
|
|
73
82
|
}
|
|
74
83
|
}
|
|
75
84
|
|
|
85
|
+
// If key is "funcName()" (empty args), try matching expected key "funcName({...})"
|
|
86
|
+
// This handles the case where LLM generates "getSurveysAction()" but expected key
|
|
87
|
+
// is "getSurveysAction({ environmentId, limit, ... })" with an object argument
|
|
88
|
+
const emptyArgsMatch = key.match(/^([a-zA-Z_][a-zA-Z0-9_]*)\(\)$/);
|
|
89
|
+
if (emptyArgsMatch) {
|
|
90
|
+
const funcName = emptyArgsMatch[1];
|
|
91
|
+
for (const expected of expectedKeys) {
|
|
92
|
+
// Match if expected key starts with the same function name and has args
|
|
93
|
+
const expectedMatch = expected.match(
|
|
94
|
+
new RegExp(`^${escapeRegExp(funcName)}\\([^)]+\\)$`),
|
|
95
|
+
);
|
|
96
|
+
if (expectedMatch) {
|
|
97
|
+
return expected;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
// If key has object literal arguments (like "useQuery({ id: 123, ... })"),
|
|
103
|
+
// try matching expected keys with the same function name and object arguments.
|
|
104
|
+
// This handles cases where LLM generates literal values but expected keys have variable references.
|
|
105
|
+
// e.g., "useQuery({ id: 123 })" matches "useQuery({ id: Number(id) })"
|
|
106
|
+
// e.g., "trpc.users.getById.useQuery({ userId: 'user-123' })" matches "trpc.users.getById.useQuery({ userId })"
|
|
107
|
+
const objectArgMatch = key.match(/^([a-zA-Z_][a-zA-Z0-9_.]*)\s*\(\s*\{/);
|
|
108
|
+
if (objectArgMatch) {
|
|
109
|
+
const funcPath = objectArgMatch[1]; // Can be "funcName" or "path.to.funcName"
|
|
110
|
+
for (const expected of expectedKeys) {
|
|
111
|
+
// Match if expected key has the same function path and starts with object argument
|
|
112
|
+
const expectedObjArgMatch = expected.match(
|
|
113
|
+
new RegExp(`^${escapeRegExp(funcPath)}\\s*\\(\\s*\\{`),
|
|
114
|
+
);
|
|
115
|
+
if (expectedObjArgMatch) {
|
|
116
|
+
return expected;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
// If key has a single argument with a literal value (string, number, etc.),
|
|
122
|
+
// try matching expected keys with the same function name but different argument.
|
|
123
|
+
// This handles cases where LLM generates "useCustomSizes('example-slug')" but expected
|
|
124
|
+
// key is "useCustomSizes(projectSlug)" with a variable reference.
|
|
125
|
+
// e.g., "useCustomSizes('example-slug')" matches "useCustomSizes(projectSlug)"
|
|
126
|
+
const singleArgMatch = key.match(
|
|
127
|
+
/^([a-zA-Z_][a-zA-Z0-9_.]*)\s*\(([^,)]+)\)$/,
|
|
128
|
+
);
|
|
129
|
+
if (singleArgMatch) {
|
|
130
|
+
const funcPath = singleArgMatch[1];
|
|
131
|
+
const arg = singleArgMatch[2].trim();
|
|
132
|
+
// Only apply this matching if the argument looks like a literal (quoted string or number)
|
|
133
|
+
const isLiteralArg = /^['"`].*['"`]$/.test(arg) || /^\d+$/.test(arg);
|
|
134
|
+
if (isLiteralArg) {
|
|
135
|
+
for (const expected of expectedKeys) {
|
|
136
|
+
// Match if expected key has the same function path with a single argument
|
|
137
|
+
const expectedSingleArgMatch = expected.match(
|
|
138
|
+
new RegExp(`^${escapeRegExp(funcPath)}\\s*\\([^,)]+\\)$`),
|
|
139
|
+
);
|
|
140
|
+
if (expectedSingleArgMatch) {
|
|
141
|
+
return expected;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
// If key has multiple arguments where one contains a literal value,
|
|
148
|
+
// try matching expected keys with the same function name and argument count.
|
|
149
|
+
// This handles cases like "getScenarioDisplayState(scenario, undefined, undefined, 'entitysha123', undefined)"
|
|
150
|
+
// matching "getScenarioDisplayState(scenario, undefined, undefined, entitySha, undefined)"
|
|
151
|
+
const multiArgWithLiteralMatch = key.match(
|
|
152
|
+
/^([a-zA-Z_][a-zA-Z0-9_.]*)\s*\((.+)\)$/,
|
|
153
|
+
);
|
|
154
|
+
if (multiArgWithLiteralMatch) {
|
|
155
|
+
const funcPath = multiArgWithLiteralMatch[1];
|
|
156
|
+
const argsStr = multiArgWithLiteralMatch[2];
|
|
157
|
+
// Check if any argument is a string literal
|
|
158
|
+
const hasLiteralArg = /'[^']*'|"[^"]*"/.test(argsStr);
|
|
159
|
+
if (hasLiteralArg) {
|
|
160
|
+
for (const expected of expectedKeys) {
|
|
161
|
+
// Match if expected key starts with the same function path
|
|
162
|
+
if (expected.startsWith(funcPath + '(')) {
|
|
163
|
+
return expected;
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
|
|
76
169
|
return null;
|
|
77
170
|
}
|
|
78
171
|
|
|
172
|
+
/**
|
|
173
|
+
* Escape special regex characters in a string.
|
|
174
|
+
*/
|
|
175
|
+
function escapeRegExp(str: string): string {
|
|
176
|
+
return str.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
177
|
+
}
|
|
178
|
+
|
|
79
179
|
/**
|
|
80
180
|
* Normalize quotes in a string: convert double quotes to single quotes.
|
|
81
181
|
* This handles cases where the LLM generates keys with double quotes
|
|
@@ -215,6 +215,11 @@ export default async function runAnalysis({
|
|
|
215
215
|
entityShas,
|
|
216
216
|
branchName: branch?.name,
|
|
217
217
|
});
|
|
218
|
+
|
|
219
|
+
// Propagate the fallback branch to branchCommit so downstream code can use it
|
|
220
|
+
if (branchCommit && branch) {
|
|
221
|
+
branchCommit.branch = branch;
|
|
222
|
+
}
|
|
218
223
|
}
|
|
219
224
|
|
|
220
225
|
// After this block, 'commit' is the union of a regular or baseline commit
|
|
@@ -330,6 +335,7 @@ export default async function runAnalysis({
|
|
|
330
335
|
desiredAnalyses,
|
|
331
336
|
force,
|
|
332
337
|
fileStore,
|
|
338
|
+
onAnalysisProducing: () => controller?.setAnalysisProducingPhase(),
|
|
333
339
|
});
|
|
334
340
|
}
|
|
335
341
|
|
|
@@ -350,6 +356,7 @@ export default async function runAnalysis({
|
|
|
350
356
|
backgroundJob,
|
|
351
357
|
desiredAnalyses,
|
|
352
358
|
fileStore,
|
|
359
|
+
onAnalysisProducing: () => controller?.setAnalysisProducingPhase(),
|
|
353
360
|
});
|
|
354
361
|
} catch (e) {
|
|
355
362
|
awsLog('CodeYam Error: Analysis failed', {
|
|
@@ -213,6 +213,108 @@ export function applyServerOnlyMocks(fileContent: string): string {
|
|
|
213
213
|
return applyServerOnlyMocksAst(fileContent);
|
|
214
214
|
}
|
|
215
215
|
|
|
216
|
+
/**
|
|
217
|
+
* Check if a file exports an "env" variable that's derived from a node module import.
|
|
218
|
+
* This is a generic pattern for env configuration packages (like @t3-oss/env-*, envalid, etc.)
|
|
219
|
+
* that create server-only environment objects.
|
|
220
|
+
*
|
|
221
|
+
* Pattern detected:
|
|
222
|
+
* import { someFunc } from "some-package";
|
|
223
|
+
* export const env = someFunc({...});
|
|
224
|
+
*
|
|
225
|
+
* Returns the name of the imported function if detected, null otherwise.
|
|
226
|
+
*/
|
|
227
|
+
function detectEnvStoreFromNodeModule(sourceFile: ts.SourceFile): {
|
|
228
|
+
importedFunctionName: string;
|
|
229
|
+
modulePath: string;
|
|
230
|
+
} | null {
|
|
231
|
+
// First, collect all imported function names from node modules
|
|
232
|
+
const nodeModuleImports = new Map<string, string>(); // functionName -> modulePath
|
|
233
|
+
|
|
234
|
+
for (const statement of sourceFile.statements) {
|
|
235
|
+
if (!ts.isImportDeclaration(statement)) continue;
|
|
236
|
+
|
|
237
|
+
const moduleSpecifier = statement.moduleSpecifier;
|
|
238
|
+
if (!ts.isStringLiteral(moduleSpecifier)) continue;
|
|
239
|
+
|
|
240
|
+
const modulePath = moduleSpecifier.text;
|
|
241
|
+
// Skip relative imports - only look at node modules
|
|
242
|
+
if (modulePath.startsWith('.') || modulePath.startsWith('/')) continue;
|
|
243
|
+
|
|
244
|
+
if (
|
|
245
|
+
statement.importClause?.namedBindings &&
|
|
246
|
+
ts.isNamedImports(statement.importClause.namedBindings)
|
|
247
|
+
) {
|
|
248
|
+
for (const element of statement.importClause.namedBindings.elements) {
|
|
249
|
+
nodeModuleImports.set(element.name.text, modulePath);
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
if (statement.importClause?.name) {
|
|
253
|
+
nodeModuleImports.set(statement.importClause.name.text, modulePath);
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
// Now look for: export const env = importedFunc(...)
|
|
258
|
+
for (const statement of sourceFile.statements) {
|
|
259
|
+
if (!ts.isVariableStatement(statement)) continue;
|
|
260
|
+
|
|
261
|
+
// Check if it's exported
|
|
262
|
+
const isExported = statement.modifiers?.some(
|
|
263
|
+
(m) => m.kind === ts.SyntaxKind.ExportKeyword,
|
|
264
|
+
);
|
|
265
|
+
if (!isExported) continue;
|
|
266
|
+
|
|
267
|
+
for (const decl of statement.declarationList.declarations) {
|
|
268
|
+
// Check if variable is named "env"
|
|
269
|
+
if (!ts.isIdentifier(decl.name) || decl.name.text !== 'env') continue;
|
|
270
|
+
|
|
271
|
+
// Check if initializer is a call expression
|
|
272
|
+
if (!decl.initializer || !ts.isCallExpression(decl.initializer)) continue;
|
|
273
|
+
|
|
274
|
+
// Get the function being called
|
|
275
|
+
const callExpr = decl.initializer.expression;
|
|
276
|
+
let funcName: string | null = null;
|
|
277
|
+
|
|
278
|
+
if (ts.isIdentifier(callExpr)) {
|
|
279
|
+
funcName = callExpr.text;
|
|
280
|
+
} else if (
|
|
281
|
+
ts.isPropertyAccessExpression(callExpr) &&
|
|
282
|
+
ts.isIdentifier(callExpr.name)
|
|
283
|
+
) {
|
|
284
|
+
funcName = callExpr.name.text;
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
if (funcName && nodeModuleImports.has(funcName)) {
|
|
288
|
+
return {
|
|
289
|
+
importedFunctionName: funcName,
|
|
290
|
+
modulePath: nodeModuleImports.get(funcName)!,
|
|
291
|
+
};
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
|
|
296
|
+
return null;
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
/**
|
|
300
|
+
* Generate mock code for env store patterns.
|
|
301
|
+
* Replaces the imported function with one that returns a proxy.
|
|
302
|
+
*/
|
|
303
|
+
function generateEnvStoreMock(functionName: string): string {
|
|
304
|
+
return `// Mock for env store function (server-only env vars)
|
|
305
|
+
const ${functionName} = (config: any) => {
|
|
306
|
+
// Return a proxy that returns undefined for any property access
|
|
307
|
+
// This allows the code to run on the client without throwing
|
|
308
|
+
return new Proxy({} as any, {
|
|
309
|
+
get: (target, prop) => {
|
|
310
|
+
if (prop === 'then' || prop === Symbol.toStringTag) return undefined;
|
|
311
|
+
return undefined;
|
|
312
|
+
},
|
|
313
|
+
});
|
|
314
|
+
};
|
|
315
|
+
`;
|
|
316
|
+
}
|
|
317
|
+
|
|
216
318
|
/**
|
|
217
319
|
* AST-based implementation of applyServerOnlyMocks for large files.
|
|
218
320
|
* Uses TypeScript parser instead of regex to avoid catastrophic backtracking.
|
|
@@ -229,6 +331,10 @@ function applyServerOnlyMocksAst(fileContent: string): string {
|
|
|
229
331
|
const replacements: { start: number; end: number; replacement: string }[] =
|
|
230
332
|
[];
|
|
231
333
|
|
|
334
|
+
// Check if this file exports an "env" variable from a node module function call
|
|
335
|
+
// This is a generic pattern for env configuration packages
|
|
336
|
+
const envStoreInfo = detectEnvStoreFromNodeModule(sourceFile);
|
|
337
|
+
|
|
232
338
|
for (const statement of sourceFile.statements) {
|
|
233
339
|
if (!ts.isImportDeclaration(statement)) continue;
|
|
234
340
|
|
|
@@ -236,8 +342,6 @@ function applyServerOnlyMocksAst(fileContent: string): string {
|
|
|
236
342
|
if (!ts.isStringLiteral(moduleSpecifier)) continue;
|
|
237
343
|
|
|
238
344
|
const modulePath = moduleSpecifier.text;
|
|
239
|
-
const config = findServerOnlyModule(modulePath);
|
|
240
|
-
if (!config) continue;
|
|
241
345
|
|
|
242
346
|
// Extract import names
|
|
243
347
|
const importNames: string[] = [];
|
|
@@ -265,6 +369,27 @@ function applyServerOnlyMocksAst(fileContent: string): string {
|
|
|
265
369
|
}
|
|
266
370
|
}
|
|
267
371
|
|
|
372
|
+
// Check if this import provides the function used to create the env store
|
|
373
|
+
if (
|
|
374
|
+
envStoreInfo &&
|
|
375
|
+
modulePath === envStoreInfo.modulePath &&
|
|
376
|
+
importNames.includes(envStoreInfo.importedFunctionName)
|
|
377
|
+
) {
|
|
378
|
+
const mockCode = generateEnvStoreMock(
|
|
379
|
+
envStoreInfo.importedFunctionName,
|
|
380
|
+
);
|
|
381
|
+
replacements.push({
|
|
382
|
+
start: statement.getStart(sourceFile),
|
|
383
|
+
end: statement.getEnd(),
|
|
384
|
+
replacement: mockCode,
|
|
385
|
+
});
|
|
386
|
+
continue;
|
|
387
|
+
}
|
|
388
|
+
|
|
389
|
+
// Check for known server-only modules (from explicit list)
|
|
390
|
+
const config = findServerOnlyModule(modulePath);
|
|
391
|
+
if (!config) continue;
|
|
392
|
+
|
|
268
393
|
const mockCode = config.getMockCode(importNames, defaultImportName);
|
|
269
394
|
replacements.push({
|
|
270
395
|
start: statement.getStart(sourceFile),
|