* Fix Windows PowerShell 5.1 compatibility in installer Use $env:PROCESSOR_ARCHITECTURE for arch detection instead of RuntimeInformation::OSArchitecture which may not be loaded in every Windows PowerShell 5.1 session. Also fix null-reference when user PATH environment variable is empty. https://claude.ai/code/session_01VFiRDM2ZweyacXN5JneVoP * Fix executable resolution and tar extraction on Windows resolveExecutable() used `sh -lc "command -v ..."` which doesn't work on Windows (no sh). Now uses `cmd /c where` on win32. Also make tar workspace restoration tolerate symlink failures on Windows — .bin/ symlinks can't be created without Developer Mode, but the actual package directories are extracted fine. https://claude.ai/code/session_01VFiRDM2ZweyacXN5JneVoP * Broad Windows compatibility fixes across the codebase - runtime.ts: Use path.delimiter instead of hardcoded ":" for PATH construction — was completely broken on Windows - executables.ts: Add Windows fallback paths for Chrome, Edge, Brave, and Pandoc in Program Files; skip macOS-only paths on win32 - node-version.ts, check-node-version.mjs, bin/feynman.js: Show Windows-appropriate install instructions (irm | iex, nodejs.org) instead of nvm/curl on win32 - preview.ts: Support winget for pandoc auto-install on Windows, and apt on Linux (was macOS/brew only) - launch.ts: Catch unsupported signal errors on Windows - README.md: Add Windows PowerShell commands alongside macOS/Linux for all install instructions https://claude.ai/code/session_01VFiRDM2ZweyacXN5JneVoP * fix: complete windows bootstrap hardening --------- Co-authored-by: Claude <noreply@anthropic.com> Co-authored-by: Advait Paliwal <advaitspaliwal@gmail.com>
77 lines
2.3 KiB
TypeScript
77 lines
2.3 KiB
TypeScript
import test from "node:test";
|
|
import assert from "node:assert/strict";
|
|
|
|
import { buildPiArgs, buildPiEnv, resolvePiPaths } from "../src/pi/runtime.js";
|
|
|
|
test("buildPiArgs includes configured runtime paths and prompt", () => {
|
|
const args = buildPiArgs({
|
|
appRoot: "/repo/feynman",
|
|
workingDir: "/workspace",
|
|
sessionDir: "/sessions",
|
|
feynmanAgentDir: "/home/.feynman/agent",
|
|
initialPrompt: "hello",
|
|
explicitModelSpec: "openai:gpt-5.4",
|
|
thinkingLevel: "medium",
|
|
});
|
|
|
|
assert.deepEqual(args, [
|
|
"--session-dir",
|
|
"/sessions",
|
|
"--extension",
|
|
"/repo/feynman/extensions/research-tools.ts",
|
|
"--prompt-template",
|
|
"/repo/feynman/prompts",
|
|
"--model",
|
|
"openai:gpt-5.4",
|
|
"--thinking",
|
|
"medium",
|
|
"hello",
|
|
]);
|
|
});
|
|
|
|
test("buildPiEnv wires Feynman paths into the Pi environment", () => {
|
|
const previousUppercasePrefix = process.env.NPM_CONFIG_PREFIX;
|
|
const previousLowercasePrefix = process.env.npm_config_prefix;
|
|
process.env.NPM_CONFIG_PREFIX = "/tmp/global-prefix";
|
|
process.env.npm_config_prefix = "/tmp/global-prefix-lower";
|
|
|
|
const env = buildPiEnv({
|
|
appRoot: "/repo/feynman",
|
|
workingDir: "/workspace",
|
|
sessionDir: "/sessions",
|
|
feynmanAgentDir: "/home/.feynman/agent",
|
|
feynmanVersion: "0.1.5",
|
|
});
|
|
|
|
try {
|
|
assert.equal(env.FEYNMAN_SESSION_DIR, "/sessions");
|
|
assert.equal(env.FEYNMAN_BIN_PATH, "/repo/feynman/bin/feynman.js");
|
|
assert.equal(env.FEYNMAN_MEMORY_DIR, "/home/.feynman/memory");
|
|
assert.equal(env.FEYNMAN_NPM_PREFIX, "/home/.feynman/npm-global");
|
|
assert.equal(env.NPM_CONFIG_PREFIX, "/home/.feynman/npm-global");
|
|
assert.equal(env.npm_config_prefix, "/home/.feynman/npm-global");
|
|
assert.ok(
|
|
env.PATH?.startsWith(
|
|
"/repo/feynman/node_modules/.bin:/repo/feynman/.feynman/npm/node_modules/.bin:/home/.feynman/npm-global/bin:",
|
|
),
|
|
);
|
|
} finally {
|
|
if (previousUppercasePrefix === undefined) {
|
|
delete process.env.NPM_CONFIG_PREFIX;
|
|
} else {
|
|
process.env.NPM_CONFIG_PREFIX = previousUppercasePrefix;
|
|
}
|
|
if (previousLowercasePrefix === undefined) {
|
|
delete process.env.npm_config_prefix;
|
|
} else {
|
|
process.env.npm_config_prefix = previousLowercasePrefix;
|
|
}
|
|
}
|
|
});
|
|
|
|
test("resolvePiPaths includes the Promise.withResolvers polyfill path", () => {
|
|
const paths = resolvePiPaths("/repo/feynman");
|
|
|
|
assert.equal(paths.promisePolyfillPath, "/repo/feynman/dist/system/promise-polyfill.js");
|
|
});
|