test: harden mock order and shell path coverage

This commit is contained in:
Peter Steinberger
2026-02-19 15:04:55 +00:00
parent 4574f3279b
commit d3bf6e1b90
2 changed files with 60 additions and 3 deletions

View File

@@ -2,7 +2,7 @@ import fs from "node:fs";
import os from "node:os";
import path from "node:path";
import { afterEach, beforeEach, describe, expect, it } from "vitest";
import { getShellConfig } from "./shell-utils.js";
import { getShellConfig, resolveShellFromPath } from "./shell-utils.js";
const isWin = process.platform === "win32";
@@ -79,3 +79,59 @@ describe("getShellConfig", () => {
expect(shell).toBe("sh");
});
});
describe("resolveShellFromPath", () => {
const originalPath = process.env.PATH;
const tempDirs: string[] = [];
const createTempBin = (name: string, executable: boolean) => {
const dir = fs.mkdtempSync(path.join(os.tmpdir(), "openclaw-shell-path-"));
tempDirs.push(dir);
const filePath = path.join(dir, name);
fs.writeFileSync(filePath, "");
if (executable) {
fs.chmodSync(filePath, 0o755);
} else {
fs.chmodSync(filePath, 0o644);
}
return dir;
};
afterEach(() => {
if (originalPath == null) {
delete process.env.PATH;
} else {
process.env.PATH = originalPath;
}
for (const dir of tempDirs.splice(0)) {
fs.rmSync(dir, { recursive: true, force: true });
}
});
if (isWin) {
it("returns undefined on Windows for missing PATH entries in this test harness", () => {
process.env.PATH = "";
expect(resolveShellFromPath("bash")).toBeUndefined();
});
return;
}
it("returns undefined when PATH is empty", () => {
process.env.PATH = "";
expect(resolveShellFromPath("bash")).toBeUndefined();
});
it("returns the first executable match from PATH", () => {
const notExecutable = createTempBin("bash", false);
const executable = createTempBin("bash", true);
process.env.PATH = [notExecutable, executable].join(path.delimiter);
expect(resolveShellFromPath("bash")).toBe(path.join(executable, "bash"));
});
it("returns undefined when command does not exist", () => {
const dir = fs.mkdtempSync(path.join(os.tmpdir(), "openclaw-shell-empty-"));
tempDirs.push(dir);
process.env.PATH = dir;
expect(resolveShellFromPath("bash")).toBeUndefined();
});
});

View File

@@ -1,13 +1,13 @@
import { beforeEach, describe, expect, it } from "vitest";
import { setDefaultChannelPluginRegistryForTests } from "./channel-test-helpers.js";
import { channelsAddCommand } from "./channels.js";
import { configMocks, offsetMocks } from "./channels.mock-harness.js";
import { baseConfigSnapshot, createTestRuntime } from "./test-runtime-config-helpers.js";
const runtime = createTestRuntime();
let channelsAddCommand: typeof import("./channels.js").channelsAddCommand;
describe("channelsAddCommand", () => {
beforeEach(() => {
beforeEach(async () => {
configMocks.readConfigFileSnapshot.mockReset();
configMocks.writeConfigFile.mockClear();
offsetMocks.deleteTelegramUpdateOffset.mockClear();
@@ -15,6 +15,7 @@ describe("channelsAddCommand", () => {
runtime.error.mockClear();
runtime.exit.mockClear();
setDefaultChannelPluginRegistryForTests();
({ channelsAddCommand } = await import("./channels.js"));
});
it("clears telegram update offsets when the token changes", async () => {