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

推荐订阅源

P
Proofpoint News Feed
M
Microsoft Research Blog - Microsoft Research
aimingoo的专栏
aimingoo的专栏
爱范儿
爱范儿
Apple Machine Learning Research
Apple Machine Learning Research
博客园 - 司徒正美
H
Hackread – Cybersecurity News, Data Breaches, AI and More
H
Help Net Security
腾讯CDC
A
About on SuperTechFans
Vercel News
Vercel News
G
Google Developers Blog
大猫的无限游戏
大猫的无限游戏
N
News | PayPal Newsroom
Stack Overflow Blog
Stack Overflow Blog
B
Blog RSS Feed
J
Java Code Geeks
S
Security @ Cisco Blogs
Security Latest
Security Latest
M
MIT News - Artificial intelligence
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Application and Cybersecurity Blog
Application and Cybersecurity Blog
F
Fox-IT International blog
O
OpenAI News
T
Tor Project blog
S
Security Archives - TechRepublic
The Register - Security
The Register - Security
博客园 - 三生石上(FineUI控件)
WordPress大学
WordPress大学
D
Docker
Hugging Face - Blog
Hugging Face - Blog
L
LINUX DO - 热门话题
Spread Privacy
Spread Privacy
I
Intezer
H
Hacker News: Front Page
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
V
Vulnerabilities – Threatpost
Google Online Security Blog
Google Online Security Blog
C
CERT Recently Published Vulnerability Notes
Schneier on Security
Schneier on Security
T
Tenable Blog
GbyAI
GbyAI
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
小众软件
小众软件
Recent Commits to openclaw:main
Recent Commits to openclaw:main
阮一峰的网络日志
阮一峰的网络日志
W
WeLiveSecurity
博客园 - 聂微东
T
The Exploit Database - CXSecurity.com

Recent Commits to openclaw:main

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(skills): restore executable bit on bundled whisper script + relea… · openclaw/openclaw@1dd3b52 fix(google): print Gemini OAuth URL before browser launch (#71469) · openclaw/openclaw@2d5bda9 docs: absorb contributor documentation fixes docs: tighten landable bug sweep gates · openclaw/openclaw@8f86383 fix: reuse provider auth lookup facts (#85499) · openclaw/openclaw@299ed80 fix: keep session picker focus separate · openclaw/openclaw@7e12370 feat: start onboarding for fresh CLI installs (#85519) · openclaw/openclaw@464ffc1 docs: refresh contributor docs · openclaw/openclaw@64d13c0 fix(update): prepack npm git update specs · openclaw/openclaw@84f6b5c fix: simplify chat session search · openclaw/openclaw@7e16a50 fix: use native mac settings sidebar · openclaw/openclaw@0556958 chore: ignore antigravity cli state · openclaw/openclaw@dd07fb4 fix(media): replace Gemini CLI fallback with sandboxed Antigravity (#… · openclaw/openclaw@0622fb6 docs: add bugbash landing changelog entries · openclaw/openclaw@faad2b0 fix(diffs): continue after card hydration errors (#84775) · openclaw/openclaw@9b5c281 fix(proxy): add missing clientSocket error handler in CONNECT tunnel … · openclaw/openclaw@e008bc9 fix(memory): report qmd workspace cwd probe failures (#63167) · openclaw/openclaw@7134a95 fix(agents): handle parallel tool call deltas in openai-completions s… test: align release validation package acceptance check (#85515) · openclaw/openclaw@423f525 fix: recover stuck Codex compaction · openclaw/openclaw@44d5330 docs: require visual proof for control ui e2e (#85513) · openclaw/openclaw@8174bfc Policy: add gateway exposure checks (#81981) · openclaw/openclaw@dcc5e45 ci: unblock advisory Tideclaw alpha release checks · openclaw/openclaw@dcfc7e5 fix(installer): tolerate WSL UNC launch cwd · openclaw/openclaw@684a9b2 docs: absorb docs sweep · openclaw/openclaw@bb5010b fix: cancel stale provider auth prewarms (#85503) · openclaw/openclaw@60e3749 Add TUI PTY integration coverage (#85485) · openclaw/openclaw@0a50cbd fix(security): escape entry.id in HTML export to prevent attribute XS… · openclaw/openclaw@7bc4a33 fix: guard openai-completions tool payload with supportsTools compat … · openclaw/openclaw@76a025c fix(slack): surface auth.test failure + normalize explicit-bot mentio… · openclaw/openclaw@995a020 chore(release): bump version to 2026.5.22 fix(ui): keep chat session search inline (#85490) · openclaw/openclaw@2601453 Policy: add secret and auth conformance checks (#81974) · openclaw/openclaw@c85feac fix(delivery): log failDelivery errors instead of silently swallowing… · openclaw/openclaw@f75789f fix(cli): validate debug proxy numeric options (#84260) · openclaw/openclaw@5c866a1 fix(daemon): use exit code instead of localized text for schtasks fal… · openclaw/openclaw@501e74d fix(auto-reply): enforce word boundary in slash command prefix match … · openclaw/openclaw@5c614de fix(message-tool): normalize send body aliases (#84102)
test(e2e): sample kitchen sink RSS on Windows · openclaw/openclaw@73c1e37
vincentkoc · 2026-05-23 · via Recent Commits to openclaw:main

@@ -4,7 +4,7 @@ import os from "node:os";

44

import path from "node:path";

55

import process from "node:process";

66

import { setTimeout as delay } from "node:timers/promises";

7-

import { pathToFileURL } from "node:url";

7+

import { fileURLToPath, pathToFileURL } from "node:url";

8899

const PLUGIN_SPEC =

1010

process.env.OPENCLAW_KITCHEN_SINK_NPM_SPEC || "npm:@openclaw/kitchen-sink@latest";

@@ -517,12 +517,21 @@ function assertToolInvokeResult(payload) {

517517

}

518518

}

