mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-10 01:33:29 +00:00
test: reclassify command config and channels suites
This commit is contained in:
73
src/commands/agents.add.test.ts
Normal file
73
src/commands/agents.add.test.ts
Normal file
@@ -0,0 +1,73 @@
|
||||
import { beforeEach, describe, expect, it, vi } from "vitest";
|
||||
import { baseConfigSnapshot, createTestRuntime } from "./test-runtime-config-helpers.js";
|
||||
|
||||
const readConfigFileSnapshotMock = vi.hoisted(() => vi.fn());
|
||||
const writeConfigFileMock = vi.hoisted(() => vi.fn().mockResolvedValue(undefined));
|
||||
|
||||
const wizardMocks = vi.hoisted(() => ({
|
||||
createClackPrompter: vi.fn(),
|
||||
}));
|
||||
|
||||
vi.mock("../config/config.js", async (importOriginal) => ({
|
||||
...(await importOriginal<typeof import("../config/config.js")>()),
|
||||
readConfigFileSnapshot: readConfigFileSnapshotMock,
|
||||
writeConfigFile: writeConfigFileMock,
|
||||
}));
|
||||
|
||||
vi.mock("../wizard/clack-prompter.js", () => ({
|
||||
createClackPrompter: wizardMocks.createClackPrompter,
|
||||
}));
|
||||
|
||||
import { WizardCancelledError } from "../wizard/prompts.js";
|
||||
import { agentsAddCommand } from "./agents.js";
|
||||
|
||||
const runtime = createTestRuntime();
|
||||
|
||||
describe("agents add command", () => {
|
||||
beforeEach(() => {
|
||||
readConfigFileSnapshotMock.mockClear();
|
||||
writeConfigFileMock.mockClear();
|
||||
wizardMocks.createClackPrompter.mockClear();
|
||||
runtime.log.mockClear();
|
||||
runtime.error.mockClear();
|
||||
runtime.exit.mockClear();
|
||||
});
|
||||
|
||||
it("requires --workspace when flags are present", async () => {
|
||||
readConfigFileSnapshotMock.mockResolvedValue({ ...baseConfigSnapshot });
|
||||
|
||||
await agentsAddCommand({ name: "Work" }, runtime, { hasFlags: true });
|
||||
|
||||
expect(runtime.error).toHaveBeenCalledWith(expect.stringContaining("--workspace"));
|
||||
expect(runtime.exit).toHaveBeenCalledWith(1);
|
||||
expect(writeConfigFileMock).not.toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it("requires --workspace in non-interactive mode", async () => {
|
||||
readConfigFileSnapshotMock.mockResolvedValue({ ...baseConfigSnapshot });
|
||||
|
||||
await agentsAddCommand({ name: "Work", nonInteractive: true }, runtime, {
|
||||
hasFlags: false,
|
||||
});
|
||||
|
||||
expect(runtime.error).toHaveBeenCalledWith(expect.stringContaining("--workspace"));
|
||||
expect(runtime.exit).toHaveBeenCalledWith(1);
|
||||
expect(writeConfigFileMock).not.toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it("exits with code 1 when the interactive wizard is cancelled", async () => {
|
||||
readConfigFileSnapshotMock.mockResolvedValue({ ...baseConfigSnapshot });
|
||||
wizardMocks.createClackPrompter.mockReturnValue({
|
||||
intro: vi.fn().mockRejectedValue(new WizardCancelledError()),
|
||||
text: vi.fn(),
|
||||
confirm: vi.fn(),
|
||||
note: vi.fn(),
|
||||
outro: vi.fn(),
|
||||
});
|
||||
|
||||
await agentsAddCommand({}, runtime);
|
||||
|
||||
expect(runtime.exit).toHaveBeenCalledWith(1);
|
||||
expect(writeConfigFileMock).not.toHaveBeenCalled();
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user