rhachet 1.11.0 → 1.12.2
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/dist/contract/cli/invoke.js +10 -1
- package/dist/contract/cli/invoke.js.map +1 -1
- package/dist/contract/cli/invokeAsk.d.ts +3 -3
- package/dist/contract/cli/invokeBriefs.d.ts +2 -2
- package/dist/contract/cli/invokeBriefsBoot.d.ts +1 -1
- package/dist/contract/cli/invokeBriefsBoot.js +2 -2
- package/dist/contract/cli/invokeBriefsBoot.js.map +1 -1
- package/dist/contract/cli/invokeBriefsLink.d.ts +2 -2
- package/dist/contract/cli/invokeBriefsLink.js +9 -47
- package/dist/contract/cli/invokeBriefsLink.js.map +1 -1
- package/dist/contract/cli/invokeChoose.d.ts +1 -1
- package/dist/contract/cli/invokeInit.d.ts +9 -0
- package/dist/contract/cli/invokeInit.js +57 -0
- package/dist/contract/cli/invokeInit.js.map +1 -0
- package/dist/contract/cli/invokeList.d.ts +2 -2
- package/dist/contract/cli/invokeReadme.d.ts +2 -2
- package/dist/contract/cli/invokeRoles.d.ts +2 -2
- package/dist/contract/cli/invokeRolesBoot.d.ts +1 -1
- package/dist/contract/cli/invokeRolesBoot.js +2 -2
- package/dist/contract/cli/invokeRolesBoot.js.map +1 -1
- package/dist/contract/cli/invokeRolesLink.d.ts +2 -2
- package/dist/contract/cli/invokeRolesLink.js +17 -96
- package/dist/contract/cli/invokeRolesLink.js.map +1 -1
- package/dist/contract/sdk.d.ts +13 -13
- package/dist/contract/sdk.js +25 -25
- package/dist/contract/sdk.js.map +1 -1
- package/dist/domain/constants.d.ts +3 -0
- package/dist/domain/constants.js +5 -0
- package/dist/domain/constants.js.map +1 -0
- package/dist/domain/objects/InvokeHooks.d.ts +1 -1
- package/dist/domain/objects/InvokeOpts.d.ts +1 -1
- package/dist/domain/objects/Role.d.ts +2 -2
- package/dist/domain/objects/RoleContext.d.ts +1 -1
- package/dist/domain/objects/RoleSkill.d.ts +2 -2
- package/dist/domain/objects/RoleSkillArgGetter.d.ts +3 -3
- package/dist/domain/objects/RoleTrait.d.ts +2 -2
- package/dist/domain/objects/Stitch.d.ts +4 -4
- package/dist/domain/objects/Stitch.js.map +1 -1
- package/dist/domain/objects/StitchChoice.d.ts +2 -2
- package/dist/domain/objects/StitchChoice.js.map +1 -1
- package/dist/domain/objects/StitchCycle.d.ts +4 -4
- package/dist/domain/objects/StitchCycle.js.map +1 -1
- package/dist/domain/objects/StitchFanout.d.ts +4 -4
- package/dist/domain/objects/StitchFanout.js.map +1 -1
- package/dist/domain/objects/StitchRoute.d.ts +1 -1
- package/dist/domain/objects/StitchRoute.js.map +1 -1
- package/dist/domain/objects/StitchSetEvent.d.ts +3 -3
- package/dist/domain/objects/StitchStep.d.ts +3 -3
- package/dist/domain/objects/Stitcher.d.ts +9 -9
- package/dist/domain/objects/Stitcher.js.map +1 -1
- package/dist/domain/objects/Template.d.ts +2 -2
- package/dist/domain/objects/Template.js.map +1 -1
- package/dist/domain/objects/Thread.d.ts +2 -2
- package/dist/domain/objects/Threads.d.ts +2 -2
- package/dist/domain/objects/Threads.js.map +1 -1
- package/dist/domain/objects/index.d.ts +2 -2
- package/dist/domain/objects/index.js +2 -2
- package/dist/domain/objects/index.js.map +1 -1
- package/dist/logic/context/genContextStitchTrail.d.ts +1 -1
- package/dist/logic/context/genContextStitchTrail.js.map +1 -1
- package/dist/logic/init/discoverRolePackages.d.ts +8 -0
- package/dist/logic/init/discoverRolePackages.js +20 -0
- package/dist/logic/init/discoverRolePackages.js.map +1 -0
- package/dist/logic/init/generateRhachetConfig.d.ts +8 -0
- package/dist/logic/init/generateRhachetConfig.js +40 -0
- package/dist/logic/init/generateRhachetConfig.js.map +1 -0
- package/dist/logic/invoke/assureFindRole.d.ts +2 -2
- package/dist/logic/invoke/assureUniqueRoles.d.ts +1 -1
- package/dist/logic/invoke/getAgentReadmeTemplates.js +1 -1
- package/dist/logic/invoke/getInvokeHooksByOpts.d.ts +4 -3
- package/dist/logic/invoke/getInvokeHooksByOpts.js +11 -3
- package/dist/logic/invoke/getInvokeHooksByOpts.js.map +1 -1
- package/dist/logic/invoke/getRegistriesByOpts.d.ts +2 -2
- package/dist/logic/invoke/getSkillContext.d.ts +3 -3
- package/dist/logic/invoke/getSkillThreads.d.ts +4 -4
- package/dist/logic/invoke/hooks/onInvokeAskInput.d.ts +2 -2
- package/dist/logic/invoke/link/findsertFile.d.ts +9 -0
- package/dist/logic/invoke/link/findsertFile.js +29 -0
- package/dist/logic/invoke/link/findsertFile.js.map +1 -0
- package/dist/logic/invoke/link/symlinkResourceDirectories.d.ts +12 -0
- package/dist/logic/invoke/link/symlinkResourceDirectories.js +81 -0
- package/dist/logic/invoke/link/symlinkResourceDirectories.js.map +1 -0
- package/dist/logic/invoke/performInCurrentThread.d.ts +2 -2
- package/dist/logic/invoke/performInIsolatedThread.execute.d.ts +1 -1
- package/dist/logic/invoke/performInIsolatedThread.invoke.d.ts +2 -2
- package/dist/logic/invoke/performInIsolatedThread.invoke.js +3 -3
- package/dist/logic/invoke/performInIsolatedThread.invoke.js.map +1 -1
- package/dist/logic/invoke/performInIsolatedThreads.d.ts +1 -1
- package/dist/logic/role/addRoleTraits.d.ts +5 -5
- package/dist/logic/role/enrollThread.d.ts +4 -4
- package/dist/logic/role/genRoleSkill.d.ts +1 -1
- package/dist/logic/stitch/adapters/imagineViaOpenAI.d.ts +1 -1
- package/dist/logic/stitch/enstitch.d.ts +3 -3
- package/dist/logic/stitch/enstitch.js +1 -1
- package/dist/logic/stitch/enstitch.js.map +1 -1
- package/dist/logic/stitch/invokeImagineStitcher.d.ts +3 -3
- package/dist/logic/stitch/withStitchTrail.d.ts +4 -4
- package/dist/logic/stitch/withStitchTrail.js +1 -1
- package/dist/logic/stitch/withStitchTrail.js.map +1 -1
- package/dist/logic/template/genStepImagineViaTemplate.d.ts +2 -2
- package/dist/logic/template/genStepImagineViaTemplate.js.map +1 -1
- package/dist/logic/template/genTemplate.d.ts +3 -3
- package/dist/logic/template/getTemplatePathByCallerPath.d.ts +1 -1
- package/dist/logic/template/getTemplatePathByCallerPath.js +2 -2
- package/dist/logic/template/getTemplatePathByCallerPath.js.map +1 -1
- package/dist/logic/template/getTemplateValFromArtifacts.d.ts +2 -2
- package/dist/logic/template/getTemplateValFromArtifacts.js.map +1 -1
- package/dist/logic/template/getTemplateVarsFromInheritance.d.ts +1 -1
- package/dist/logic/template/useTemplate.d.ts +2 -2
- package/dist/logic/thread/getStitch.d.ts +1 -1
- package/dist/logic/weave/compose/GStitcherInferredFromChoice.generic.d.ts +3 -3
- package/dist/logic/weave/compose/GStitcherInferredFromCycle.generic.d.ts +4 -4
- package/dist/logic/weave/compose/GStitcherInferredFromFanout.generic.d.ts +6 -6
- package/dist/logic/weave/compose/GStitcherInferredFromRoute.generic.d.ts +4 -4
- package/dist/logic/weave/compose/ProcedureContextMerged.generic.d.ts +1 -1
- package/dist/logic/weave/compose/ThreadsMerged.generic.d.ts +4 -4
- package/dist/logic/weave/compose/asStitcher.d.ts +3 -3
- package/dist/logic/weave/compose/asStitcherFlat.d.ts +2 -2
- package/dist/logic/weave/compose/genStitchChoice.d.ts +3 -3
- package/dist/logic/weave/compose/genStitchCycle.d.ts +5 -5
- package/dist/logic/weave/compose/genStitchFanout.d.ts +5 -5
- package/dist/logic/weave/compose/genStitchFanout.js.map +1 -1
- package/dist/logic/weave/compose/genStitchRoute.d.ts +3 -3
- package/dist/logic/weave/compose/genStitchRoute.js.map +1 -1
- package/dist/logic/weave/enweaveOneChoice.d.ts +2 -2
- package/dist/logic/weave/enweaveOneChoice.js.map +1 -1
- package/dist/logic/weave/enweaveOneCycle.d.ts +2 -2
- package/dist/logic/weave/enweaveOneCycle.js.map +1 -1
- package/dist/logic/weave/enweaveOneFanout.d.ts +2 -2
- package/dist/logic/weave/enweaveOneFanout.js.map +1 -1
- package/dist/logic/weave/enweaveOneRoute.d.ts +2 -2
- package/dist/logic/weave/enweaveOneRoute.js.map +1 -1
- package/dist/logic/weave/enweaveOneStitcher.d.ts +2 -2
- package/dist/logic/weave/enweaveOneStitcher.js.map +1 -1
- package/license.md +21 -0
- package/package.json +36 -36
- package/dist/.test/directory.d.ts +0 -2
- package/dist/.test/directory.js +0 -6
- package/dist/.test/directory.js.map +0 -1
- package/dist/.test/example.use.repo/example.echoRegistry.d.ts +0 -2
- package/dist/.test/example.use.repo/example.echoRegistry.js +0 -108
- package/dist/.test/example.use.repo/example.echoRegistry.js.map +0 -1
- package/dist/.test/genContextLogTrail.d.ts +0 -2
- package/dist/.test/genContextLogTrail.js +0 -12
- package/dist/.test/genContextLogTrail.js.map +0 -1
- package/dist/.test/getContextOpenAI.d.ts +0 -2
- package/dist/.test/getContextOpenAI.js +0 -18
- package/dist/.test/getContextOpenAI.js.map +0 -1
- package/dist/.test/stitchers/genStitcherCodeFileRead.d.ts +0 -14
- package/dist/.test/stitchers/genStitcherCodeFileRead.js +0 -23
- package/dist/.test/stitchers/genStitcherCodeFileRead.js.map +0 -1
- package/dist/.test/stitchers/genStitcherCodeFileWrite.d.ts +0 -16
- package/dist/.test/stitchers/genStitcherCodeFileWrite.js +0 -29
- package/dist/.test/stitchers/genStitcherCodeFileWrite.js.map +0 -1
- package/dist/.test/stitchers/genStitcherCodeReviewImagine.d.ts +0 -15
- package/dist/.test/stitchers/genStitcherCodeReviewImagine.js +0 -97
- package/dist/.test/stitchers/genStitcherCodeReviewImagine.js.map +0 -1
- package/dist/.test/stitchers/stitcherCodeDiffImagine.d.ts +0 -13
- package/dist/.test/stitchers/stitcherCodeDiffImagine.js +0 -33
- package/dist/.test/stitchers/stitcherCodeDiffImagine.js.map +0 -1
- package/dist/.test/stitchers/stitcherFanoutRandomSum.d.ts +0 -13
- package/dist/.test/stitchers/stitcherFanoutRandomSum.js +0 -45
- package/dist/.test/stitchers/stitcherFanoutRandomSum.js.map +0 -1
- package/dist/.test/stitchers/stitcherFanoutSubroutes.d.ts +0 -35
- package/dist/.test/stitchers/stitcherFanoutSubroutes.js +0 -76
- package/dist/.test/stitchers/stitcherFanoutSubroutes.js.map +0 -1
- package/dist/.test/threads/codeArtist.d.ts +0 -6
- package/dist/.test/threads/codeArtist.js +0 -26
- package/dist/.test/threads/codeArtist.js.map +0 -1
- package/dist/.test/threads/codeCritic.d.ts +0 -6
- package/dist/.test/threads/codeCritic.js +0 -21
- package/dist/.test/threads/codeCritic.js.map +0 -1
- package/dist/.test/threads/director.d.ts +0 -6
- package/dist/.test/threads/director.js +0 -14
- package/dist/.test/threads/director.js.map +0 -1
- package/dist/contract/cli/invoke.integration.test.d.ts +0 -1
- package/dist/contract/cli/invoke.integration.test.js +0 -39
- package/dist/contract/cli/invoke.integration.test.js.map +0 -1
- package/dist/contract/cli/invokeAsk.integration.test.d.ts +0 -1
- package/dist/contract/cli/invokeAsk.integration.test.js +0 -69
- package/dist/contract/cli/invokeAsk.integration.test.js.map +0 -1
- package/dist/contract/cli/invokeBriefsBoot.integration.test.d.ts +0 -1
- package/dist/contract/cli/invokeBriefsBoot.integration.test.js +0 -159
- package/dist/contract/cli/invokeBriefsBoot.integration.test.js.map +0 -1
- package/dist/contract/cli/invokeBriefsLink.integration.test.d.ts +0 -1
- package/dist/contract/cli/invokeBriefsLink.integration.test.js +0 -97
- package/dist/contract/cli/invokeBriefsLink.integration.test.js.map +0 -1
- package/dist/contract/cli/invokeChoose.integration.test.d.ts +0 -1
- package/dist/contract/cli/invokeChoose.integration.test.js +0 -111
- package/dist/contract/cli/invokeChoose.integration.test.js.map +0 -1
- package/dist/contract/cli/invokeReadme.integration.test.d.ts +0 -1
- package/dist/contract/cli/invokeReadme.integration.test.js +0 -62
- package/dist/contract/cli/invokeReadme.integration.test.js.map +0 -1
- package/dist/domain/objects/InvokeOpts.test.d.ts +0 -1
- package/dist/domain/objects/InvokeOpts.test.js +0 -41
- package/dist/domain/objects/InvokeOpts.test.js.map +0 -1
- package/dist/domain/objects/Stitcher.test.d.ts +0 -1
- package/dist/domain/objects/Stitcher.test.js +0 -78
- package/dist/domain/objects/Stitcher.test.js.map +0 -1
- package/dist/domain/objects/Template.test.d.ts +0 -1
- package/dist/domain/objects/Template.test.js +0 -48
- package/dist/domain/objects/Template.test.js.map +0 -1
- package/dist/logic/invoke/addAttemptQualifierToOutputPath.test.d.ts +0 -1
- package/dist/logic/invoke/addAttemptQualifierToOutputPath.test.js +0 -130
- package/dist/logic/invoke/addAttemptQualifierToOutputPath.test.js.map +0 -1
- package/dist/logic/invoke/getPeerQualifiersOfOutputChoice.test.d.ts +0 -1
- package/dist/logic/invoke/getPeerQualifiersOfOutputChoice.test.js +0 -77
- package/dist/logic/invoke/getPeerQualifiersOfOutputChoice.test.js.map +0 -1
- package/dist/logic/invoke/getSkillContext.test.d.ts +0 -1
- package/dist/logic/invoke/getSkillContext.test.js +0 -85
- package/dist/logic/invoke/getSkillContext.test.js.map +0 -1
- package/dist/logic/invoke/getSkillThread.test.d.ts +0 -1
- package/dist/logic/invoke/getSkillThread.test.js +0 -115
- package/dist/logic/invoke/getSkillThread.test.js.map +0 -1
- package/dist/logic/invoke/performInIsolatedThread.invoke.integration.test.d.ts +0 -1
- package/dist/logic/invoke/performInIsolatedThread.invoke.integration.test.js +0 -74
- package/dist/logic/invoke/performInIsolatedThread.invoke.integration.test.js.map +0 -1
- package/dist/logic/invoke/performInIsolatedThreads.integration.test.d.ts +0 -1
- package/dist/logic/invoke/performInIsolatedThreads.integration.test.js +0 -75
- package/dist/logic/invoke/performInIsolatedThreads.integration.test.js.map +0 -1
- package/dist/logic/role/addRoleTraits.test.d.ts +0 -1
- package/dist/logic/role/addRoleTraits.test.js +0 -93
- package/dist/logic/role/addRoleTraits.test.js.map +0 -1
- package/dist/logic/role/enrollThread.integration.test.d.ts +0 -1
- package/dist/logic/role/enrollThread.integration.test.js +0 -79
- package/dist/logic/role/enrollThread.integration.test.js.map +0 -1
- package/dist/logic/role/genRoleSkill.test.d.ts +0 -1
- package/dist/logic/role/genRoleSkill.test.js +0 -79
- package/dist/logic/role/genRoleSkill.test.js.map +0 -1
- package/dist/logic/stitch/enstitch.test.d.ts +0 -1
- package/dist/logic/stitch/enstitch.test.js +0 -112
- package/dist/logic/stitch/enstitch.test.js.map +0 -1
- package/dist/logic/stitch/invokeImagineStitcher.integration.test.d.ts +0 -1
- package/dist/logic/stitch/invokeImagineStitcher.integration.test.js +0 -195
- package/dist/logic/stitch/invokeImagineStitcher.integration.test.js.map +0 -1
- package/dist/logic/template/genStepImagineViaTemplate.test.d.ts +0 -1
- package/dist/logic/template/genStepImagineViaTemplate.test.js +0 -126
- package/dist/logic/template/genStepImagineViaTemplate.test.js.map +0 -1
- package/dist/logic/template/genTemplate.test.d.ts +0 -1
- package/dist/logic/template/genTemplate.test.js +0 -118
- package/dist/logic/template/genTemplate.test.js.map +0 -1
- package/dist/logic/template/useTemplate.integration.test.d.ts +0 -1
- package/dist/logic/template/useTemplate.integration.test.js +0 -28
- package/dist/logic/template/useTemplate.integration.test.js.map +0 -1
- package/dist/logic/thread/getStitch.test.d.ts +0 -1
- package/dist/logic/thread/getStitch.test.js +0 -73
- package/dist/logic/thread/getStitch.test.js.map +0 -1
- package/dist/logic/weave/compose/GStitcherInferredFromChoice.generic.test.d.ts +0 -1
- package/dist/logic/weave/compose/GStitcherInferredFromChoice.generic.test.js +0 -67
- package/dist/logic/weave/compose/GStitcherInferredFromChoice.generic.test.js.map +0 -1
- package/dist/logic/weave/compose/GStitcherInferredFromCycle.generic.test.d.ts +0 -1
- package/dist/logic/weave/compose/GStitcherInferredFromCycle.generic.test.js +0 -132
- package/dist/logic/weave/compose/GStitcherInferredFromCycle.generic.test.js.map +0 -1
- package/dist/logic/weave/compose/GStitcherInferredFromFanout.generic.test.d.ts +0 -1
- package/dist/logic/weave/compose/GStitcherInferredFromFanout.generic.test.js +0 -74
- package/dist/logic/weave/compose/GStitcherInferredFromFanout.generic.test.js.map +0 -1
- package/dist/logic/weave/compose/GStitcherInferredFromRoute.generic.test.d.ts +0 -1
- package/dist/logic/weave/compose/GStitcherInferredFromRoute.generic.test.js +0 -190
- package/dist/logic/weave/compose/GStitcherInferredFromRoute.generic.test.js.map +0 -1
- package/dist/logic/weave/compose/ProcedureContextMerged.generic.test.d.ts +0 -1
- package/dist/logic/weave/compose/ProcedureContextMerged.generic.test.js +0 -29
- package/dist/logic/weave/compose/ProcedureContextMerged.generic.test.js.map +0 -1
- package/dist/logic/weave/compose/ThreadsMerged.generic.test.d.ts +0 -1
- package/dist/logic/weave/compose/ThreadsMerged.generic.test.js +0 -420
- package/dist/logic/weave/compose/ThreadsMerged.generic.test.js.map +0 -1
- package/dist/logic/weave/compose/asStitcher.test.d.ts +0 -1
- package/dist/logic/weave/compose/asStitcher.test.js +0 -95
- package/dist/logic/weave/compose/asStitcher.test.js.map +0 -1
- package/dist/logic/weave/compose/asStitcherFlat.test.d.ts +0 -1
- package/dist/logic/weave/compose/asStitcherFlat.test.js +0 -96
- package/dist/logic/weave/compose/asStitcherFlat.test.js.map +0 -1
- package/dist/logic/weave/compose/genStitchChoice.test.d.ts +0 -1
- package/dist/logic/weave/compose/genStitchChoice.test.js +0 -200
- package/dist/logic/weave/compose/genStitchChoice.test.js.map +0 -1
- package/dist/logic/weave/compose/genStitchCycle.test.d.ts +0 -1
- package/dist/logic/weave/compose/genStitchCycle.test.js +0 -267
- package/dist/logic/weave/compose/genStitchCycle.test.js.map +0 -1
- package/dist/logic/weave/compose/genStitchFanout.test.d.ts +0 -1
- package/dist/logic/weave/compose/genStitchFanout.test.js +0 -79
- package/dist/logic/weave/compose/genStitchFanout.test.js.map +0 -1
- package/dist/logic/weave/compose/genStitchRoute.test.d.ts +0 -1
- package/dist/logic/weave/compose/genStitchRoute.test.js +0 -120
- package/dist/logic/weave/compose/genStitchRoute.test.js.map +0 -1
- package/dist/logic/weave/enweaveOneChoice.test.d.ts +0 -1
- package/dist/logic/weave/enweaveOneChoice.test.js +0 -181
- package/dist/logic/weave/enweaveOneChoice.test.js.map +0 -1
- package/dist/logic/weave/enweaveOneCycle.test.d.ts +0 -1
- package/dist/logic/weave/enweaveOneCycle.test.js +0 -180
- package/dist/logic/weave/enweaveOneCycle.test.js.map +0 -1
- package/dist/logic/weave/enweaveOneFanout.integration.test.d.ts +0 -1
- package/dist/logic/weave/enweaveOneFanout.integration.test.js +0 -166
- package/dist/logic/weave/enweaveOneFanout.integration.test.js.map +0 -1
- package/dist/logic/weave/enweaveOneRoute.integration.test.d.ts +0 -1
- package/dist/logic/weave/enweaveOneRoute.integration.test.js +0 -159
- package/dist/logic/weave/enweaveOneRoute.integration.test.js.map +0 -1
- package/dist/logic/weave/enweaveOneStitcher.integration.test.d.ts +0 -2
- package/dist/logic/weave/enweaveOneStitcher.integration.test.js +0 -258
- package/dist/logic/weave/enweaveOneStitcher.integration.test.js.map +0 -1
|
@@ -1,166 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const helpful_errors_1 = require("helpful-errors");
|
|
4
|
-
const test_fns_1 = require("test-fns");
|
|
5
|
-
const genContextLogTrail_1 = require("../../.test/genContextLogTrail");
|
|
6
|
-
const getContextOpenAI_1 = require("../../.test/getContextOpenAI");
|
|
7
|
-
const genStitcherCodeReviewImagine_1 = require("../../.test/stitchers/genStitcherCodeReviewImagine");
|
|
8
|
-
const stitcherFanoutRandomSum_1 = require("../../.test/stitchers/stitcherFanoutRandomSum");
|
|
9
|
-
const stitcherFanoutSubroutes_1 = require("../../.test/stitchers/stitcherFanoutSubroutes");
|
|
10
|
-
const StitchStep_1 = require("../../domain/objects/StitchStep");
|
|
11
|
-
const Thread_1 = require("../../domain/objects/Thread");
|
|
12
|
-
const genContextStitchTrail_1 = require("../context/genContextStitchTrail");
|
|
13
|
-
const genThread_1 = require("../thread/genThread");
|
|
14
|
-
const genStitchFanout_1 = require("./compose/genStitchFanout");
|
|
15
|
-
const enweaveOneFanout_1 = require("./enweaveOneFanout");
|
|
16
|
-
describe('enweaveOneFanout', () => {
|
|
17
|
-
const context = { ...(0, genContextStitchTrail_1.genContextStitchTrail)(), ...(0, genContextLogTrail_1.genContextLogTrail)() };
|
|
18
|
-
(0, test_fns_1.given)('a fanout that computes 5 random numbers then sums them', () => {
|
|
19
|
-
const threadMain = new Thread_1.Thread({
|
|
20
|
-
context: { role: 'main' },
|
|
21
|
-
stitches: [],
|
|
22
|
-
});
|
|
23
|
-
(0, test_fns_1.when)('invoked with the correct thread', () => {
|
|
24
|
-
(0, test_fns_1.then)('it should return a number stitch equal to the sum of the random outputs', async () => {
|
|
25
|
-
const { stitch, threads } = await (0, enweaveOneFanout_1.enweaveOneFanout)({
|
|
26
|
-
stitcher: stitcherFanoutRandomSum_1.stitcherFanoutRandomSum,
|
|
27
|
-
threads: { main: threadMain },
|
|
28
|
-
}, context);
|
|
29
|
-
console.log({ stitch, threads });
|
|
30
|
-
// validate output is a number
|
|
31
|
-
expect(typeof stitch.output).toBe('number');
|
|
32
|
-
// validate input to the concluder is a number[]
|
|
33
|
-
expect(Array.isArray(stitch.input)).toBe(true);
|
|
34
|
-
expect(stitch.input.every((n) => typeof n === 'number')).toBe(true);
|
|
35
|
-
// validate stitch.output === sum(stitch.input)
|
|
36
|
-
const expectedSum = stitch.input.reduce((a, b) => a + b, 0);
|
|
37
|
-
expect(stitch.output).toBe(expectedSum);
|
|
38
|
-
// validate thread output is form: 'single'
|
|
39
|
-
expect(threads.main.stitches.at(-1)?.output).toBe(expectedSum);
|
|
40
|
-
});
|
|
41
|
-
});
|
|
42
|
-
(0, test_fns_1.when)('invoked with an incorrect thread role', () => {
|
|
43
|
-
const threadWrong = new Thread_1.Thread({
|
|
44
|
-
context: { role: 'wrong' },
|
|
45
|
-
stitches: [],
|
|
46
|
-
});
|
|
47
|
-
(0, test_fns_1.then)('it should throw at compile time due to wrong role', async () => {
|
|
48
|
-
await (0, helpful_errors_1.getError)((0, enweaveOneFanout_1.enweaveOneFanout)({
|
|
49
|
-
stitcher: stitcherFanoutRandomSum_1.stitcherFanoutRandomSum,
|
|
50
|
-
// @ts-expect-error: wrong thread role
|
|
51
|
-
threads: { wrong: threadWrong },
|
|
52
|
-
}, context));
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
});
|
|
56
|
-
(0, test_fns_1.given)('a fanout with one route of 2 steps and another of 3 steps', () => {
|
|
57
|
-
const threadMain = new Thread_1.Thread({
|
|
58
|
-
context: { role: 'main' },
|
|
59
|
-
stitches: [],
|
|
60
|
-
});
|
|
61
|
-
(0, test_fns_1.then)('it should output a stitch where input = [3, 6] and output = 9', async () => {
|
|
62
|
-
const { stitch, threads } = await (0, enweaveOneFanout_1.enweaveOneFanout)({
|
|
63
|
-
stitcher: stitcherFanoutSubroutes_1.stitcherFanoutWithRoutes,
|
|
64
|
-
threads: { main: threadMain },
|
|
65
|
-
}, context);
|
|
66
|
-
expect(Array.isArray(stitch.input)).toBe(true);
|
|
67
|
-
expect(stitch.input).toEqual([3, 6]);
|
|
68
|
-
expect(stitch.output).toBe(9);
|
|
69
|
-
expect(threads.main.stitches.at(-1)?.output).toBe(9);
|
|
70
|
-
});
|
|
71
|
-
});
|
|
72
|
-
test_fns_1.given.only('a route with imagine stitchers, parallelized (closer to real world usecase)', () => {
|
|
73
|
-
const stitchCodeRead = {
|
|
74
|
-
input: null,
|
|
75
|
-
output: {
|
|
76
|
-
path: '__path__',
|
|
77
|
-
content: `
|
|
78
|
-
import { UnexpectedCodePathError } from '@ehmpathy/error-fns';
|
|
79
|
-
import { UniDateTime } from '@ehmpathy/uni-time';
|
|
80
|
-
import { PickOne } from 'type-fns';
|
|
81
|
-
|
|
82
|
-
import { daoJobProspect } from '../../data/dao/jobProspectDao';
|
|
83
|
-
import { withDatabaseContext } from '../../utils/database/withDatabaseContext';
|
|
84
|
-
|
|
85
|
-
export const getProspects = withDatabaseContext(
|
|
86
|
-
async (
|
|
87
|
-
input: PickOne<{
|
|
88
|
-
byProvider: { providerUuid: string };
|
|
89
|
-
}> & {
|
|
90
|
-
page: {
|
|
91
|
-
since?: { openedAt: UniDateTime };
|
|
92
|
-
until?: { openedAt: UniDateTime };
|
|
93
|
-
limit: number;
|
|
94
|
-
};
|
|
95
|
-
},
|
|
96
|
-
context,
|
|
97
|
-
) => {
|
|
98
|
-
if (input.byProvider)
|
|
99
|
-
return daoJobProspect.findAllByProvider(
|
|
100
|
-
{
|
|
101
|
-
by: {
|
|
102
|
-
providerUuid: input.byProvider.providerUuid,
|
|
103
|
-
},
|
|
104
|
-
filter: {
|
|
105
|
-
sinceOpenedAt: input.page.since?.openedAt,
|
|
106
|
-
untilOpenedAt: input.page.until?.openedAt,
|
|
107
|
-
},
|
|
108
|
-
limit: input.page.limit,
|
|
109
|
-
},
|
|
110
|
-
context,
|
|
111
|
-
);
|
|
112
|
-
|
|
113
|
-
throw new UnexpectedCodePathError('unsupported input option');
|
|
114
|
-
},
|
|
115
|
-
`.trim(),
|
|
116
|
-
},
|
|
117
|
-
};
|
|
118
|
-
const stitcherCodeReviewConcluder = new StitchStep_1.StitchStepCompute({
|
|
119
|
-
slug: 'sum',
|
|
120
|
-
readme: null,
|
|
121
|
-
form: 'COMPUTE',
|
|
122
|
-
stitchee: 'critic',
|
|
123
|
-
invoke: ({ threads }) => {
|
|
124
|
-
const feedbacks = threads.critic.peers.map((peer) => peer.stitches.slice(-1)[0]?.output);
|
|
125
|
-
return {
|
|
126
|
-
input: feedbacks,
|
|
127
|
-
output: feedbacks,
|
|
128
|
-
};
|
|
129
|
-
},
|
|
130
|
-
});
|
|
131
|
-
const fanout = (0, genStitchFanout_1.genStitchFanout)({
|
|
132
|
-
slug: '[critic]<code:review>.<fanout>[[review]]',
|
|
133
|
-
readme: null,
|
|
134
|
-
parallels: [
|
|
135
|
-
(0, genStitcherCodeReviewImagine_1.genStitcherCodeReview)({ scope: 'technical', focus: 'blockers' }),
|
|
136
|
-
(0, genStitcherCodeReviewImagine_1.genStitcherCodeReview)({ scope: 'technical', focus: 'chances' }),
|
|
137
|
-
(0, genStitcherCodeReviewImagine_1.genStitcherCodeReview)({ scope: 'technical', focus: 'praises' }),
|
|
138
|
-
(0, genStitcherCodeReviewImagine_1.genStitcherCodeReview)({ scope: 'functional', focus: 'blockers' }),
|
|
139
|
-
(0, genStitcherCodeReviewImagine_1.genStitcherCodeReview)({ scope: 'functional', focus: 'chances' }),
|
|
140
|
-
(0, genStitcherCodeReviewImagine_1.genStitcherCodeReview)({ scope: 'functional', focus: 'praises' }),
|
|
141
|
-
],
|
|
142
|
-
concluder: stitcherCodeReviewConcluder,
|
|
143
|
-
});
|
|
144
|
-
(0, test_fns_1.when)('given the threads required', () => {
|
|
145
|
-
(0, test_fns_1.then)('it should successfully execute the stitches as a weave', async () => {
|
|
146
|
-
const output = await (0, enweaveOneFanout_1.enweaveOneFanout)({
|
|
147
|
-
stitcher: fanout,
|
|
148
|
-
threads: {
|
|
149
|
-
critic: {
|
|
150
|
-
...(0, genThread_1.genThread)({
|
|
151
|
-
role: 'critic',
|
|
152
|
-
tools: [],
|
|
153
|
-
facts: [],
|
|
154
|
-
}),
|
|
155
|
-
stitches: [stitchCodeRead],
|
|
156
|
-
},
|
|
157
|
-
director: (0, genThread_1.genThread)({ role: 'director' }),
|
|
158
|
-
},
|
|
159
|
-
}, { ...context, ...(0, getContextOpenAI_1.getContextOpenAI)() });
|
|
160
|
-
expect(output.stitch.output.length).toEqual(6);
|
|
161
|
-
console.log(output.stitch.output);
|
|
162
|
-
});
|
|
163
|
-
});
|
|
164
|
-
});
|
|
165
|
-
});
|
|
166
|
-
//# sourceMappingURL=enweaveOneFanout.integration.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"enweaveOneFanout.integration.test.js","sourceRoot":"","sources":["../../../src/logic/weave/enweaveOneFanout.integration.test.ts"],"names":[],"mappings":";;AAAA,mDAA0C;AAC1C,uCAA6C;AAG7C,uEAAoE;AACpE,mEAAgE;AAChE,qGAA2F;AAC3F,2FAAwF;AACxF,2FAAyF;AAEzF,gEAAoE;AAEpE,wDAAqD;AAErD,4EAAyE;AACzE,mDAAgD;AAChD,+DAA4D;AAC5D,yDAAsD;AAEtD,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,MAAM,OAAO,GAAG,EAAE,GAAG,IAAA,6CAAqB,GAAE,EAAE,GAAG,IAAA,uCAAkB,GAAE,EAAE,CAAC;IACxE,IAAA,gBAAK,EAAC,wDAAwD,EAAE,GAAG,EAAE;QACnE,MAAM,UAAU,GAAG,IAAI,eAAM,CAAC;YAC5B,OAAO,EAAE,EAAE,IAAI,EAAE,MAAe,EAAE;YAClC,QAAQ,EAAE,EAAE;SACb,CAAC,CAAC;QAEH,IAAA,eAAI,EAAC,iCAAiC,EAAE,GAAG,EAAE;YAC3C,IAAA,eAAI,EACF,yEAAyE,EACzE,KAAK,IAAI,EAAE;gBACT,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAA,mCAAgB,EAChD;oBACE,QAAQ,EAAE,iDAAuB;oBACjC,OAAO,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;iBAC9B,EACD,OAAO,CACR,CAAC;gBACF,OAAO,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC;gBAEjC,8BAA8B;gBAC9B,MAAM,CAAC,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAE5C,gDAAgD;gBAChD,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC/C,MAAM,CACJ,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAU,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,CAAC,CAC1D,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAEb,+CAA+C;gBAC/C,MAAM,WAAW,GAAI,MAAM,CAAC,KAAkB,CAAC,MAAM,CACnD,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EACf,CAAC,CACF,CAAC;gBACF,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAExC,2CAA2C;gBAC3C,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACjE,CAAC,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,IAAA,eAAI,EAAC,uCAAuC,EAAE,GAAG,EAAE;YACjD,MAAM,WAAW,GAAG,IAAI,eAAM,CAAC;gBAC7B,OAAO,EAAE,EAAE,IAAI,EAAE,OAAgB,EAAE;gBACnC,QAAQ,EAAE,EAAE;aACb,CAAC,CAAC;YAEH,IAAA,eAAI,EAAC,mDAAmD,EAAE,KAAK,IAAI,EAAE;gBACnE,MAAM,IAAA,yBAAQ,EACZ,IAAA,mCAAgB,EACd;oBACE,QAAQ,EAAE,iDAAuB;oBACjC,sCAAsC;oBACtC,OAAO,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE;iBAChC,EACD,OAAO,CACR,CACF,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAA,gBAAK,EAAC,2DAA2D,EAAE,GAAG,EAAE;QACtE,MAAM,UAAU,GAAG,IAAI,eAAM,CAAC;YAC5B,OAAO,EAAE,EAAE,IAAI,EAAE,MAAe,EAAE;YAClC,QAAQ,EAAE,EAAE;SACb,CAAC,CAAC;QAEH,IAAA,eAAI,EACF,+DAA+D,EAC/D,KAAK,IAAI,EAAE;YACT,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAA,mCAAgB,EAChD;gBACE,QAAQ,EAAE,kDAAwB;gBAClC,OAAO,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;aAC9B,EACD,OAAO,CACR,CAAC;YAEF,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC/C,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACrC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAE9B,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACvD,CAAC,CACF,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,gBAAK,CAAC,IAAI,CACR,6EAA6E,EAC7E,GAAG,EAAE;QACH,MAAM,cAAc,GAAG;YACrB,KAAK,EAAE,IAAI;YACX,MAAM,EAAE;gBACN,IAAI,EAAE,UAAU;gBAChB,OAAO,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAsCR,CAAC,IAAI,EAAE;aACT;SACF,CAAC;QAEF,MAAM,2BAA2B,GAAG,IAAI,8BAAiB,CAMvD;YACA,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,IAAI;YACZ,IAAI,EAAE,SAAS;YACf,QAAQ,EAAE,QAAQ;YAClB,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE;gBACtB,MAAM,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CACxC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,CAC7C,CAAC;gBACF,OAAO;oBACL,KAAK,EAAE,SAAS;oBAChB,MAAM,EAAE,SAAS;iBAClB,CAAC;YACJ,CAAC;SACF,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,IAAA,iCAAe,EAAC;YAC7B,IAAI,EAAE,0CAA0C;YAChD,MAAM,EAAE,IAAI;YACZ,SAAS,EAAE;gBACT,IAAA,oDAAqB,EAAC,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC;gBAChE,IAAA,oDAAqB,EAAC,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;gBAC/D,IAAA,oDAAqB,EAAC,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;gBAC/D,IAAA,oDAAqB,EAAC,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC;gBACjE,IAAA,oDAAqB,EAAC,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;gBAChE,IAAA,oDAAqB,EAAC,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;aACjE;YACD,SAAS,EAAE,2BAA2B;SACvC,CAAC,CAAC;QAEH,IAAA,eAAI,EAAC,4BAA4B,EAAE,GAAG,EAAE;YACtC,IAAA,eAAI,EACF,wDAAwD,EACxD,KAAK,IAAI,EAAE;gBACT,MAAM,MAAM,GAAG,MAAM,IAAA,mCAAgB,EACnC;oBACE,QAAQ,EAAE,MAAM;oBAChB,OAAO,EAAE;wBACP,MAAM,EAAE;4BACN,GAAG,IAAA,qBAAS,EAAC;gCACX,IAAI,EAAE,QAAiB;gCACvB,KAAK,EAAE,EAAE;gCACT,KAAK,EAAE,EAAE;6BACV,CAAC;4BACF,QAAQ,EAAE,CAAC,cAA6B,CAAC;yBAC1C;wBACD,QAAQ,EAAE,IAAA,qBAAS,EAAC,EAAE,IAAI,EAAE,UAAmB,EAAE,CAAC;qBACnD;iBACF,EACD,EAAE,GAAG,OAAO,EAAE,GAAG,IAAA,mCAAgB,GAAE,EAAE,CACtC,CAAC;gBAEF,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC/C,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YACpC,CAAC,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,159 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const uni_time_1 = require("@ehmpathy/uni-time");
|
|
4
|
-
const helpful_errors_1 = require("helpful-errors");
|
|
5
|
-
const test_fns_1 = require("test-fns");
|
|
6
|
-
const genContextLogTrail_1 = require("../../.test/genContextLogTrail");
|
|
7
|
-
const getContextOpenAI_1 = require("../../.test/getContextOpenAI");
|
|
8
|
-
const stitcherCodeDiffImagine_1 = require("../../.test/stitchers/stitcherCodeDiffImagine");
|
|
9
|
-
const codeArtist_1 = require("../../.test/threads/codeArtist");
|
|
10
|
-
const director_1 = require("../../.test/threads/director");
|
|
11
|
-
const StitchStep_1 = require("../../domain/objects/StitchStep");
|
|
12
|
-
const Thread_1 = require("../../domain/objects/Thread");
|
|
13
|
-
const genContextStitchTrail_1 = require("../context/genContextStitchTrail");
|
|
14
|
-
const genStitchRoute_1 = require("./compose/genStitchRoute");
|
|
15
|
-
const enweaveOneRoute_1 = require("./enweaveOneRoute");
|
|
16
|
-
describe('enweaveOneRoute', () => {
|
|
17
|
-
const context = {
|
|
18
|
-
...(0, genContextStitchTrail_1.genContextStitchTrail)(),
|
|
19
|
-
...(0, genContextLogTrail_1.genContextLogTrail)(),
|
|
20
|
-
...(0, getContextOpenAI_1.getContextOpenAI)(),
|
|
21
|
-
};
|
|
22
|
-
(0, test_fns_1.given)('a route with compute stitchers (fast and no api keys required); same threads required for each stitcher', () => {
|
|
23
|
-
const stitcherGetTime = new StitchStep_1.StitchStepCompute({
|
|
24
|
-
slug: 'get-time',
|
|
25
|
-
readme: null,
|
|
26
|
-
form: 'COMPUTE',
|
|
27
|
-
stitchee: 'main',
|
|
28
|
-
invoke: () => ({ input: null, output: (0, uni_time_1.asUniDateTime)(new Date()) }),
|
|
29
|
-
});
|
|
30
|
-
const stitcherAddHours = new StitchStep_1.StitchStepCompute({
|
|
31
|
-
slug: 'add-hours',
|
|
32
|
-
readme: null,
|
|
33
|
-
form: 'COMPUTE',
|
|
34
|
-
stitchee: 'main',
|
|
35
|
-
invoke: ({ threads }) => {
|
|
36
|
-
const lastStitch = threads.main.stitches.slice(-1)[0] ??
|
|
37
|
-
helpful_errors_1.UnexpectedCodePathError.throw('no stitches found on main thread yet.', { threads });
|
|
38
|
-
return {
|
|
39
|
-
input: lastStitch.output,
|
|
40
|
-
output: (0, uni_time_1.addDuration)(uni_time_1.isUniDateTime.assure(lastStitch.output), {
|
|
41
|
-
hours: 1,
|
|
42
|
-
}),
|
|
43
|
-
};
|
|
44
|
-
},
|
|
45
|
-
});
|
|
46
|
-
const route = (0, genStitchRoute_1.genStitchRoute)({
|
|
47
|
-
slug: 'time:get:hour+',
|
|
48
|
-
readme: null,
|
|
49
|
-
sequence: [stitcherGetTime, stitcherAddHours],
|
|
50
|
-
});
|
|
51
|
-
(0, test_fns_1.when)('the wrong thread is given as an input', () => {
|
|
52
|
-
const threadAuthor = new Thread_1.Thread({
|
|
53
|
-
context: { role: 'author' },
|
|
54
|
-
stitches: [],
|
|
55
|
-
});
|
|
56
|
-
(0, test_fns_1.then)('there should be a compiletime error, when the input.threads doesnt have the desired thread', async () => {
|
|
57
|
-
// it also throws an error; but we care about the @ts-expect-error below, since compile time is most important
|
|
58
|
-
await (0, helpful_errors_1.getError)((0, enweaveOneRoute_1.enweaveOneRoute)(
|
|
59
|
-
// @ts-expect-error: 'author' does not exist in type 'Threads<"main">'.
|
|
60
|
-
{ stitcher: route, threads: { author: threadAuthor } }, context));
|
|
61
|
-
});
|
|
62
|
-
(0, test_fns_1.then)('there should be a compiletime error, when the input.threads does have the desired thread, but it was mislabeled', async () => {
|
|
63
|
-
await (0, enweaveOneRoute_1.enweaveOneRoute)(
|
|
64
|
-
// @ts-expect-error: Type '"author"' is not assignable to type '"main"'.
|
|
65
|
-
{ stitcher: route, threads: { main: threadAuthor } }, context);
|
|
66
|
-
});
|
|
67
|
-
});
|
|
68
|
-
(0, test_fns_1.when)('invoked with desired thread', () => {
|
|
69
|
-
const threadMain = new Thread_1.Thread({
|
|
70
|
-
context: { role: 'main' },
|
|
71
|
-
stitches: [],
|
|
72
|
-
});
|
|
73
|
-
(0, test_fns_1.then)('it should successfully enweave the full route', async () => {
|
|
74
|
-
const { stitch, threads } = await (0, enweaveOneRoute_1.enweaveOneRoute)({ stitcher: route, threads: { main: threadMain } }, context);
|
|
75
|
-
console.log(stitch.input);
|
|
76
|
-
console.log(stitch.output);
|
|
77
|
-
// stitch should look right
|
|
78
|
-
expect((0, uni_time_1.isUniDateTime)(stitch.output));
|
|
79
|
-
expect((0, uni_time_1.isUniDateTime)(stitch.input));
|
|
80
|
-
expect(stitch.output).not.toEqual(stitch.input);
|
|
81
|
-
// stitchee should be updated, too
|
|
82
|
-
expect(threads.main.stitches.length).toEqual(threadMain.stitches.length + 2);
|
|
83
|
-
});
|
|
84
|
-
});
|
|
85
|
-
});
|
|
86
|
-
(0, test_fns_1.given)('a route with imagine stitchers (closer to real world usecase)', () => {
|
|
87
|
-
const stitcherCodeFileRead = new StitchStep_1.StitchStepCompute({
|
|
88
|
-
slug: 'mock:read-stubout',
|
|
89
|
-
readme: null,
|
|
90
|
-
form: 'COMPUTE',
|
|
91
|
-
stitchee: 'artist',
|
|
92
|
-
invoke: () => {
|
|
93
|
-
// e.g., execute tooluse:file:read
|
|
94
|
-
return {
|
|
95
|
-
input: null,
|
|
96
|
-
output: `
|
|
97
|
-
/**
|
|
98
|
-
* .what = calls the open-meteo weather api
|
|
99
|
-
* .how =
|
|
100
|
-
* - uses procedural pattern
|
|
101
|
-
* - fails fast
|
|
102
|
-
*/
|
|
103
|
-
export const sdkOpenMeteo = {
|
|
104
|
-
getWeather: (input: {...}, context: VisualogicContext & AuthContextOpenMeteo) => {
|
|
105
|
-
...
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
`.trim(),
|
|
109
|
-
};
|
|
110
|
-
},
|
|
111
|
-
});
|
|
112
|
-
const stitcherCodeFileWrite = new StitchStep_1.StitchStepCompute({
|
|
113
|
-
slug: 'mock:write-fillout',
|
|
114
|
-
readme: null,
|
|
115
|
-
form: 'COMPUTE',
|
|
116
|
-
stitchee: 'artist',
|
|
117
|
-
invoke: ({ threads }) => {
|
|
118
|
-
// e.g., execute tooluse:file:write
|
|
119
|
-
return {
|
|
120
|
-
input: null,
|
|
121
|
-
output: {
|
|
122
|
-
path: '@src/...', // mock that we did so
|
|
123
|
-
content: threads.artist.stitches.slice(-1)[0]?.output ??
|
|
124
|
-
helpful_errors_1.UnexpectedCodePathError.throw('expected artist to have had a stitch by now'),
|
|
125
|
-
},
|
|
126
|
-
};
|
|
127
|
-
},
|
|
128
|
-
});
|
|
129
|
-
const route = (0, genStitchRoute_1.genStitchRoute)({
|
|
130
|
-
slug: 'code:propose',
|
|
131
|
-
readme: null,
|
|
132
|
-
sequence: [
|
|
133
|
-
stitcherCodeFileRead,
|
|
134
|
-
stitcherCodeDiffImagine_1.stitcherCodeDiffImagine,
|
|
135
|
-
stitcherCodeFileWrite,
|
|
136
|
-
],
|
|
137
|
-
});
|
|
138
|
-
(0, test_fns_1.when)('given the threads required', () => {
|
|
139
|
-
let threads;
|
|
140
|
-
beforeAll(async () => {
|
|
141
|
-
threads = {
|
|
142
|
-
artist: await (0, codeArtist_1.getExampleThreadCodeArtist)(),
|
|
143
|
-
director: director_1.exampleThreadDirector,
|
|
144
|
-
};
|
|
145
|
-
});
|
|
146
|
-
(0, test_fns_1.then)('it should successfully execute the stitches as a weave', async () => {
|
|
147
|
-
const output = await (0, enweaveOneRoute_1.enweaveOneRoute)({
|
|
148
|
-
stitcher: route,
|
|
149
|
-
threads,
|
|
150
|
-
}, context);
|
|
151
|
-
console.log(output);
|
|
152
|
-
// verify that it used conflict markers and wrote the full output
|
|
153
|
-
expect(output.stitch.output.content).toContain('<<<<<<< ORIGINAL'); // per the artist thread's context, it knows the tool of conflict-marker, that it should have used
|
|
154
|
-
expect(output.stitch.output.content).toContain('>>>>>>> MODIFIED');
|
|
155
|
-
});
|
|
156
|
-
});
|
|
157
|
-
});
|
|
158
|
-
});
|
|
159
|
-
//# sourceMappingURL=enweaveOneRoute.integration.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"enweaveOneRoute.integration.test.js","sourceRoot":"","sources":["../../../src/logic/weave/enweaveOneRoute.integration.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,258 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.deepReplaceShortUuidsWithLetters = exports.deepOmit = void 0;
|
|
4
|
-
const uni_time_1 = require("@ehmpathy/uni-time");
|
|
5
|
-
const helpful_errors_1 = require("helpful-errors");
|
|
6
|
-
const test_fns_1 = require("test-fns");
|
|
7
|
-
const uuid_fns_1 = require("uuid-fns");
|
|
8
|
-
const genContextLogTrail_1 = require("../../.test/genContextLogTrail");
|
|
9
|
-
const getContextOpenAI_1 = require("../../.test/getContextOpenAI");
|
|
10
|
-
const genStitcherCodeFileRead_1 = require("../../.test/stitchers/genStitcherCodeFileRead");
|
|
11
|
-
const genStitcherCodeFileWrite_1 = require("../../.test/stitchers/genStitcherCodeFileWrite");
|
|
12
|
-
const genStitcherCodeReviewImagine_1 = require("../../.test/stitchers/genStitcherCodeReviewImagine");
|
|
13
|
-
const stitcherCodeDiffImagine_1 = require("../../.test/stitchers/stitcherCodeDiffImagine");
|
|
14
|
-
const codeArtist_1 = require("../../.test/threads/codeArtist");
|
|
15
|
-
const codeCritic_1 = require("../../.test/threads/codeCritic");
|
|
16
|
-
const director_1 = require("../../.test/threads/director");
|
|
17
|
-
const StitchStep_1 = require("../../domain/objects/StitchStep");
|
|
18
|
-
const genContextStitchTrail_1 = require("../context/genContextStitchTrail");
|
|
19
|
-
const genThread_1 = require("../thread/genThread");
|
|
20
|
-
const asStitcher_1 = require("./compose/asStitcher");
|
|
21
|
-
const asStitcherFlat_1 = require("./compose/asStitcherFlat");
|
|
22
|
-
const genStitchCycle_1 = require("./compose/genStitchCycle");
|
|
23
|
-
const genStitchFanout_1 = require("./compose/genStitchFanout");
|
|
24
|
-
const genStitchRoute_1 = require("./compose/genStitchRoute");
|
|
25
|
-
const enweaveOneStitcher_1 = require("./enweaveOneStitcher");
|
|
26
|
-
jest.setTimeout((0, uni_time_1.toMilliseconds)({ minutes: 3 }));
|
|
27
|
-
describe('enweaveOneStitcher', () => {
|
|
28
|
-
const baseContext = {
|
|
29
|
-
...(0, genContextStitchTrail_1.genContextStitchTrail)(),
|
|
30
|
-
...(0, genContextLogTrail_1.genContextLogTrail)(),
|
|
31
|
-
};
|
|
32
|
-
const context = { ...baseContext, ...(0, getContextOpenAI_1.getContextOpenAI)() };
|
|
33
|
-
// takes a while; skip by default
|
|
34
|
-
test_fns_1.given.runIf(!process.env.CI)('a review loop that proposes, reviews, summarizes, and judges code improvement until blockers are gone or 3 attempts max', () => {
|
|
35
|
-
const stitcherCodeReviewConcluder = new StitchStep_1.StitchStepCompute({
|
|
36
|
-
slug: '[critic]<review:concluder>',
|
|
37
|
-
readme: null,
|
|
38
|
-
form: 'COMPUTE',
|
|
39
|
-
stitchee: 'critic',
|
|
40
|
-
invoke: ({ threads }) => {
|
|
41
|
-
const summary = threads.critic.peers
|
|
42
|
-
.map((peer) => peer.stitches.slice(-1)[0]?.output)
|
|
43
|
-
.filter(Boolean);
|
|
44
|
-
const blockers = summary.filter((x) => x.includes('blocker'));
|
|
45
|
-
return { input: summary, output: { blockers, summary } };
|
|
46
|
-
},
|
|
47
|
-
});
|
|
48
|
-
const stitcherCodeReviewFanout = (0, asStitcher_1.asStitcher)((0, genStitchFanout_1.genStitchFanout)({
|
|
49
|
-
slug: '[critic]<code:review>.<fanout>[[review]]',
|
|
50
|
-
readme: null,
|
|
51
|
-
parallels: [
|
|
52
|
-
(0, genStitcherCodeReviewImagine_1.genStitcherCodeReview)({ scope: 'technical', focus: 'blockers' }),
|
|
53
|
-
// genStitcherCodeReview({ scope: 'technical', focus: 'chances' }),
|
|
54
|
-
// genStitcherCodeReview({ scope: 'technical', focus: 'praises' }),
|
|
55
|
-
(0, genStitcherCodeReviewImagine_1.genStitcherCodeReview)({ scope: 'functional', focus: 'blockers' }),
|
|
56
|
-
// genStitcherCodeReview({ scope: 'functional', focus: 'chances' }),
|
|
57
|
-
// genStitcherCodeReview({ scope: 'functional', focus: 'praises' }),
|
|
58
|
-
],
|
|
59
|
-
concluder: stitcherCodeReviewConcluder,
|
|
60
|
-
}));
|
|
61
|
-
const directorSummarize = new StitchStep_1.StitchStepCompute({
|
|
62
|
-
slug: '[director]<summarize>',
|
|
63
|
-
form: 'COMPUTE',
|
|
64
|
-
stitchee: 'director',
|
|
65
|
-
readme: 'turn critic summary into a director directive',
|
|
66
|
-
invoke: ({ threads }) => {
|
|
67
|
-
const last = threads.critic.stitches.slice(-1)[0]?.output;
|
|
68
|
-
return {
|
|
69
|
-
input: last,
|
|
70
|
-
output: {
|
|
71
|
-
directive: `resolve blockers, blockers: ${JSON.stringify(last?.blockers, null, 2)}`,
|
|
72
|
-
blockers: last?.blockers,
|
|
73
|
-
},
|
|
74
|
-
};
|
|
75
|
-
},
|
|
76
|
-
});
|
|
77
|
-
const artistCodeProposeRoute = (0, asStitcher_1.asStitcher)((0, genStitchRoute_1.genStitchRoute)({
|
|
78
|
-
slug: '[artist]<code:propose>',
|
|
79
|
-
readme: 'imagine diff, then write to file',
|
|
80
|
-
sequence: [
|
|
81
|
-
stitcherCodeDiffImagine_1.stitcherCodeDiffImagine,
|
|
82
|
-
(0, genStitcherCodeFileWrite_1.genStitcherCodeFileWrite)({
|
|
83
|
-
stitchee: 'artist',
|
|
84
|
-
}),
|
|
85
|
-
],
|
|
86
|
-
}));
|
|
87
|
-
const criticCodeReviewRoute = (0, asStitcher_1.asStitcher)((0, genStitchRoute_1.genStitchRoute)({
|
|
88
|
-
slug: '[critic]<code:review>',
|
|
89
|
-
readme: 'review the code from multiple perspectives',
|
|
90
|
-
sequence: [
|
|
91
|
-
(0, genStitcherCodeFileRead_1.genStitcherCodeFileRead)({
|
|
92
|
-
stitchee: 'critic',
|
|
93
|
-
output: ({ threads }) => threads.artist?.stitches.slice(-1)[0]?.output ??
|
|
94
|
-
helpful_errors_1.UnexpectedCodePathError.throw('expected to find file write output stitch', { threads }),
|
|
95
|
-
}),
|
|
96
|
-
stitcherCodeReviewFanout,
|
|
97
|
-
],
|
|
98
|
-
}));
|
|
99
|
-
const codeIterateRoute = (0, asStitcherFlat_1.asStitcherFlat)((0, genStitchRoute_1.genStitchRoute)({
|
|
100
|
-
slug: '[code:iterate]',
|
|
101
|
-
readme: 'one pass of propose + review + summarize',
|
|
102
|
-
sequence: [
|
|
103
|
-
artistCodeProposeRoute,
|
|
104
|
-
criticCodeReviewRoute,
|
|
105
|
-
directorSummarize,
|
|
106
|
-
],
|
|
107
|
-
}));
|
|
108
|
-
const judgeDeciderNextStep = new StitchStep_1.StitchStepCompute({
|
|
109
|
-
slug: '[judge]<decide:release?>',
|
|
110
|
-
form: 'COMPUTE',
|
|
111
|
-
stitchee: 'judge',
|
|
112
|
-
readme: 'release if more than 3 reviews',
|
|
113
|
-
invoke: ({ threads }) => {
|
|
114
|
-
const choice = threads.critic.stitches.length >= 3 ? 'release' : 'repeat';
|
|
115
|
-
return {
|
|
116
|
-
input: { stitches: threads.critic.stitches.length },
|
|
117
|
-
output: { choice },
|
|
118
|
-
};
|
|
119
|
-
},
|
|
120
|
-
});
|
|
121
|
-
const mechanicCodeDiffIterateUntilRelease = (0, asStitcher_1.asStitcher)((0, genStitchCycle_1.genStitchCycle)({
|
|
122
|
-
slug: '[mechanic]<code:iterate-until-release>',
|
|
123
|
-
readme: 'iterate until no blockers or max 3 tries',
|
|
124
|
-
repeatee: codeIterateRoute,
|
|
125
|
-
decider: judgeDeciderNextStep,
|
|
126
|
-
}));
|
|
127
|
-
const stitcherRestitchLatestArtistOutput = new StitchStep_1.StitchStepCompute({
|
|
128
|
-
slug: '[artist]<restitch:latest>',
|
|
129
|
-
readme: 'Restitch artists latest output for final record',
|
|
130
|
-
form: 'COMPUTE',
|
|
131
|
-
stitchee: 'artist',
|
|
132
|
-
invoke: ({ threads }) => {
|
|
133
|
-
const latest = threads.artist.stitches.slice(-1)[0];
|
|
134
|
-
if (!latest?.output || typeof latest.output !== 'object')
|
|
135
|
-
throw new Error('No valid artist output to restitch');
|
|
136
|
-
return latest;
|
|
137
|
-
},
|
|
138
|
-
});
|
|
139
|
-
const rootRouteCodeDiff = (0, genStitchRoute_1.genStitchRoute)({
|
|
140
|
-
slug: '[mechanic]<code:diff>',
|
|
141
|
-
readme: 'read initial file, then iterate against directive until no blockers or 3 tries',
|
|
142
|
-
sequence: [
|
|
143
|
-
(0, genStitcherCodeFileRead_1.genStitcherCodeFileRead)({
|
|
144
|
-
stitchee: 'artist',
|
|
145
|
-
output: {
|
|
146
|
-
path: '__path__',
|
|
147
|
-
content: `
|
|
148
|
-
/**
|
|
149
|
-
* .what = calls the open-meteo weather api
|
|
150
|
-
* .how =
|
|
151
|
-
* - uses procedural pattern
|
|
152
|
-
* - fails fast
|
|
153
|
-
*/
|
|
154
|
-
export const sdkOpenMeteo = {
|
|
155
|
-
getWeather: (input: {...}, context: VisualogicContext & AuthContextOpenMeteo) => {
|
|
156
|
-
...
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
`.trim(),
|
|
160
|
-
},
|
|
161
|
-
}),
|
|
162
|
-
mechanicCodeDiffIterateUntilRelease,
|
|
163
|
-
stitcherRestitchLatestArtistOutput,
|
|
164
|
-
],
|
|
165
|
-
});
|
|
166
|
-
console.log(JSON.stringify(rootRouteCodeDiff, null, 2));
|
|
167
|
-
(0, test_fns_1.when)('executing the full review loop with realistic threads for artist, critic, director, and judge', () => {
|
|
168
|
-
let threads;
|
|
169
|
-
beforeAll(async () => {
|
|
170
|
-
threads = {
|
|
171
|
-
artist: await (0, codeArtist_1.getExampleThreadCodeArtist)(),
|
|
172
|
-
critic: await (0, codeCritic_1.getExampleThreadCodeCritic)(),
|
|
173
|
-
director: director_1.exampleThreadDirector.clone({
|
|
174
|
-
stitches: [
|
|
175
|
-
{
|
|
176
|
-
uuid: (0, uuid_fns_1.getUuid)(),
|
|
177
|
-
createdAt: (0, uni_time_1.asUniDateTime)(new Date()),
|
|
178
|
-
input: null,
|
|
179
|
-
output: { directive: 'fillout the stubout' },
|
|
180
|
-
stitcher: null,
|
|
181
|
-
trail: null,
|
|
182
|
-
}, // start with this directive
|
|
183
|
-
],
|
|
184
|
-
}),
|
|
185
|
-
judge: (0, genThread_1.genThread)({ role: 'judge' }),
|
|
186
|
-
};
|
|
187
|
-
});
|
|
188
|
-
(0, test_fns_1.then)('it should have a readable route plan declared', () => {
|
|
189
|
-
// expect(rootRouteCodeDiff).toMatchSnapshot();
|
|
190
|
-
expect(JSON.stringify(rootRouteCodeDiff, null, 2)).toMatchSnapshot();
|
|
191
|
-
});
|
|
192
|
-
(0, test_fns_1.then)('it should exit after 3 cycles if blockers are always returned', async () => {
|
|
193
|
-
const output = await (0, enweaveOneStitcher_1.enweaveOneStitcher)({ stitcher: rootRouteCodeDiff, threads }, context);
|
|
194
|
-
expect(output.threads.artist.stitches.length).toBeGreaterThan(0);
|
|
195
|
-
expect(output.threads.critic.stitches.length).toBeGreaterThan(0);
|
|
196
|
-
expect(output.threads.judge.stitches.length).toBeGreaterThan(0);
|
|
197
|
-
expect(JSON.stringify(deepReplaceShortUuidsWithLetters(deepOmit(output, [
|
|
198
|
-
'occurredAt',
|
|
199
|
-
'createdAt',
|
|
200
|
-
'input',
|
|
201
|
-
'output',
|
|
202
|
-
'tools',
|
|
203
|
-
'facts',
|
|
204
|
-
'uuid',
|
|
205
|
-
'stitchUuid',
|
|
206
|
-
])), null, 2)).toMatchSnapshot();
|
|
207
|
-
});
|
|
208
|
-
});
|
|
209
|
-
});
|
|
210
|
-
});
|
|
211
|
-
function deepOmit(obj, keys) {
|
|
212
|
-
if (Array.isArray(obj)) {
|
|
213
|
-
return obj.map((item) => deepOmit(item, keys));
|
|
214
|
-
}
|
|
215
|
-
if (obj !== null && typeof obj === 'object') {
|
|
216
|
-
const raw = { ...obj };
|
|
217
|
-
for (const key of keys) {
|
|
218
|
-
delete raw[key];
|
|
219
|
-
}
|
|
220
|
-
return Object.fromEntries(Object.entries(raw).map(([k, v]) => [k, deepOmit(v, keys)]));
|
|
221
|
-
}
|
|
222
|
-
return obj;
|
|
223
|
-
}
|
|
224
|
-
exports.deepOmit = deepOmit;
|
|
225
|
-
const shortUuidRegex = /\(([0-9a-f]{7})\)/gi;
|
|
226
|
-
function getLetterLabel(index) {
|
|
227
|
-
let label = '';
|
|
228
|
-
while (index >= 0) {
|
|
229
|
-
label = String.fromCharCode((index % 26) + 65) + label;
|
|
230
|
-
index = Math.floor(index / 26) - 1;
|
|
231
|
-
}
|
|
232
|
-
return label;
|
|
233
|
-
}
|
|
234
|
-
function deepReplaceShortUuidsWithLetters(obj) {
|
|
235
|
-
const seen = new Map();
|
|
236
|
-
let index = 0;
|
|
237
|
-
const replace = (value) => {
|
|
238
|
-
if (typeof value === 'string') {
|
|
239
|
-
return value.replace(shortUuidRegex, (_, shortId) => {
|
|
240
|
-
const key = shortId.toLowerCase();
|
|
241
|
-
if (!seen.has(key)) {
|
|
242
|
-
seen.set(key, getLetterLabel(index++));
|
|
243
|
-
}
|
|
244
|
-
return `(${seen.get(key)})`;
|
|
245
|
-
});
|
|
246
|
-
}
|
|
247
|
-
if (Array.isArray(value)) {
|
|
248
|
-
return value.map(replace);
|
|
249
|
-
}
|
|
250
|
-
if (value !== null && typeof value === 'object') {
|
|
251
|
-
return Object.fromEntries(Object.entries(value).map(([k, v]) => [k, replace(v)]));
|
|
252
|
-
}
|
|
253
|
-
return value;
|
|
254
|
-
};
|
|
255
|
-
return replace(obj);
|
|
256
|
-
}
|
|
257
|
-
exports.deepReplaceShortUuidsWithLetters = deepReplaceShortUuidsWithLetters;
|
|
258
|
-
//# sourceMappingURL=enweaveOneStitcher.integration.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"enweaveOneStitcher.integration.test.js","sourceRoot":"","sources":["../../../src/logic/weave/enweaveOneStitcher.integration.test.ts"],"names":[],"mappings":"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"}
|