@slopus/beer 0.1.1
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/README.md +24 -0
- package/bin/beer.js +2 -0
- package/dist/apps/bootstrap.d.ts +5 -0
- package/dist/apps/bootstrap.d.ts.map +1 -0
- package/dist/apps/bootstrap.js +170 -0
- package/dist/apps/bootstrap.js.map +1 -0
- package/dist/commands/bootstrapCommand.d.ts +6 -0
- package/dist/commands/bootstrapCommand.d.ts.map +1 -0
- package/dist/commands/bootstrapCommand.js +16 -0
- package/dist/commands/bootstrapCommand.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +17 -0
- package/dist/main.js.map +1 -0
- package/dist/modules/ai/aiOutputExtract.d.ts +6 -0
- package/dist/modules/ai/aiOutputExtract.d.ts.map +1 -0
- package/dist/modules/ai/aiOutputExtract.js +16 -0
- package/dist/modules/ai/aiOutputExtract.js.map +1 -0
- package/dist/modules/ai/aiOutputExtract.spec.d.ts +2 -0
- package/dist/modules/ai/aiOutputExtract.spec.d.ts.map +1 -0
- package/dist/modules/ai/aiOutputExtract.spec.js +25 -0
- package/dist/modules/ai/aiOutputExtract.spec.js.map +1 -0
- package/dist/modules/ai/aiReadmeGenerate.d.ts +18 -0
- package/dist/modules/ai/aiReadmeGenerate.d.ts.map +1 -0
- package/dist/modules/ai/aiReadmeGenerate.js +23 -0
- package/dist/modules/ai/aiReadmeGenerate.js.map +1 -0
- package/dist/modules/ai/aiReadmeGenerate.spec.d.ts +2 -0
- package/dist/modules/ai/aiReadmeGenerate.spec.d.ts.map +1 -0
- package/dist/modules/ai/aiReadmeGenerate.spec.js +27 -0
- package/dist/modules/ai/aiReadmeGenerate.spec.js.map +1 -0
- package/dist/modules/ai/generate.d.ts +28 -0
- package/dist/modules/ai/generate.d.ts.map +1 -0
- package/dist/modules/ai/generate.js +132 -0
- package/dist/modules/ai/generate.js.map +1 -0
- package/dist/modules/ai/generate.spec.d.ts +2 -0
- package/dist/modules/ai/generate.spec.d.ts.map +1 -0
- package/dist/modules/ai/generate.spec.js +53 -0
- package/dist/modules/ai/generate.spec.js.map +1 -0
- package/dist/modules/ai/generateFile.d.ts +14 -0
- package/dist/modules/ai/generateFile.d.ts.map +1 -0
- package/dist/modules/ai/generateFile.js +56 -0
- package/dist/modules/ai/generateFile.js.map +1 -0
- package/dist/modules/ai/generateFile.spec.d.ts +2 -0
- package/dist/modules/ai/generateFile.spec.d.ts.map +1 -0
- package/dist/modules/ai/generateFile.spec.js +60 -0
- package/dist/modules/ai/generateFile.spec.js.map +1 -0
- package/dist/modules/ai/generateText.d.ts +9 -0
- package/dist/modules/ai/generateText.d.ts.map +1 -0
- package/dist/modules/ai/generateText.js +12 -0
- package/dist/modules/ai/generateText.js.map +1 -0
- package/dist/modules/ai/generateText.spec.d.ts +2 -0
- package/dist/modules/ai/generateText.spec.d.ts.map +1 -0
- package/dist/modules/ai/generateText.spec.js +28 -0
- package/dist/modules/ai/generateText.spec.js.map +1 -0
- package/dist/modules/ai/providerGenerate.d.ts +29 -0
- package/dist/modules/ai/providerGenerate.d.ts.map +1 -0
- package/dist/modules/ai/providerGenerate.js +144 -0
- package/dist/modules/ai/providerGenerate.js.map +1 -0
- package/dist/modules/ai/providerGenerate.spec.d.ts +2 -0
- package/dist/modules/ai/providerGenerate.spec.d.ts.map +1 -0
- package/dist/modules/ai/providerGenerate.spec.js +85 -0
- package/dist/modules/ai/providerGenerate.spec.js.map +1 -0
- package/dist/modules/ai/providerGenerate.unit.spec.d.ts +2 -0
- package/dist/modules/ai/providerGenerate.unit.spec.d.ts.map +1 -0
- package/dist/modules/ai/providerGenerate.unit.spec.js +49 -0
- package/dist/modules/ai/providerGenerate.unit.spec.js.map +1 -0
- package/dist/modules/beer/beerDevFolderResolve.d.ts +5 -0
- package/dist/modules/beer/beerDevFolderResolve.d.ts.map +1 -0
- package/dist/modules/beer/beerDevFolderResolve.js +9 -0
- package/dist/modules/beer/beerDevFolderResolve.js.map +1 -0
- package/dist/modules/beer/beerDevFolderResolve.spec.d.ts +2 -0
- package/dist/modules/beer/beerDevFolderResolve.spec.d.ts.map +1 -0
- package/dist/modules/beer/beerDevFolderResolve.spec.js +10 -0
- package/dist/modules/beer/beerDevFolderResolve.spec.js.map +1 -0
- package/dist/modules/beer/beerOriginalPathResolve.d.ts +5 -0
- package/dist/modules/beer/beerOriginalPathResolve.d.ts.map +1 -0
- package/dist/modules/beer/beerOriginalPathResolve.js +8 -0
- package/dist/modules/beer/beerOriginalPathResolve.js.map +1 -0
- package/dist/modules/beer/beerOriginalPathResolve.spec.d.ts +2 -0
- package/dist/modules/beer/beerOriginalPathResolve.spec.d.ts.map +1 -0
- package/dist/modules/beer/beerOriginalPathResolve.spec.js +10 -0
- package/dist/modules/beer/beerOriginalPathResolve.spec.js.map +1 -0
- package/dist/modules/beer/beerSettingsPathResolve.d.ts +5 -0
- package/dist/modules/beer/beerSettingsPathResolve.d.ts.map +1 -0
- package/dist/modules/beer/beerSettingsPathResolve.js +9 -0
- package/dist/modules/beer/beerSettingsPathResolve.js.map +1 -0
- package/dist/modules/beer/beerSettingsPathResolve.spec.d.ts +2 -0
- package/dist/modules/beer/beerSettingsPathResolve.spec.d.ts.map +1 -0
- package/dist/modules/beer/beerSettingsPathResolve.spec.js +10 -0
- package/dist/modules/beer/beerSettingsPathResolve.spec.js.map +1 -0
- package/dist/modules/beer/beerSettingsRead.d.ts +6 -0
- package/dist/modules/beer/beerSettingsRead.d.ts.map +1 -0
- package/dist/modules/beer/beerSettingsRead.js +28 -0
- package/dist/modules/beer/beerSettingsRead.js.map +1 -0
- package/dist/modules/beer/beerSettingsTypes.d.ts +12 -0
- package/dist/modules/beer/beerSettingsTypes.d.ts.map +1 -0
- package/dist/modules/beer/beerSettingsTypes.js +2 -0
- package/dist/modules/beer/beerSettingsTypes.js.map +1 -0
- package/dist/modules/beer/beerSettingsWrite.d.ts +6 -0
- package/dist/modules/beer/beerSettingsWrite.d.ts.map +1 -0
- package/dist/modules/beer/beerSettingsWrite.js +10 -0
- package/dist/modules/beer/beerSettingsWrite.js.map +1 -0
- package/dist/modules/context/contextGet.d.ts +7 -0
- package/dist/modules/context/contextGet.d.ts.map +1 -0
- package/dist/modules/context/contextGet.js +12 -0
- package/dist/modules/context/contextGet.js.map +1 -0
- package/dist/modules/context/contextGetOrInitialize.d.ts +7 -0
- package/dist/modules/context/contextGetOrInitialize.d.ts.map +1 -0
- package/dist/modules/context/contextGetOrInitialize.js +12 -0
- package/dist/modules/context/contextGetOrInitialize.js.map +1 -0
- package/dist/modules/context/contextInitialize.d.ts +7 -0
- package/dist/modules/context/contextInitialize.d.ts.map +1 -0
- package/dist/modules/context/contextInitialize.js +25 -0
- package/dist/modules/context/contextInitialize.js.map +1 -0
- package/dist/modules/context/contextInitialize.spec.d.ts +2 -0
- package/dist/modules/context/contextInitialize.spec.d.ts.map +1 -0
- package/dist/modules/context/contextInitialize.spec.js +77 -0
- package/dist/modules/context/contextInitialize.spec.js.map +1 -0
- package/dist/modules/context/contextTypes.d.ts +21 -0
- package/dist/modules/context/contextTypes.d.ts.map +1 -0
- package/dist/modules/context/contextTypes.js +2 -0
- package/dist/modules/context/contextTypes.js.map +1 -0
- package/dist/modules/git/gitPush.d.ts +6 -0
- package/dist/modules/git/gitPush.d.ts.map +1 -0
- package/dist/modules/git/gitPush.js +9 -0
- package/dist/modules/git/gitPush.js.map +1 -0
- package/dist/modules/git/gitRemoteEnsure.d.ts +6 -0
- package/dist/modules/git/gitRemoteEnsure.d.ts.map +1 -0
- package/dist/modules/git/gitRemoteEnsure.js +20 -0
- package/dist/modules/git/gitRemoteEnsure.js.map +1 -0
- package/dist/modules/git/gitRepoCheckout.d.ts +6 -0
- package/dist/modules/git/gitRepoCheckout.d.ts.map +1 -0
- package/dist/modules/git/gitRepoCheckout.js +15 -0
- package/dist/modules/git/gitRepoCheckout.js.map +1 -0
- package/dist/modules/git/gitRepoCheckout.spec.d.ts +2 -0
- package/dist/modules/git/gitRepoCheckout.spec.d.ts.map +1 -0
- package/dist/modules/git/gitRepoCheckout.spec.js +33 -0
- package/dist/modules/git/gitRepoCheckout.spec.js.map +1 -0
- package/dist/modules/git/gitStageAndCommit.d.ts +6 -0
- package/dist/modules/git/gitStageAndCommit.d.ts.map +1 -0
- package/dist/modules/git/gitStageAndCommit.js +18 -0
- package/dist/modules/git/gitStageAndCommit.js.map +1 -0
- package/dist/modules/github/githubCliEnsure.d.ts +6 -0
- package/dist/modules/github/githubCliEnsure.d.ts.map +1 -0
- package/dist/modules/github/githubCliEnsure.js +13 -0
- package/dist/modules/github/githubCliEnsure.js.map +1 -0
- package/dist/modules/github/githubOwnerChoicesGet.d.ts +5 -0
- package/dist/modules/github/githubOwnerChoicesGet.d.ts.map +1 -0
- package/dist/modules/github/githubOwnerChoicesGet.js +20 -0
- package/dist/modules/github/githubOwnerChoicesGet.js.map +1 -0
- package/dist/modules/github/githubRepoCreate.d.ts +6 -0
- package/dist/modules/github/githubRepoCreate.d.ts.map +1 -0
- package/dist/modules/github/githubRepoCreate.js +17 -0
- package/dist/modules/github/githubRepoCreate.js.map +1 -0
- package/dist/modules/github/githubRepoExists.d.ts +5 -0
- package/dist/modules/github/githubRepoExists.d.ts.map +1 -0
- package/dist/modules/github/githubRepoExists.js +9 -0
- package/dist/modules/github/githubRepoExists.js.map +1 -0
- package/dist/modules/github/githubRepoNameResolve.d.ts +17 -0
- package/dist/modules/github/githubRepoNameResolve.d.ts.map +1 -0
- package/dist/modules/github/githubRepoNameResolve.js +34 -0
- package/dist/modules/github/githubRepoNameResolve.js.map +1 -0
- package/dist/modules/github/githubRepoNameResolve.spec.d.ts +2 -0
- package/dist/modules/github/githubRepoNameResolve.spec.d.ts.map +1 -0
- package/dist/modules/github/githubRepoNameResolve.spec.js +37 -0
- package/dist/modules/github/githubRepoNameResolve.spec.js.map +1 -0
- package/dist/modules/github/githubRepoParse.d.ts +7 -0
- package/dist/modules/github/githubRepoParse.d.ts.map +1 -0
- package/dist/modules/github/githubRepoParse.js +35 -0
- package/dist/modules/github/githubRepoParse.js.map +1 -0
- package/dist/modules/github/githubRepoParse.spec.d.ts +2 -0
- package/dist/modules/github/githubRepoParse.spec.d.ts.map +1 -0
- package/dist/modules/github/githubRepoParse.spec.js +17 -0
- package/dist/modules/github/githubRepoParse.spec.js.map +1 -0
- package/dist/modules/github/githubRepoStatusGet.d.ts +7 -0
- package/dist/modules/github/githubRepoStatusGet.d.ts.map +1 -0
- package/dist/modules/github/githubRepoStatusGet.js +21 -0
- package/dist/modules/github/githubRepoStatusGet.js.map +1 -0
- package/dist/modules/github/githubRepoUrlBuild.d.ts +5 -0
- package/dist/modules/github/githubRepoUrlBuild.d.ts.map +1 -0
- package/dist/modules/github/githubRepoUrlBuild.js +7 -0
- package/dist/modules/github/githubRepoUrlBuild.js.map +1 -0
- package/dist/modules/github/githubTypes.d.ts +8 -0
- package/dist/modules/github/githubTypes.d.ts.map +1 -0
- package/dist/modules/github/githubTypes.js +2 -0
- package/dist/modules/github/githubTypes.js.map +1 -0
- package/dist/modules/github/githubViewerGet.d.ts +5 -0
- package/dist/modules/github/githubViewerGet.d.ts.map +1 -0
- package/dist/modules/github/githubViewerGet.js +14 -0
- package/dist/modules/github/githubViewerGet.js.map +1 -0
- package/dist/modules/prompt/promptConfirm.d.ts +6 -0
- package/dist/modules/prompt/promptConfirm.d.ts.map +1 -0
- package/dist/modules/prompt/promptConfirm.js +23 -0
- package/dist/modules/prompt/promptConfirm.js.map +1 -0
- package/dist/modules/prompt/promptInput.d.ts +6 -0
- package/dist/modules/prompt/promptInput.d.ts.map +1 -0
- package/dist/modules/prompt/promptInput.js +14 -0
- package/dist/modules/prompt/promptInput.js.map +1 -0
- package/dist/modules/providers/providerDetect.d.ts +6 -0
- package/dist/modules/providers/providerDetect.d.ts.map +1 -0
- package/dist/modules/providers/providerDetect.js +43 -0
- package/dist/modules/providers/providerDetect.js.map +1 -0
- package/dist/modules/providers/providerDetect.spec.d.ts +2 -0
- package/dist/modules/providers/providerDetect.spec.d.ts.map +1 -0
- package/dist/modules/providers/providerDetect.spec.js +76 -0
- package/dist/modules/providers/providerDetect.spec.js.map +1 -0
- package/dist/modules/providers/providerModelSelect.d.ts +12 -0
- package/dist/modules/providers/providerModelSelect.d.ts.map +1 -0
- package/dist/modules/providers/providerModelSelect.js +134 -0
- package/dist/modules/providers/providerModelSelect.js.map +1 -0
- package/dist/modules/providers/providerModelSelect.spec.d.ts +2 -0
- package/dist/modules/providers/providerModelSelect.spec.d.ts.map +1 -0
- package/dist/modules/providers/providerModelSelect.spec.js +68 -0
- package/dist/modules/providers/providerModelSelect.spec.js.map +1 -0
- package/dist/modules/providers/providerModelsGet.d.ts +7 -0
- package/dist/modules/providers/providerModelsGet.d.ts.map +1 -0
- package/dist/modules/providers/providerModelsGet.js +100 -0
- package/dist/modules/providers/providerModelsGet.js.map +1 -0
- package/dist/modules/providers/providerModelsGet.spec.d.ts +2 -0
- package/dist/modules/providers/providerModelsGet.spec.d.ts.map +1 -0
- package/dist/modules/providers/providerModelsGet.spec.js +88 -0
- package/dist/modules/providers/providerModelsGet.spec.js.map +1 -0
- package/dist/modules/providers/providerPriorityList.d.ts +6 -0
- package/dist/modules/providers/providerPriorityList.d.ts.map +1 -0
- package/dist/modules/providers/providerPriorityList.js +16 -0
- package/dist/modules/providers/providerPriorityList.js.map +1 -0
- package/dist/modules/providers/providerPriorityList.spec.d.ts +2 -0
- package/dist/modules/providers/providerPriorityList.spec.d.ts.map +1 -0
- package/dist/modules/providers/providerPriorityList.spec.js +19 -0
- package/dist/modules/providers/providerPriorityList.spec.js.map +1 -0
- package/dist/modules/providers/providerTypes.d.ts +21 -0
- package/dist/modules/providers/providerTypes.d.ts.map +1 -0
- package/dist/modules/providers/providerTypes.js +2 -0
- package/dist/modules/providers/providerTypes.js.map +1 -0
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.d.ts +17 -0
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.d.ts.map +1 -0
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.js +88 -0
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.js.map +1 -0
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.spec.d.ts +2 -0
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.spec.d.ts.map +1 -0
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.spec.js +70 -0
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.spec.js.map +1 -0
- package/dist/modules/sandbox/sandboxInferenceGet.d.ts +12 -0
- package/dist/modules/sandbox/sandboxInferenceGet.d.ts.map +1 -0
- package/dist/modules/sandbox/sandboxInferenceGet.js +18 -0
- package/dist/modules/sandbox/sandboxInferenceGet.js.map +1 -0
- package/dist/modules/sandbox/sandboxInferenceGet.spec.d.ts +2 -0
- package/dist/modules/sandbox/sandboxInferenceGet.spec.d.ts.map +1 -0
- package/dist/modules/sandbox/sandboxInferenceGet.spec.js +65 -0
- package/dist/modules/sandbox/sandboxInferenceGet.spec.js.map +1 -0
- package/dist/modules/sandbox/sandboxInferenceTypes.d.ts +7 -0
- package/dist/modules/sandbox/sandboxInferenceTypes.d.ts.map +1 -0
- package/dist/modules/sandbox/sandboxInferenceTypes.js +2 -0
- package/dist/modules/sandbox/sandboxInferenceTypes.js.map +1 -0
- package/dist/modules/sandbox/sandboxTypes.d.ts +4 -0
- package/dist/modules/sandbox/sandboxTypes.d.ts.map +1 -0
- package/dist/modules/sandbox/sandboxTypes.js +2 -0
- package/dist/modules/sandbox/sandboxTypes.js.map +1 -0
- package/dist/modules/util/commandRun.d.ts +22 -0
- package/dist/modules/util/commandRun.d.ts.map +1 -0
- package/dist/modules/util/commandRun.js +112 -0
- package/dist/modules/util/commandRun.js.map +1 -0
- package/dist/modules/util/commandRun.spec.d.ts +2 -0
- package/dist/modules/util/commandRun.spec.d.ts.map +1 -0
- package/dist/modules/util/commandRun.spec.js +43 -0
- package/dist/modules/util/commandRun.spec.js.map +1 -0
- package/dist/modules/util/pathResolveFromInitCwd.d.ts +6 -0
- package/dist/modules/util/pathResolveFromInitCwd.d.ts.map +1 -0
- package/dist/modules/util/pathResolveFromInitCwd.js +10 -0
- package/dist/modules/util/pathResolveFromInitCwd.js.map +1 -0
- package/dist/release/releaseRun.d.ts +6 -0
- package/dist/release/releaseRun.d.ts.map +1 -0
- package/dist/release/releaseRun.js +153 -0
- package/dist/release/releaseRun.js.map +1 -0
- package/dist/release/releaseVersionIncrement.d.ts +7 -0
- package/dist/release/releaseVersionIncrement.d.ts.map +1 -0
- package/dist/release/releaseVersionIncrement.js +23 -0
- package/dist/release/releaseVersionIncrement.js.map +1 -0
- package/dist/release/releaseVersionIncrement.spec.d.ts +2 -0
- package/dist/release/releaseVersionIncrement.spec.d.ts.map +1 -0
- package/dist/release/releaseVersionIncrement.spec.js +20 -0
- package/dist/release/releaseVersionIncrement.spec.js.map +1 -0
- package/dist/release/releaseVersionPrompt.d.ts +6 -0
- package/dist/release/releaseVersionPrompt.d.ts.map +1 -0
- package/dist/release/releaseVersionPrompt.js +55 -0
- package/dist/release/releaseVersionPrompt.js.map +1 -0
- package/dist/text/all.txt +85 -0
- package/dist/text/text.d.ts +7 -0
- package/dist/text/text.d.ts.map +1 -0
- package/dist/text/text.js +34 -0
- package/dist/text/text.js.map +1 -0
- package/dist/types.d.ts +6 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/workflows/steps/generateCommitMessage.d.ts +13 -0
- package/dist/workflows/steps/generateCommitMessage.d.ts.map +1 -0
- package/dist/workflows/steps/generateCommitMessage.js +25 -0
- package/dist/workflows/steps/generateCommitMessage.js.map +1 -0
- package/dist/workflows/steps/generateCommitMessage.spec.d.ts +2 -0
- package/dist/workflows/steps/generateCommitMessage.spec.d.ts.map +1 -0
- package/dist/workflows/steps/generateCommitMessage.spec.js +28 -0
- package/dist/workflows/steps/generateCommitMessage.spec.js.map +1 -0
- package/package.json +38 -0
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { beforeEach, describe, expect, it, vi } from "vitest";
|
|
2
|
+
const commandRunMock = vi.hoisted(() => vi.fn());
|
|
3
|
+
vi.mock("@/modules/util/commandRun.js", () => ({
|
|
4
|
+
commandRun: commandRunMock
|
|
5
|
+
}));
|
|
6
|
+
import { providerGenerate } from "@/modules/ai/providerGenerate.js";
|
|
7
|
+
describe("providerGenerate", () => {
|
|
8
|
+
beforeEach(() => {
|
|
9
|
+
commandRunMock.mockReset();
|
|
10
|
+
});
|
|
11
|
+
it("fails text mode when pi json output has no assistant message", async () => {
|
|
12
|
+
commandRunMock.mockResolvedValue({
|
|
13
|
+
exitCode: 0,
|
|
14
|
+
stdout: "{\"type\":\"session\"}\n",
|
|
15
|
+
stderr: ""
|
|
16
|
+
});
|
|
17
|
+
const result = await providerGenerate({
|
|
18
|
+
providerId: "pi",
|
|
19
|
+
command: "pi",
|
|
20
|
+
prompt: "hello",
|
|
21
|
+
sandbox: { wrapCommand: async (command) => command }
|
|
22
|
+
});
|
|
23
|
+
expect(commandRunMock).toHaveBeenCalledWith("pi", ["--mode", "json", "--print", "--no-session", "hello"], expect.objectContaining({ allowFailure: true, timeoutMs: 90_000 }));
|
|
24
|
+
expect(result).toEqual({
|
|
25
|
+
output: null,
|
|
26
|
+
failure: {
|
|
27
|
+
providerId: "pi",
|
|
28
|
+
exitCode: 1,
|
|
29
|
+
stderr: "Provider returned no JSON assistant output."
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
it("allows empty assistant text in file mode", async () => {
|
|
34
|
+
commandRunMock.mockResolvedValue({
|
|
35
|
+
exitCode: 0,
|
|
36
|
+
stdout: "{\"type\":\"session\"}\n",
|
|
37
|
+
stderr: ""
|
|
38
|
+
});
|
|
39
|
+
const result = await providerGenerate({
|
|
40
|
+
providerId: "pi",
|
|
41
|
+
command: "pi",
|
|
42
|
+
prompt: "write file",
|
|
43
|
+
sandbox: { wrapCommand: async (command) => command },
|
|
44
|
+
requireOutputTags: false
|
|
45
|
+
});
|
|
46
|
+
expect(result).toEqual({ output: "" });
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
//# sourceMappingURL=providerGenerate.unit.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"providerGenerate.unit.spec.js","sourceRoot":"","sources":["../../../sources/modules/ai/providerGenerate.unit.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE9D,MAAM,cAAc,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;AAEjD,EAAE,CAAC,IAAI,CAAC,8BAA8B,EAAE,GAAG,EAAE,CAAC,CAAC;IAC7C,UAAU,EAAE,cAAc;CAC3B,CAAC,CAAC,CAAC;AAEJ,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAEpE,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,UAAU,CAAC,GAAG,EAAE;QACd,cAAc,CAAC,SAAS,EAAE,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;QAC5E,cAAc,CAAC,iBAAiB,CAAC;YAC/B,QAAQ,EAAE,CAAC;YACX,MAAM,EAAE,0BAA0B;YAClC,MAAM,EAAE,EAAE;SACX,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC;YACpC,UAAU,EAAE,IAAI;YAChB,OAAO,EAAE,IAAI;YACb,MAAM,EAAE,OAAO;YACf,OAAO,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,CAAC,OAAO,EAAE;SACrD,CAAC,CAAC;QAEH,MAAM,CAAC,cAAc,CAAC,CAAC,oBAAoB,CACzC,IAAI,EACJ,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,cAAc,EAAE,OAAO,CAAC,EACtD,MAAM,CAAC,gBAAgB,CAAC,EAAE,YAAY,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CACnE,CAAC;QACF,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,MAAM,EAAE,IAAI;YACZ,OAAO,EAAE;gBACP,UAAU,EAAE,IAAI;gBAChB,QAAQ,EAAE,CAAC;gBACX,MAAM,EAAE,6CAA6C;aACtD;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE,KAAK,IAAI,EAAE;QACxD,cAAc,CAAC,iBAAiB,CAAC;YAC/B,QAAQ,EAAE,CAAC;YACX,MAAM,EAAE,0BAA0B;YAClC,MAAM,EAAE,EAAE;SACX,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC;YACpC,UAAU,EAAE,IAAI;YAChB,OAAO,EAAE,IAAI;YACb,MAAM,EAAE,YAAY;YACpB,OAAO,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,CAAC,OAAO,EAAE;YACpD,iBAAiB,EAAE,KAAK;SACzB,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerDevFolderResolve.d.ts","sourceRoot":"","sources":["../../../sources/modules/beer/beerDevFolderResolve.ts"],"names":[],"mappings":"AAGA;;GAEG;AACH,wBAAgB,oBAAoB,IAAI,MAAM,CAE7C"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import os from "node:os";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
/**
|
|
4
|
+
* Returns the canonical holdmybeer development folder under the user home directory.
|
|
5
|
+
*/
|
|
6
|
+
export function beerDevFolderResolve() {
|
|
7
|
+
return path.join(os.homedir(), "Developer", "HoldMyBeerDev");
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=beerDevFolderResolve.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerDevFolderResolve.js","sourceRoot":"","sources":["../../../sources/modules/beer/beerDevFolderResolve.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,IAAI,MAAM,WAAW,CAAC;AAE7B;;GAEG;AACH,MAAM,UAAU,oBAAoB;IAClC,OAAO,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,WAAW,EAAE,eAAe,CAAC,CAAC;AAC/D,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerDevFolderResolve.spec.d.ts","sourceRoot":"","sources":["../../../sources/modules/beer/beerDevFolderResolve.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import os from "node:os";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { beerDevFolderResolve } from "@/modules/beer/beerDevFolderResolve.js";
|
|
5
|
+
describe("beerDevFolderResolve", () => {
|
|
6
|
+
it("resolves to ~/Developer/HoldMyBeerDev", () => {
|
|
7
|
+
expect(beerDevFolderResolve()).toBe(path.join(os.homedir(), "Developer", "HoldMyBeerDev"));
|
|
8
|
+
});
|
|
9
|
+
});
|
|
10
|
+
//# sourceMappingURL=beerDevFolderResolve.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerDevFolderResolve.spec.js","sourceRoot":"","sources":["../../../sources/modules/beer/beerDevFolderResolve.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAE9E,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;QAC/C,MAAM,CAAC,oBAAoB,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,WAAW,EAAE,eAAe,CAAC,CAAC,CAAC;IAC7F,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerOriginalPathResolve.d.ts","sourceRoot":"","sources":["../../../sources/modules/beer/beerOriginalPathResolve.ts"],"names":[],"mappings":"AAEA;;GAEG;AACH,wBAAgB,uBAAuB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAEnE"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
/**
|
|
3
|
+
* Returns the local original source checkout path under projectPath/.beer/original.
|
|
4
|
+
*/
|
|
5
|
+
export function beerOriginalPathResolve(projectPath) {
|
|
6
|
+
return path.join(projectPath, ".beer", "original");
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=beerOriginalPathResolve.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerOriginalPathResolve.js","sourceRoot":"","sources":["../../../sources/modules/beer/beerOriginalPathResolve.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAE7B;;GAEG;AACH,MAAM,UAAU,uBAAuB,CAAC,WAAmB;IACzD,OAAO,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;AACrD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerOriginalPathResolve.spec.d.ts","sourceRoot":"","sources":["../../../sources/modules/beer/beerOriginalPathResolve.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { beerOriginalPathResolve } from "@/modules/beer/beerOriginalPathResolve.js";
|
|
4
|
+
describe("beerOriginalPathResolve", () => {
|
|
5
|
+
it("resolves to .beer/original under the provided project path", () => {
|
|
6
|
+
const projectPath = "/tmp/test-project";
|
|
7
|
+
expect(beerOriginalPathResolve(projectPath)).toBe(path.join(projectPath, ".beer", "original"));
|
|
8
|
+
});
|
|
9
|
+
});
|
|
10
|
+
//# sourceMappingURL=beerOriginalPathResolve.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerOriginalPathResolve.spec.js","sourceRoot":"","sources":["../../../sources/modules/beer/beerOriginalPathResolve.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,uBAAuB,EAAE,MAAM,2CAA2C,CAAC;AAEpF,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,EAAE,CAAC,4DAA4D,EAAE,GAAG,EAAE;QACpE,MAAM,WAAW,GAAG,mBAAmB,CAAC;QACxC,MAAM,CAAC,uBAAuB,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC;IACjG,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerSettingsPathResolve.d.ts","sourceRoot":"","sources":["../../../sources/modules/beer/beerSettingsPathResolve.ts"],"names":[],"mappings":"AAGA;;GAEG;AACH,wBAAgB,uBAAuB,IAAI,MAAM,CAEhD"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
import { beerDevFolderResolve } from "@/modules/beer/beerDevFolderResolve.js";
|
|
3
|
+
/**
|
|
4
|
+
* Returns the canonical settings file path under ~/Developer/HoldMyBeerDev/.beer/settings.json.
|
|
5
|
+
*/
|
|
6
|
+
export function beerSettingsPathResolve() {
|
|
7
|
+
return path.join(beerDevFolderResolve(), ".beer", "settings.json");
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=beerSettingsPathResolve.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerSettingsPathResolve.js","sourceRoot":"","sources":["../../../sources/modules/beer/beerSettingsPathResolve.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAE9E;;GAEG;AACH,MAAM,UAAU,uBAAuB;IACrC,OAAO,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,OAAO,EAAE,eAAe,CAAC,CAAC;AACrE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerSettingsPathResolve.spec.d.ts","sourceRoot":"","sources":["../../../sources/modules/beer/beerSettingsPathResolve.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import os from "node:os";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { beerSettingsPathResolve } from "@/modules/beer/beerSettingsPathResolve.js";
|
|
5
|
+
describe("beerSettingsPathResolve", () => {
|
|
6
|
+
it("resolves settings path under the HoldMyBeerDev folder", () => {
|
|
7
|
+
expect(beerSettingsPathResolve()).toBe(path.join(os.homedir(), "Developer", "HoldMyBeerDev", ".beer", "settings.json"));
|
|
8
|
+
});
|
|
9
|
+
});
|
|
10
|
+
//# sourceMappingURL=beerSettingsPathResolve.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerSettingsPathResolve.spec.js","sourceRoot":"","sources":["../../../sources/modules/beer/beerSettingsPathResolve.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,uBAAuB,EAAE,MAAM,2CAA2C,CAAC;AAEpF,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,EAAE,CAAC,uDAAuD,EAAE,GAAG,EAAE;QAC/D,MAAM,CAAC,uBAAuB,EAAE,CAAC,CAAC,IAAI,CACpC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,WAAW,EAAE,eAAe,EAAE,OAAO,EAAE,eAAe,CAAC,CAChF,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { BeerSettings } from "@/modules/beer/beerSettingsTypes.js";
|
|
2
|
+
/**
|
|
3
|
+
* Reads settings.json or returns default settings when missing.
|
|
4
|
+
*/
|
|
5
|
+
export declare function beerSettingsRead(settingsPath: string): Promise<BeerSettings>;
|
|
6
|
+
//# sourceMappingURL=beerSettingsRead.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerSettingsRead.d.ts","sourceRoot":"","sources":["../../../sources/modules/beer/beerSettingsRead.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAExE;;GAEG;AACH,wBAAsB,gBAAgB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CAsBlF"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { readFile } from "node:fs/promises";
|
|
2
|
+
/**
|
|
3
|
+
* Reads settings.json or returns default settings when missing.
|
|
4
|
+
*/
|
|
5
|
+
export async function beerSettingsRead(settingsPath) {
|
|
6
|
+
const fallback = {
|
|
7
|
+
version: 1,
|
|
8
|
+
providers: [],
|
|
9
|
+
updatedAt: Date.now()
|
|
10
|
+
};
|
|
11
|
+
try {
|
|
12
|
+
const content = await readFile(settingsPath, "utf-8");
|
|
13
|
+
const parsed = JSON.parse(content);
|
|
14
|
+
return {
|
|
15
|
+
...fallback,
|
|
16
|
+
...parsed,
|
|
17
|
+
updatedAt: Date.now()
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
const err = error;
|
|
22
|
+
if (err.code === "ENOENT") {
|
|
23
|
+
return fallback;
|
|
24
|
+
}
|
|
25
|
+
throw error;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=beerSettingsRead.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerSettingsRead.js","sourceRoot":"","sources":["../../../sources/modules/beer/beerSettingsRead.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAG5C;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,YAAoB;IACzD,MAAM,QAAQ,GAAiB;QAC7B,OAAO,EAAE,CAAC;QACV,SAAS,EAAE,EAAE;QACb,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;KACtB,CAAC;IAEF,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;QACtD,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAiB,CAAC;QACnD,OAAO;YACL,GAAG,QAAQ;YACX,GAAG,MAAM;YACT,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC;IACJ,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,GAAG,GAAG,KAA8B,CAAC;QAC3C,IAAI,GAAG,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC1B,OAAO,QAAQ,CAAC;QAClB,CAAC;QACD,MAAM,KAAK,CAAC;IACd,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { GitHubRepoRef } from "@/modules/github/githubTypes.js";
|
|
2
|
+
import type { ProviderDetection } from "@/modules/providers/providerTypes.js";
|
|
3
|
+
export interface BeerSettings {
|
|
4
|
+
version: 1;
|
|
5
|
+
providers: ProviderDetection[];
|
|
6
|
+
sourceRepo?: GitHubRepoRef;
|
|
7
|
+
sourceCommitHash?: string;
|
|
8
|
+
publishRepo?: GitHubRepoRef;
|
|
9
|
+
updatedAt: number;
|
|
10
|
+
}
|
|
11
|
+
export type { ProviderDetection };
|
|
12
|
+
//# sourceMappingURL=beerSettingsTypes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerSettingsTypes.d.ts","sourceRoot":"","sources":["../../../sources/modules/beer/beerSettingsTypes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AACrE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,sCAAsC,CAAC;AAE9E,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,CAAC,CAAC;IACX,SAAS,EAAE,iBAAiB,EAAE,CAAC;IAC/B,UAAU,CAAC,EAAE,aAAa,CAAC;IAC3B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,WAAW,CAAC,EAAE,aAAa,CAAC;IAC5B,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,YAAY,EAAE,iBAAiB,EAAE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerSettingsTypes.js","sourceRoot":"","sources":["../../../sources/modules/beer/beerSettingsTypes.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { BeerSettings } from "@/modules/beer/beerSettingsTypes.js";
|
|
2
|
+
/**
|
|
3
|
+
* Persists .beer/settings.json with stable formatting.
|
|
4
|
+
*/
|
|
5
|
+
export declare function beerSettingsWrite(settingsPath: string, settings: BeerSettings): Promise<void>;
|
|
6
|
+
//# sourceMappingURL=beerSettingsWrite.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerSettingsWrite.d.ts","sourceRoot":"","sources":["../../../sources/modules/beer/beerSettingsWrite.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAExE;;GAEG;AACH,wBAAsB,iBAAiB,CACrC,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,YAAY,GACrB,OAAO,CAAC,IAAI,CAAC,CAGf"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { mkdir, writeFile } from "node:fs/promises";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
/**
|
|
4
|
+
* Persists .beer/settings.json with stable formatting.
|
|
5
|
+
*/
|
|
6
|
+
export async function beerSettingsWrite(settingsPath, settings) {
|
|
7
|
+
await mkdir(path.dirname(settingsPath), { recursive: true });
|
|
8
|
+
await writeFile(settingsPath, `${JSON.stringify(settings, null, 2)}\n`, "utf-8");
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=beerSettingsWrite.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beerSettingsWrite.js","sourceRoot":"","sources":["../../../sources/modules/beer/beerSettingsWrite.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,IAAI,MAAM,WAAW,CAAC;AAG7B;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,YAAoB,EACpB,QAAsB;IAEtB,MAAM,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC7D,MAAM,SAAS,CAAC,YAAY,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;AACnF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contextGet.d.ts","sourceRoot":"","sources":["../../../sources/modules/context/contextGet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mCAAmC,CAAC;AAGjE;;;GAGG;AACH,wBAAgB,UAAU,IAAI,OAAO,CAMpC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { text } from "@text";
|
|
2
|
+
/**
|
|
3
|
+
* Returns the initialized global Context.
|
|
4
|
+
* Expects: contextInitialize() was called first.
|
|
5
|
+
*/
|
|
6
|
+
export function contextGet() {
|
|
7
|
+
if (!globalThis.Context) {
|
|
8
|
+
throw new Error(text["error_context_not_initialized"]);
|
|
9
|
+
}
|
|
10
|
+
return globalThis.Context;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=contextGet.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contextGet.js","sourceRoot":"","sources":["../../../sources/modules/context/contextGet.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,OAAO,CAAC;AAE7B;;;GAGG;AACH,MAAM,UAAU,UAAU;IACxB,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;QACxB,MAAM,IAAI,KAAK,CAAC,IAAI,CAAC,+BAA+B,CAAE,CAAC,CAAC;IAC1D,CAAC;IAED,OAAO,UAAU,CAAC,OAAO,CAAC;AAC5B,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { Context } from "@/modules/context/contextTypes.js";
|
|
2
|
+
/**
|
|
3
|
+
* Returns existing global Context or initializes it on first use.
|
|
4
|
+
* Expects: projectPath is required on first call; ignored when context already exists.
|
|
5
|
+
*/
|
|
6
|
+
export declare function contextGetOrInitialize(projectPath: string): Promise<Context>;
|
|
7
|
+
//# sourceMappingURL=contextGetOrInitialize.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contextGetOrInitialize.d.ts","sourceRoot":"","sources":["../../../sources/modules/context/contextGetOrInitialize.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mCAAmC,CAAC;AAGjE;;;GAGG;AACH,wBAAsB,sBAAsB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAMlF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { contextInitialize } from "@/modules/context/contextInitialize.js";
|
|
2
|
+
/**
|
|
3
|
+
* Returns existing global Context or initializes it on first use.
|
|
4
|
+
* Expects: projectPath is required on first call; ignored when context already exists.
|
|
5
|
+
*/
|
|
6
|
+
export async function contextGetOrInitialize(projectPath) {
|
|
7
|
+
if (globalThis.Context) {
|
|
8
|
+
return globalThis.Context;
|
|
9
|
+
}
|
|
10
|
+
return contextInitialize(projectPath);
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=contextGetOrInitialize.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contextGetOrInitialize.js","sourceRoot":"","sources":["../../../sources/modules/context/contextGetOrInitialize.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAE3E;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,WAAmB;IAC9D,IAAI,UAAU,CAAC,OAAO,EAAE,CAAC;QACvB,OAAO,UAAU,CAAC,OAAO,CAAC;IAC5B,CAAC;IAED,OAAO,iBAAiB,CAAC,WAAW,CAAC,CAAC;AACxC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { Context } from "@/modules/context/contextTypes.js";
|
|
2
|
+
/**
|
|
3
|
+
* Detects providers once and creates the global Context object.
|
|
4
|
+
* Expects: projectPath is the root directory for all git operations.
|
|
5
|
+
*/
|
|
6
|
+
export declare function contextInitialize(projectPath: string): Promise<Context>;
|
|
7
|
+
//# sourceMappingURL=contextInitialize.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contextInitialize.d.ts","sourceRoot":"","sources":["../../../sources/modules/context/contextInitialize.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mCAAmC,CAAC;AAEjE;;;GAGG;AACH,wBAAsB,iBAAiB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAmB7E"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { generateText } from "@/modules/ai/generateText.js";
|
|
2
|
+
import { gitStageAndCommit } from "@/modules/git/gitStageAndCommit.js";
|
|
3
|
+
import { providerDetect } from "@/modules/providers/providerDetect.js";
|
|
4
|
+
/**
|
|
5
|
+
* Detects providers once and creates the global Context object.
|
|
6
|
+
* Expects: projectPath is the root directory for all git operations.
|
|
7
|
+
*/
|
|
8
|
+
export async function contextInitialize(projectPath) {
|
|
9
|
+
const providers = await providerDetect();
|
|
10
|
+
const context = {
|
|
11
|
+
projectPath,
|
|
12
|
+
providers,
|
|
13
|
+
inferText: (input) => generateText(context, input.prompt, {
|
|
14
|
+
providerPriority: input.providerPriority,
|
|
15
|
+
modelPriority: input.modelPriority,
|
|
16
|
+
modelSelectionMode: input.modelSelectionMode,
|
|
17
|
+
showProgress: input.showProgress,
|
|
18
|
+
writePolicy: input.writePolicy
|
|
19
|
+
}),
|
|
20
|
+
stageAndCommit: (message) => gitStageAndCommit(message, projectPath)
|
|
21
|
+
};
|
|
22
|
+
globalThis.Context = context;
|
|
23
|
+
return context;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=contextInitialize.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contextInitialize.js","sourceRoot":"","sources":["../../../sources/modules/context/contextInitialize.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AAGvE;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,WAAmB;IACzD,MAAM,SAAS,GAAG,MAAM,cAAc,EAAE,CAAC;IAEzC,MAAM,OAAO,GAAY;QACvB,WAAW;QACX,SAAS;QACT,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE,CACnB,YAAY,CAAC,OAAO,EAAE,KAAK,CAAC,MAAM,EAAE;YAClC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;YACxC,aAAa,EAAE,KAAK,CAAC,aAAa;YAClC,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;YAC5C,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,WAAW,EAAE,KAAK,CAAC,WAAW;SAC/B,CAAC;QACJ,cAAc,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,iBAAiB,CAAC,OAAO,EAAE,WAAW,CAAC;KACrE,CAAC;IAEF,UAAU,CAAC,OAAO,GAAG,OAAO,CAAC;IAC7B,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contextInitialize.spec.d.ts","sourceRoot":"","sources":["../../../sources/modules/context/contextInitialize.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { beforeEach, describe, expect, it, vi } from "vitest";
|
|
2
|
+
const providerDetectMock = vi.hoisted(() => vi.fn());
|
|
3
|
+
const generateTextMock = vi.hoisted(() => vi.fn());
|
|
4
|
+
const gitStageAndCommitMock = vi.hoisted(() => vi.fn());
|
|
5
|
+
vi.mock("../providers/providerDetect.js", () => ({
|
|
6
|
+
providerDetect: providerDetectMock
|
|
7
|
+
}));
|
|
8
|
+
vi.mock("../ai/generateText.js", () => ({
|
|
9
|
+
generateText: generateTextMock
|
|
10
|
+
}));
|
|
11
|
+
vi.mock("../git/gitStageAndCommit.js", () => ({
|
|
12
|
+
gitStageAndCommit: gitStageAndCommitMock
|
|
13
|
+
}));
|
|
14
|
+
import { contextInitialize } from "@/modules/context/contextInitialize.js";
|
|
15
|
+
describe("contextInitialize", () => {
|
|
16
|
+
beforeEach(() => {
|
|
17
|
+
providerDetectMock.mockReset();
|
|
18
|
+
generateTextMock.mockReset();
|
|
19
|
+
gitStageAndCommitMock.mockReset();
|
|
20
|
+
globalThis.Context = undefined;
|
|
21
|
+
});
|
|
22
|
+
it("creates global Context with projectPath and wires inferText to generateText", async () => {
|
|
23
|
+
providerDetectMock.mockResolvedValue([
|
|
24
|
+
{ id: "pi", available: true, command: "pi", priority: 1 }
|
|
25
|
+
]);
|
|
26
|
+
generateTextMock.mockResolvedValue({ provider: "pi", text: "ok" });
|
|
27
|
+
const context = await contextInitialize("/tmp/test-project");
|
|
28
|
+
expect(context.projectPath).toBe("/tmp/test-project");
|
|
29
|
+
const result = await context.inferText({
|
|
30
|
+
providerPriority: ["pi"],
|
|
31
|
+
prompt: "hello"
|
|
32
|
+
});
|
|
33
|
+
expect(globalThis.Context).toBe(context);
|
|
34
|
+
expect(result).toEqual({ provider: "pi", text: "ok" });
|
|
35
|
+
expect(generateTextMock).toHaveBeenCalledWith(context, "hello", {
|
|
36
|
+
providerPriority: ["pi"],
|
|
37
|
+
modelPriority: undefined,
|
|
38
|
+
modelSelectionMode: undefined,
|
|
39
|
+
showProgress: undefined,
|
|
40
|
+
writePolicy: undefined
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
it("wires stageAndCommit to gitStageAndCommit with projectPath", async () => {
|
|
44
|
+
providerDetectMock.mockResolvedValue([]);
|
|
45
|
+
gitStageAndCommitMock.mockResolvedValue(true);
|
|
46
|
+
const context = await contextInitialize("/tmp/test-project");
|
|
47
|
+
await context.stageAndCommit("test commit");
|
|
48
|
+
expect(gitStageAndCommitMock).toHaveBeenCalledWith("test commit", "/tmp/test-project");
|
|
49
|
+
});
|
|
50
|
+
it("passes showProgress and writePolicy through to generate", async () => {
|
|
51
|
+
providerDetectMock.mockResolvedValue([
|
|
52
|
+
{ id: "pi", available: true, command: "pi", priority: 1 }
|
|
53
|
+
]);
|
|
54
|
+
generateTextMock.mockResolvedValue({ provider: "pi", text: "ok" });
|
|
55
|
+
const context = await contextInitialize("/tmp/test-project");
|
|
56
|
+
await context.inferText({
|
|
57
|
+
providerPriority: ["pi"],
|
|
58
|
+
prompt: "hello",
|
|
59
|
+
showProgress: true,
|
|
60
|
+
writePolicy: {
|
|
61
|
+
mode: "write-whitelist",
|
|
62
|
+
writablePaths: ["README.md"]
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
expect(generateTextMock).toHaveBeenCalledWith(context, "hello", {
|
|
66
|
+
providerPriority: ["pi"],
|
|
67
|
+
modelPriority: undefined,
|
|
68
|
+
modelSelectionMode: undefined,
|
|
69
|
+
showProgress: true,
|
|
70
|
+
writePolicy: {
|
|
71
|
+
mode: "write-whitelist",
|
|
72
|
+
writablePaths: ["README.md"]
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
//# sourceMappingURL=contextInitialize.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contextInitialize.spec.js","sourceRoot":"","sources":["../../../sources/modules/context/contextInitialize.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { GenerateResult } from "@/modules/ai/generate.js";
|
|
2
|
+
import type { ProviderDetection, ProviderId, ProviderModelSelectionMode } from "@/modules/providers/providerTypes.js";
|
|
3
|
+
import type { InferenceWritePolicy } from "@/modules/sandbox/sandboxInferenceTypes.js";
|
|
4
|
+
export interface ContextInferTextInput {
|
|
5
|
+
providerPriority: readonly ProviderId[];
|
|
6
|
+
modelPriority?: readonly string[];
|
|
7
|
+
modelSelectionMode?: ProviderModelSelectionMode;
|
|
8
|
+
prompt: string;
|
|
9
|
+
showProgress?: boolean;
|
|
10
|
+
writePolicy?: InferenceWritePolicy;
|
|
11
|
+
}
|
|
12
|
+
export interface Context {
|
|
13
|
+
projectPath: string;
|
|
14
|
+
providers: ProviderDetection[];
|
|
15
|
+
inferText(input: ContextInferTextInput): Promise<GenerateResult>;
|
|
16
|
+
stageAndCommit(message: string): Promise<boolean>;
|
|
17
|
+
}
|
|
18
|
+
declare global {
|
|
19
|
+
var Context: Context | undefined;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=contextTypes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contextTypes.d.ts","sourceRoot":"","sources":["../../../sources/modules/context/contextTypes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,KAAK,EACV,iBAAiB,EACjB,UAAU,EACV,0BAA0B,EAC3B,MAAM,sCAAsC,CAAC;AAC9C,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,4CAA4C,CAAC;AAEvF,MAAM,WAAW,qBAAqB;IACpC,gBAAgB,EAAE,SAAS,UAAU,EAAE,CAAC;IACxC,aAAa,CAAC,EAAE,SAAS,MAAM,EAAE,CAAC;IAClC,kBAAkB,CAAC,EAAE,0BAA0B,CAAC;IAChD,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,WAAW,CAAC,EAAE,oBAAoB,CAAC;CACpC;AAED,MAAM,WAAW,OAAO;IACtB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,iBAAiB,EAAE,CAAC;IAC/B,SAAS,CAAC,KAAK,EAAE,qBAAqB,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC;IACjE,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CACnD;AAED,OAAO,CAAC,MAAM,CAAC;IACb,IAAI,OAAO,EAAE,OAAO,GAAG,SAAS,CAAC;CAClC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contextTypes.js","sourceRoot":"","sources":["../../../sources/modules/context/contextTypes.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gitPush.d.ts","sourceRoot":"","sources":["../../../sources/modules/git/gitPush.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,wBAAsB,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAExF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { commandRun } from "@/modules/util/commandRun.js";
|
|
2
|
+
/**
|
|
3
|
+
* Pushes current HEAD to the target remote branch.
|
|
4
|
+
* Expects: cwd is the git repository root.
|
|
5
|
+
*/
|
|
6
|
+
export async function gitPush(remote, branch, cwd) {
|
|
7
|
+
await commandRun("git", ["push", "-u", remote, `HEAD:${branch}`], { cwd });
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=gitPush.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gitPush.js","sourceRoot":"","sources":["../../../sources/modules/git/gitPush.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,MAAc,EAAE,MAAc,EAAE,GAAW;IACvE,MAAM,UAAU,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,MAAM,EAAE,CAAC,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;AAC7E,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gitRemoteEnsure.d.ts","sourceRoot":"","sources":["../../../sources/modules/git/gitRemoteEnsure.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,wBAAsB,eAAe,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAenF"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { commandRun } from "@/modules/util/commandRun.js";
|
|
2
|
+
/**
|
|
3
|
+
* Ensures origin points to the target remote URL.
|
|
4
|
+
* Expects: cwd is the git repository root.
|
|
5
|
+
*/
|
|
6
|
+
export async function gitRemoteEnsure(remoteUrl, cwd) {
|
|
7
|
+
const existing = await commandRun("git", ["remote", "get-url", "origin"], {
|
|
8
|
+
cwd,
|
|
9
|
+
allowFailure: true
|
|
10
|
+
});
|
|
11
|
+
if (existing.exitCode !== 0) {
|
|
12
|
+
await commandRun("git", ["remote", "add", "origin", remoteUrl], { cwd });
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
const current = existing.stdout.trim();
|
|
16
|
+
if (current !== remoteUrl) {
|
|
17
|
+
await commandRun("git", ["remote", "set-url", "origin", remoteUrl], { cwd });
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=gitRemoteEnsure.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gitRemoteEnsure.js","sourceRoot":"","sources":["../../../sources/modules/git/gitRemoteEnsure.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,SAAiB,EAAE,GAAW;IAClE,MAAM,QAAQ,GAAG,MAAM,UAAU,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,QAAQ,CAAC,EAAE;QACxE,GAAG;QACH,YAAY,EAAE,IAAI;KACnB,CAAC,CAAC;IAEH,IAAI,QAAQ,CAAC,QAAQ,KAAK,CAAC,EAAE,CAAC;QAC5B,MAAM,UAAU,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,CAAC,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;QACzE,OAAO;IACT,CAAC;IAED,MAAM,OAAO,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACvC,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;QAC1B,MAAM,UAAU,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,CAAC,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;IAC/E,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Recreates a shallow clone of the repository at targetDir.
|
|
3
|
+
* Returns the HEAD commit hash of the checkout for reproducibility.
|
|
4
|
+
*/
|
|
5
|
+
export declare function gitRepoCheckout(remoteUrl: string, targetDir: string): Promise<string>;
|
|
6
|
+
//# sourceMappingURL=gitRepoCheckout.d.ts.map
|