mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-05 12:30:22 +00:00
fix: finalize exec fish fallback (#1297) (thanks @ysqander)
This commit is contained in:
82
src/agents/shell-utils.test.ts
Normal file
82
src/agents/shell-utils.test.ts
Normal file
@@ -0,0 +1,82 @@
|
||||
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";
|
||||
|
||||
const isWin = process.platform === "win32";
|
||||
|
||||
describe("getShellConfig", () => {
|
||||
const originalShell = process.env.SHELL;
|
||||
const originalPath = process.env.PATH;
|
||||
const tempDirs: string[] = [];
|
||||
|
||||
const createTempBin = (files: string[]) => {
|
||||
const dir = fs.mkdtempSync(path.join(os.tmpdir(), "clawdbot-shell-"));
|
||||
tempDirs.push(dir);
|
||||
for (const name of files) {
|
||||
const filePath = path.join(dir, name);
|
||||
fs.writeFileSync(filePath, "");
|
||||
fs.chmodSync(filePath, 0o755);
|
||||
}
|
||||
return dir;
|
||||
};
|
||||
|
||||
beforeEach(() => {
|
||||
if (!isWin) {
|
||||
process.env.SHELL = "/usr/bin/fish";
|
||||
}
|
||||
});
|
||||
|
||||
afterEach(() => {
|
||||
if (originalShell == null) {
|
||||
delete process.env.SHELL;
|
||||
} else {
|
||||
process.env.SHELL = originalShell;
|
||||
}
|
||||
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("uses PowerShell on Windows", () => {
|
||||
const { shell } = getShellConfig();
|
||||
expect(shell.toLowerCase()).toContain("powershell");
|
||||
});
|
||||
return;
|
||||
}
|
||||
|
||||
it("prefers bash when fish is default and bash is on PATH", () => {
|
||||
const binDir = createTempBin(["bash"]);
|
||||
process.env.PATH = binDir;
|
||||
const { shell } = getShellConfig();
|
||||
expect(shell).toBe(path.join(binDir, "bash"));
|
||||
});
|
||||
|
||||
it("falls back to sh when fish is default and bash is missing", () => {
|
||||
const binDir = createTempBin(["sh"]);
|
||||
process.env.PATH = binDir;
|
||||
const { shell } = getShellConfig();
|
||||
expect(shell).toBe(path.join(binDir, "sh"));
|
||||
});
|
||||
|
||||
it("falls back to env shell when fish is default and no sh is available", () => {
|
||||
process.env.PATH = "";
|
||||
const { shell } = getShellConfig();
|
||||
expect(shell).toBe("/usr/bin/fish");
|
||||
});
|
||||
|
||||
it("uses sh when SHELL is unset", () => {
|
||||
delete process.env.SHELL;
|
||||
process.env.PATH = "";
|
||||
const { shell } = getShellConfig();
|
||||
expect(shell).toBe("sh");
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user