519519520-

async function sampleProcess(pid) {

521-

if (!pid || process.platform === "win32") {

520+

export async function sampleProcess(pid, options = {}) {

521+

const platform = options.platform ?? process.platform;

522+

const run = options.runCommand ?? runCommand;

523+

if (!pid) {

522524

return null;

523525

}

526+

if (platform === "win32") {

527+

return sampleWindowsProcess(pid, run);

528+

}

529+

return samplePosixProcess(pid, run);

530+

}

531+532+

async function samplePosixProcess(pid, run) {

524533

try {

525-

const { stdout } = await runCommand("ps", ["-o", "rss=,pcpu=", "-p", String(pid)], {

534+

const { stdout } = await run("ps", ["-o", "rss=,pcpu=", "-p", String(pid)], {

526535

timeoutMs: 5000,

527536

});

528537

const [rssKbRaw, cpuRaw] = stdout.trim().split(/\s+/u);

@@ -540,7 +549,44 @@ async function sampleProcess(pid) {

540549

}

541550

}

542551543-

function assertResourceCeiling(sample) {

552+

async function sampleWindowsProcess(pid, run) {

553+

const safePid = Number(pid);

554+

if (!Number.isInteger(safePid) || safePid <= 0) {

555+

return null;

556+

}

557+

const command = [

558+

"$ErrorActionPreference = 'Stop'",

559+

`$process = Get-Process -Id ${safePid} -ErrorAction Stop`,

560+

"$cpu = 0",

561+

"if ($null -ne $process.CPU) { $cpu = $process.CPU }",

562+

"[Console]::Out.Write(('{0} {1}' -f $process.WorkingSet64, $cpu))",

563+

].join("; ");

564+

for (const powershell of ["powershell.exe", "powershell"]) {

565+

try {

566+

const { stdout } = await run(

567+

powershell,

568+

["-NoProfile", "-NonInteractive", "-ExecutionPolicy", "Bypass", "-Command", command],

569+

{ timeoutMs: 5000 },

570+

);

571+

const [workingSetBytesRaw, cpuSecondsRaw] = stdout.trim().split(/\s+/u);

572+

const workingSetBytes = Number.parseInt(workingSetBytesRaw ?? "", 10);

573+

const cpuSeconds = Number.parseFloat(cpuSecondsRaw ?? "");

574+

if (!Number.isFinite(workingSetBytes)) {

575+

return null;

576+

}

577+

return {

578+

rssMiB: Math.round((workingSetBytes / 1024 / 1024) * 10) / 10,

579+

cpuPercent: null,

580+

cpuSeconds: Number.isFinite(cpuSeconds) ? cpuSeconds : null,

581+

};

582+

} catch {

583+

// Try the next Windows PowerShell command name.

584+

}

585+

}

586+

return null;

587+

}

588+589+

export function assertResourceCeiling(sample) {

544590

if (!sample) {

545591

return;

546592

}

@@ -590,7 +636,7 @@ function isNonEmptyString(value) {

590636

return typeof value === "string" && value.trim().length > 0;

591637

}

592638593-

async function main() {

639+

export async function main() {

594640

const runner = resolveOpenClawRunner();

595641

const port = readPositiveInt(process.env.OPENCLAW_KITCHEN_SINK_RPC_PORT, DEFAULT_PORT);

596642

const { root, env } = makeEnv();

@@ -725,4 +771,6 @@ async function main() {

725771

}

726772

}

727773728-

await main();

774+

if (process.argv[1] && path.resolve(process.argv[1]) === fileURLToPath(import.meta.url)) {

775+

await main();

776+

}