惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

大猫的无限游戏
大猫的无限游戏
阮一峰的网络日志
阮一峰的网络日志
T
Tailwind CSS Blog
WordPress大学
WordPress大学
小众软件
小众软件
Engineering at Meta
Engineering at Meta
有赞技术团队
有赞技术团队
博客园 - 聂微东
GbyAI
GbyAI
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
Stack Overflow Blog
Stack Overflow Blog
罗磊的独立博客
腾讯CDC
The Cloudflare Blog
博客园 - Franky
MongoDB | Blog
MongoDB | Blog
Martin Fowler
Martin Fowler
G
Google Developers Blog
博客园 - 三生石上(FineUI控件)
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知

Recent Commits to openclaw:main

fix(ci): repair crabbox hydrate replay (#85706) feat(auth): support named model login profiles fix(gateway): restore WebChat image understanding routing · openclaw/openclaw@55a0c9b fix(anthropic): migrate 1M context to GA handling fix(scripts): resolve Crabbox shims on Windows · openclaw/openclaw@5c535df test(ci): harden installer smoke coverage · openclaw/openclaw@68bcd4e fix(status): bound deep docker audit probes (#85476) · openclaw/openclaw@f7c05dc docs: expand meeting notes docs · openclaw/openclaw@a7e0fa0 fix(cli): validate tasks audit limit (#84901) · openclaw/openclaw@44d470f fix(twitch): preserve newer message handler during cleanup (#85425) · openclaw/openclaw@71ddc01 fix(ci): require live docker credentials by resource · openclaw/openclaw@1e21121 fix(diagnostics): drop snake case otel ids (#72645) · openclaw/openclaw@e0bafc5 fix(ci): clear signal and docs guard blockers (#85693) · openclaw/openclaw@3a1d4dd fix(ci): require factory auth for droid live docker · openclaw/openclaw@cc6c372 fix: honor disabled synthetic auth lookup · openclaw/openclaw@a4a1abb fix(scripts): repair live docker auth shellcheck · openclaw/openclaw@4e34ac4 fix(docker): avoid printing gateway token · openclaw/openclaw@5db773f fix(cli): keep logs follow on live gateway state · openclaw/openclaw@6e3b318 fix(e2e): prefer x64 MinGit on Windows · openclaw/openclaw@15d9134 feat: add meeting notes plugin docs: update changelog for memory artifacts (#85060) (thanks @brokema… · openclaw/openclaw@9e55383 fix(memory-lancedb): expose public memory artifacts · openclaw/openclaw@aac1abe fix(memory): preserve sidecar capability hooks · openclaw/openclaw@e6288ca fix(e2e): scrub Windows update config on PowerShell 5.1 · openclaw/openclaw@6657b49 docs: absorb documentation PR sweep · openclaw/openclaw@2c536a8 fix(agents): stabilize Linux fallback tests · openclaw/openclaw@6b04170 fix(codex): preserve native web search action metadata (#85378) · openclaw/openclaw@bcf756c test: refresh Codex prompt snapshots · openclaw/openclaw@492d656 docs: absorb hook and subagent guidance PRs fix(agents): audit tool policy blocks (#85673) · openclaw/openclaw@09dd051 ci: fix plugin npm bundled dependency install · openclaw/openclaw@d485464 feat(diagnostics): classify skill and tool usage (#80370) docs(skills): clarify control ui recording proof (#85568) · openclaw/openclaw@0b476b9 test(agents): repair main failure fixtures · openclaw/openclaw@c29967b feat(diagnostics): trace gateway secret preparation (#83019) · openclaw/openclaw@4f0c902 fix(diagnostics): harden observability exports and smokes (#85371) · openclaw/openclaw@7f05be0 fix(stepfun): drop stale auth choice metadata · openclaw/openclaw@0b2ab6c test(e2e): sample kitchen sink RSS on Windows · openclaw/openclaw@73c1e37 test(plugins): fail gauntlet on load diagnostics fix(build): preserve tsdown heap floor · openclaw/openclaw@9ff1a43 fix(tools): honor config apiKey in media tool preflight (#85570) · openclaw/openclaw@31c269f fix(e2e): support macOS script wrappers fix(ci): scope changed shrinkwrap checks · openclaw/openclaw@743fd4c chore(ui): refresh fa control ui locale chore(ui): refresh nl control ui locale · openclaw/openclaw@908464b chore(ui): refresh vi control ui locale · openclaw/openclaw@62b75f4 chore(ui): refresh th control ui locale · openclaw/openclaw@fc4ba31 chore(ui): refresh id control ui locale · openclaw/openclaw@5b1bdd1 chore(ui): refresh pl control ui locale · openclaw/openclaw@534d4b1 chore(ui): refresh uk control ui locale · openclaw/openclaw@055c3bd chore(ui): refresh ar control ui locale · openclaw/openclaw@89c5a68 chore(ui): refresh it control ui locale · openclaw/openclaw@44ca805 chore(ui): refresh tr control ui locale chore(ui): refresh fr control ui locale · openclaw/openclaw@2240b0e chore(ui): refresh ko control ui locale · openclaw/openclaw@5fa250b chore(ui): refresh ja-JP control ui locale · openclaw/openclaw@f4ea401 chore(ui): refresh es control ui locale · openclaw/openclaw@751dde0 chore(ui): refresh de control ui locale · openclaw/openclaw@72a9b5b chore(ui): refresh pt-BR control ui locale · openclaw/openclaw@501b6e0 chore(ui): refresh zh-CN control ui locale chore(ui): refresh zh-TW control ui locale · openclaw/openclaw@88dee79 Add Slack approval QA checkpoints (#85141) fix(agents): mirror internal ui message tool replies (#85564) perf(whatsapp): narrow runtime setter entry (#85589) · openclaw/openclaw@463929d fix: smooth chat focus mode layout · openclaw/openclaw@bb5abef Fix Telegram missing harness spool poison (#85605) · openclaw/openclaw@b745082 fix(session): surface previous-transcript archive failures on /new ro… · openclaw/openclaw@679a46d Policy: add agent workspace conformance checks (#85096) · openclaw/openclaw@a94f344 fix(installer): fail failed Windows git builds · openclaw/openclaw@2edd6e2 fix(codex): honor node exec policy for native surfaces (#85534) · openclaw/openclaw@e0405ec fix(qa-lab): stabilize codex runtime parity fixtures fix(github): preserve sufficient proof against negative relabel (#85567) · openclaw/openclaw@6b52dff docs: add changelog for context pressure preflight · openclaw/openclaw@5ca734f Fix context pressure preflight for tool-heavy sessions (#85541) · openclaw/openclaw@c08400e fix(doctor): classify codex asset notice as info (#85119) · openclaw/openclaw@959b935 fix(ui): keep chat picker search current (#85547) fix: preserve message-tool delivery evidence · openclaw/openclaw@f022b05 fix(codex): add API key paste auth (#85533) fix: satisfy openai video test typecheck · openclaw/openclaw@743caed fix: route openai video edits to edits endpoint · openclaw/openclaw@6c3fcb8 fix(qmd): normalize direct file collection paths (#65212) · openclaw/openclaw@227b4bf fix(testbox): preserve clean sparse checkouts · openclaw/openclaw@58e9628 fix(ui): run ui script through junction paths (#85525) · openclaw/openclaw@ad19dd8 docs: fix troubleshooting logs link (#85545) · openclaw/openclaw@60582b6 Revert chat session picker inline search (#85527) · openclaw/openclaw@d69bcfd fix: preserve guarded video operation cleanup · openclaw/openclaw@ed7d99a fix: honor openai video provider request network policy fix: retry guarded video downloads · openclaw/openclaw@efbf9f3 fix: thread openai video request policy · openclaw/openclaw@31b5145 docs(changelog): note heartbeat message-tool fix · openclaw/openclaw@c127334 fix: use fs-safe trash for agent delete (#84394) · openclaw/openclaw@951bbe6 Fix heartbeat message-tool delivery policy (#85357) · openclaw/openclaw@bd9c78f Scope config preflight note suppression (#84439) · openclaw/openclaw@91d85e7 fix(cron): document best-effort edit delivery mode (#84526) fix(dreaming): open report cards from memory palace (#85144) · openclaw/openclaw@2e15830 fix(openai-codex): preserve image input capability (#85393) · openclaw/openclaw@49ce171 fix(codex): stabilize heartbeat dynamic tool schema (#84681) · openclaw/openclaw@c52daa4 docs: absorb small documentation PRs · openclaw/openclaw@658be7f fix(scripts): preserve bws resolver parse errors (#85528) · openclaw/openclaw@13a4c57 fix(telegram): honor outbound media max bytes (#83478) · openclaw/openclaw@f2d4f93
fix(release): run npm shims on Windows · openclaw/openclaw@1f32a48
vincentkoc · 2026-05-23 · via Recent Commits to openclaw:main

@@ -1,6 +1,7 @@

1-

import { mkdirSync, mkdtempSync, rmSync, writeFileSync } from "node:fs";

1+

import { execFileSync } from "node:child_process";

2+

import { mkdirSync, mkdtempSync, readFileSync, rmSync, writeFileSync } from "node:fs";

23

import { tmpdir } from "node:os";

3-

import { join } from "node:path";

4+

import { delimiter, join } from "node:path";

45

import { describe, expect, it } from "vitest";

56

import { WORKSPACE_TEMPLATE_PACK_PATHS } from "../scripts/lib/workspace-bootstrap-smoke.mjs";

67

import {

@@ -284,34 +285,122 @@ describe("resolveNpmCommandInvocation", () => {

284285

expect(

285286

resolveNpmCommandInvocation({

286287

npmExecPath: "/usr/local/lib/node_modules/npm/bin/npm-cli.js",

288+

npmArgs: ["view", "openclaw", "version"],

287289

nodeExecPath: "/usr/local/bin/node",

288290

platform: "linux",

289291

}),

290292

).toEqual({

291293

command: "/usr/local/bin/node",

292-

args: ["/usr/local/lib/node_modules/npm/bin/npm-cli.js"],

294+

args: ["/usr/local/lib/node_modules/npm/bin/npm-cli.js", "view", "openclaw", "version"],

293295

});

294296

});

295297296298

it("falls back to the npm command when npm_execpath points to pnpm", () => {

297299

expect(

298300

resolveNpmCommandInvocation({

301+

npmArgs: ["pack"],

299302

npmExecPath: "/home/test/.cache/node/corepack/v1/pnpm/10.23.0/bin/pnpm.cjs",

300303

nodeExecPath: "/usr/local/bin/node",

301304

platform: "linux",

302305

}),

303306

).toEqual({

304307

command: "npm",

305-

args: [],

308+

args: ["pack"],

306309

});

307310

});

308311309-

it("uses the platform npm command when npm_execpath is missing", () => {

310-

expect(resolveNpmCommandInvocation({ npmExecPath: "", platform: "win32" })).toEqual({

311-

command: "npm.cmd",

312-

args: [],

312+

it("wraps the Windows npm command when npm_execpath is missing", () => {

313+

expect(

314+

resolveNpmCommandInvocation({

315+

comSpec: "C:\\Windows\\System32\\cmd.exe",

316+

npmArgs: ["view", "openclaw@beta", "version"],

317+

npmExecPath: "",

318+

platform: "win32",

319+

}),

320+

).toEqual({

321+

command: "C:\\Windows\\System32\\cmd.exe",

322+

args: ["/d", "/s", "/c", "npm.cmd view openclaw@beta version"],

323+

windowsVerbatimArguments: true,

324+

});

325+

});

326+327+

it("wraps Windows npm_execpath command shims", () => {

328+

expect(

329+

resolveNpmCommandInvocation({

330+

comSpec: "C:\\Windows\\System32\\cmd.exe",

331+

npmArgs: ["install", "-g", "C:\\tmp\\openclaw package.tgz"],

332+

npmExecPath: "C:\\Program Files\\nodejs\\npm.cmd",

333+

nodeExecPath: "C:\\Program Files\\nodejs\\node.exe",

334+

platform: "win32",

335+

}),

336+

).toEqual({

337+

command: "C:\\Windows\\System32\\cmd.exe",

338+

args: [

339+

"/d",

340+

"/s",

341+

"/c",

342+

'"C:\\Program Files\\nodejs\\npm.cmd" install -g "C:\\tmp\\openclaw package.tgz"',

343+

],

344+

windowsVerbatimArguments: true,

345+

});

346+

});

347+348+

it("runs Windows npm_execpath executables directly", () => {

349+

expect(

350+

resolveNpmCommandInvocation({

351+

npmArgs: ["--version"],

352+

npmExecPath: "C:\\Program Files\\nodejs\\npm.exe",

353+

platform: "win32",

354+

}),

355+

).toEqual({

356+

command: "C:\\Program Files\\nodejs\\npm.exe",

357+

args: ["--version"],

313358

});

314359

});

360+361+

if (process.platform === "win32") {

362+

it("executes fallback npm.cmd through cmd.exe on Windows", () => {

363+

const dir = mkdtempSync(join(tmpdir(), "openclaw-fake-npm-cmd-"));

364+

try {

365+

const outputPath = join(dir, "args.json");

366+

writeFileSync(

367+

join(dir, "fake-npm.js"),

368+

[

369+

"const fs = require('node:fs');",

370+

"fs.writeFileSync(process.env.OPENCLAW_FAKE_NPM_OUT, JSON.stringify(process.argv.slice(2)));",

371+

].join("\n"),

372+

);

373+

writeFileSync(

374+

join(dir, "npm.cmd"),

375+

`@echo off\r\n"${process.execPath}" "%~dp0fake-npm.js" %*\r\n`,

376+

);

377+378+

const invocation = resolveNpmCommandInvocation({

379+

comSpec: process.env.ComSpec ?? "cmd.exe",

380+

npmArgs: ["view", "openclaw@beta", "version"],

381+

npmExecPath: "",

382+

platform: "win32",

383+

});

384+

execFileSync(invocation.command, invocation.args, {

385+

cwd: dir,

386+

env: {

387+

...process.env,

388+

OPENCLAW_FAKE_NPM_OUT: outputPath,

389+

PATH: `${dir}${delimiter}${process.env.PATH ?? ""}`,

390+

},

391+

windowsVerbatimArguments: invocation.windowsVerbatimArguments,

392+

});

393+394+

expect(JSON.parse(readFileSync(outputPath, "utf8"))).toEqual([

395+

"view",

396+

"openclaw@beta",

397+

"version",

398+

]);

399+

} finally {

400+

rmSync(dir, { recursive: true, force: true });

401+

}

402+

});

403+

}

315404

});

316405317406

describe("parseNpmPackJsonOutput", () => {