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

推荐订阅源

让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
人人都是产品经理
人人都是产品经理
Cisco Talos Blog
Cisco Talos Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
V
V2EX
博客园 - 三生石上(FineUI控件)
Martin Fowler
Martin Fowler
WordPress大学
WordPress大学
D
Docker
S
SegmentFault 最新的问题
博客园 - 聂微东
美团技术团队
Apple Machine Learning Research
Apple Machine Learning Research
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Last Week in AI
Last Week in AI
M
MIT News - Artificial intelligence
F
Fortinet All Blogs
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
The GitHub Blog
The GitHub Blog
GbyAI
GbyAI
L
LangChain Blog
Vercel News
Vercel News
博客园 - 叶小钗
MongoDB | Blog
MongoDB | Blog
Stack Overflow Blog
Stack Overflow Blog
H
Help Net Security
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
The Cloudflare Blog
Engineering at Meta
Engineering at Meta
T
Threat Research - Cisco Blogs
T
Threatpost
Scott Helme
Scott Helme
T
Tailwind CSS Blog
Latest news
Latest news
Stack Overflow Blog
Stack Overflow Blog
Blog — PlanetScale
Blog — PlanetScale
The Register - Security
The Register - Security
罗磊的独立博客
P
Proofpoint News Feed
腾讯CDC
S
Schneier on Security
雷峰网
雷峰网
A
About on SuperTechFans
T
Tenable Blog
F
Full Disclosure
Cyberwarzone
Cyberwarzone
博客园_首页
有赞技术团队
有赞技术团队
K
Kaspersky official blog

Recent Commits to openclaw:main

refactor(agents): bind subagent threads in core (#88416) fix: skip browser cleanup when browser is disabled perf: skip unnecessary setup auth fallback · openclaw/openclaw@39e9873 ci(release): allow direct publish recovery ci(release): checkout approval helper refactor(msteams): persist conversation and poll stores in sqlite · openclaw/openclaw@a2b2c4a fix(agents): dedupe subagent browser session cleanup · openclaw/openclaw@a9a86f7 fix(build): avoid stale agent-core dts warnings (#87915) · openclaw/openclaw@371a8ab Move cron persistence to SQLite (#88285) · openclaw/openclaw@005da57 fix(ui): keep selected chat model visible after session switch · openclaw/openclaw@d11e82a fix(llm): repair invalid streaming unicode escapes ci: update Blacksmith Testbox actions refactor: move model catalog normalization into core package fix(codex): keep app-server continuation turns alive · openclaw/openclaw@961691d test(agents): wait for MCP method-not-found log · openclaw/openclaw@2780f54 fix(scripts): quiet minimal runtime asset copies · openclaw/openclaw@37058ad ci: skip codeql network shard for test-only changes · openclaw/openclaw@37c6e2d fix: remove redundant unknown union ci: keep harness changes on fast checks (#88429) · openclaw/openclaw@e24a9c5 chore: remove inert skill workshop package · openclaw/openclaw@d9c0d09 fix(auth): bound oauth mirror expiry · openclaw/openclaw@0c7ab41 fix(export-html): guard msg.content and result.content filter/iterati… · openclaw/openclaw@5811693 fix(agents): bound auth health expiry · openclaw/openclaw@445ff22 ci: stabilize changed checks · openclaw/openclaw@602364f fix(agents): bound discovery auth expiry · openclaw/openclaw@c73e8ee fix: harden skill workshop proposal results · openclaw/openclaw@7d19f89 fix: preserve trusted policy checks for skill workshop · openclaw/openclaw@908fc35 fix: refresh skill workshop generated surfaces · openclaw/openclaw@77c6bee refactor: move skill research capture logic · openclaw/openclaw@6eb6730 fix: serialize skill proposal lifecycle mutations · openclaw/openclaw@41044a2 fix: keep autonomous skill capture opt-in · openclaw/openclaw@43e4b9d fix: allow concise skill update descriptions · openclaw/openclaw@28290a4 fix: preserve auto-captured skill updates · openclaw/openclaw@0b49710 fix: scan skill proposal prompt content · openclaw/openclaw@131e662 fix: refresh skill workshop CI expectations · openclaw/openclaw@515d4ff chore: keep skill workshop package manifest inert · openclaw/openclaw@dcc329a fix: align skill proposal revise validation · openclaw/openclaw@7051bf1 fix: approve final skill workshop tool params · openclaw/openclaw@3cd368e fix: serialize skill proposal creation limits · openclaw/openclaw@d6d1cc2 fix: bound skill workshop descriptions · openclaw/openclaw@3a9e7df refactor: rename skill workshop agent tool · openclaw/openclaw@2383cfd fix: enforce skill workshop proposal bounds · openclaw/openclaw@e4905ce fix(plugin-sdk): bound oauth result expiry fix(agents): harden message dts and block timestamps fix(outbound): bound delivery recovery deadline fix(shared): bound epoch expiry helpers fix(media): bound provider operation deadlines · openclaw/openclaw@06e0fd3 fix(agents): bound run drain deadlines · openclaw/openclaw@51cceaf fix(github-copilot): bound device code expiry feat: improve MCP operability fix(models): bound pasted token expiry · openclaw/openclaw@9cb9851 fix(plugins): bound scheduled turn delays fix(skill-creator): sort .skill entries deterministically · openclaw/openclaw@878e433 fix(qqbot): bound reminder schedule time fix(memory): bound qmd embed backoff · openclaw/openclaw@caac973 fix(discord): bound timeout member expiry · openclaw/openclaw@6399b6a fix(qqbot): skip token cache on invalid clock · openclaw/openclaw@472606d fix(infra): bound device bootstrap expiry · openclaw/openclaw@1774965 fix(cron): bound relative at timestamps · openclaw/openclaw@e0248fc fix(crestodian): bound rescue approval expiry · openclaw/openclaw@6a753ad fix(agents): bound codex cli fallback expiry · openclaw/openclaw@53812bd fix(gateway): forward stop sequences across providers · openclaw/openclaw@fe3c3ac feat: expand workboard orchestration metadata (#88408) · openclaw/openclaw@5435b45 fix(discord): bound rest rate-limit deadlines · openclaw/openclaw@abc26b0 fix(agents): show exec target node in tool display · openclaw/openclaw@64533ba fix(telegram): bound transport cooldown expiry · openclaw/openclaw@7d4bf8f test(release): harden live release checks · openclaw/openclaw@bdb0fde fix(anthropic): bound setup token expiry · openclaw/openclaw@926a165 fix(bedrock): bound mantle runtime token expiry · openclaw/openclaw@70b6fdd fix(agents): bound sqlite cache expiry · openclaw/openclaw@9ad7f5b fix(agents): bound google prompt cache expiry · openclaw/openclaw@1ee751d fix(agents): bound auth profile block expiry · openclaw/openclaw@30e3ca0 fix(telegram): bound error cooldown expiry · openclaw/openclaw@1f6c1ea fix(discord): bound component registry expiry · openclaw/openclaw@8654353 fix(discord): carry reply typing feedback through queue · openclaw/openclaw@6f20f29 fix(discord): omit undefined component registry fields fix(gateway): bound node pending work expiry fix(gateway): explain ignored restart signal · openclaw/openclaw@bc77f7a fix(media): dedupe duplicate inbound media path urls fix(gateway): bound plugin node capability expiry fix(install): show npm install progress without gum · openclaw/openclaw@1c9851e fix(commitments): bound terminal failure cooldown expiry · openclaw/openclaw@a4f6240 test(tasks): cover task domain view mappers (#86755) · openclaw/openclaw@8d3fe21 fix(imessage): bound private api negative cache expiry refactor(matrix): move ephemeral state to plugin sqlite (#88387) fix(imessage): bound approval reaction poll expiry fix(agents): bound exec followup handoff expiry · openclaw/openclaw@cbad1b6 fix(sandbox): bound novnc observer token expiry · openclaw/openclaw@f4cd5e4 test(release): wait for live probe cleanup · openclaw/openclaw@0e7773d fix(agents): bound exec approval request expiry · openclaw/openclaw@d8e7734 fix(google): bound realtime browser session expiry · openclaw/openclaw@da7fb64 fix(msteams): bound delegated token expiry · openclaw/openclaw@3fffb34 fix(workboard): bound claim expiry checks · openclaw/openclaw@0dd67e2 fix(browser): bound armed dialog expiry · openclaw/openclaw@4df27b9 fix(commands): bound private approval route expiry · openclaw/openclaw@e708a87 fix(agents): hide sessions_send alias normalization · openclaw/openclaw@2dacc6d fix(plugin-state): bound ttl expiry writes · openclaw/openclaw@9660e42 fix(skills): bound upload expiry checks · openclaw/openclaw@522da25 fix(exec): bound approval pending expiry · openclaw/openclaw@d44621b test(release): skip unavailable anthropic live models
test(scripts): expose kitchen sink command RSS · openclaw/openclaw@b93ed3f
vincentkoc · 2026-05-31 · via Recent Commits to openclaw:main

@@ -181,16 +181,65 @@ function formatCapturedOutput(label, buffer) {

181181182182

export function runCommand(command, args, options = {}) {

183183

return new Promise((resolve, reject) => {

184-

const { timeoutKillGraceMs = 2000, timeoutMs = COMMAND_TIMEOUT_MS, ...spawnOptions } = options;

184+

const {

185+

resourceLabel,

186+

resourceSampleIntervalMs = 1000,

187+

resourceSampleOptions,

188+

resourceSamples,

189+

sampleProcessImpl = sampleProcess,

190+

timeoutKillGraceMs = 2000,

191+

timeoutMs = COMMAND_TIMEOUT_MS,

192+

...spawnOptions

193+

} = options;

185194

const child = childProcess.spawn(command, args, {

186195

stdio: ["ignore", "pipe", "pipe"],

187196

...spawnOptions,

188197

detached: spawnOptions.detached ?? process.platform !== "win32",

189198

});

199+

const startedAt = Date.now();

190200

let stdout = { text: "", truncatedChars: 0 };

191201

let stderr = { text: "", truncatedChars: 0 };

192202

let timedOut = false;

193203

let forceKillTimer;

204+

let sampleTimer;

205+

let resourceSampleInFlight = null;

206+

const commandLabel = resourceLabel ?? [command, ...args.slice(0, 2)].join(" ");

207+

const shouldSampleResources = Array.isArray(resourceSamples);

208+

const collectResourceSample = () => {

209+

if (!shouldSampleResources || !child.pid) {

210+

return null;

211+

}

212+

resourceSampleInFlight ??= Promise.resolve()

213+

.then(() => sampleProcessImpl(child.pid, resourceSampleOptions ?? {}))

214+

.then((sample) => {

215+

if (sample) {

216+

resourceSamples.push({

217+

...sample,

218+

elapsedMs: Date.now() - startedAt,

219+

label: commandLabel,

220+

});

221+

}

222+

})

223+

.catch(() => {})

224+

.finally(() => {

225+

resourceSampleInFlight = null;

226+

});

227+

return resourceSampleInFlight;

228+

};

229+

const stopResourceSampling = async () => {

230+

clearInterval(sampleTimer);

231+

await resourceSampleInFlight?.catch(() => {});

232+

};

233+

if (shouldSampleResources) {

234+

void collectResourceSample();

235+

sampleTimer = setInterval(

236+

() => {

237+

void collectResourceSample();

238+

},

239+

Math.max(100, resourceSampleIntervalMs),

240+

);

241+

sampleTimer.unref?.();

242+

}

194243

const timer = setTimeout(() => {

195244

timedOut = true;

196245

signalProcessGroup(child, "SIGTERM");

@@ -206,35 +255,37 @@ export function runCommand(command, args, options = {}) {

206255

child.on("error", (error) => {

207256

clearTimeout(timer);

208257

clearTimeout(forceKillTimer);

209-

reject(error);

258+

void stopResourceSampling().finally(() => reject(error));

210259

});

211260

child.on("close", (status, signal) => {

212261

clearTimeout(timer);

213262

clearTimeout(forceKillTimer);

214-

if (status === 0) {

215-

resolve({

216-

stdout: stdout.text,

217-

stderr: stderr.text,

218-

stdoutTruncatedChars: stdout.truncatedChars,

219-

stderrTruncatedChars: stderr.truncatedChars,

220-

});

221-

return;

222-

}

223-

const detail = [

224-

formatCapturedOutput("stdout", stdout),

225-

formatCapturedOutput("stderr", stderr),

226-

]

227-

.filter(Boolean)

228-

.join("\n")

229-

.trim();

230-

const failure = timedOut

231-

? `timed out after ${timeoutMs}ms`

232-

: `failed with ${signal || status}`;

233-

reject(

234-

new Error(

235-

`${command} ${args.join(" ")} ${failure}${detail ? `\n${tailText(detail)}` : ""}`,

236-

),

237-

);

263+

void stopResourceSampling().then(() => {

264+

if (status === 0) {

265+

resolve({

266+

stdout: stdout.text,

267+

stderr: stderr.text,

268+

stdoutTruncatedChars: stdout.truncatedChars,

269+

stderrTruncatedChars: stderr.truncatedChars,

270+

});

271+

return;

272+

}

273+

const detail = [

274+

formatCapturedOutput("stdout", stdout),

275+

formatCapturedOutput("stderr", stderr),

276+

]

277+

.filter(Boolean)

278+

.join("\n")

279+

.trim();

280+

const failure = timedOut

281+

? `timed out after ${timeoutMs}ms`

282+

: `failed with ${signal || status}`;

283+

reject(

284+

new Error(

285+

`${command} ${args.join(" ")} ${failure}${detail ? `\n${tailText(detail)}` : ""}`,

286+

),

287+

);

288+

});

238289

});

239290

});

240291

}

@@ -262,6 +313,10 @@ async function runOpenClaw(runner, args, env, options = {}) {

262313

return runCommand(command.command, command.args, {

263314

...command.options,

264315

env,

316+

resourceLabel: options.resourceLabel,

317+

resourceSampleIntervalMs: options.resourceSampleIntervalMs,

318+

resourceSampleOptions: options.resourceSampleOptions,

319+

resourceSamples: options.resourceSamples,

265320

timeoutMs: options.timeoutMs ?? COMMAND_TIMEOUT_MS,

266321

});

267322

}

@@ -1372,20 +1427,35 @@ export async function main() {

13721427

let child;

1373142813741429

const processSamples = [];

1430+

const commandSamples = [];

1431+

const commandResourceOptions = {

1432+

resourceSampleIntervalMs: 500,

1433+

resourceSamples: commandSamples,

1434+

};

13751435

let sampleInFlight = null;

13761436

let sampleTimer;

13771437

try {

13781438

console.log(`Kitchen Sink RPC walk using ${PLUGIN_SPEC} via ${runner.label}`);

13791439

await runOpenClaw(runner, ["plugins", "install", PLUGIN_SPEC], env, {

1440+

...commandResourceOptions,

1441+

resourceLabel: "plugins install",

13801442

timeoutMs: INSTALL_TIMEOUT_MS,

13811443

});

13821444

runner = resolveOpenClawRunner();

13831445

console.log(`Kitchen Sink RPC runtime runner: ${runner.label}`);

13841446

configureKitchenSink(env, port);

1385-

await runOpenClaw(runner, ["plugins", "enable", PLUGIN_ID], env, { timeoutMs: 60000 });

1447+

await runOpenClaw(runner, ["plugins", "enable", PLUGIN_ID], env, {

1448+

...commandResourceOptions,

1449+

resourceLabel: "plugins enable",

1450+

timeoutMs: 60000,

1451+

});

13861452

const inspect = parseJsonOutput(

1387-

(await runOpenClaw(runner, ["plugins", "inspect", PLUGIN_ID, "--runtime", "--json"], env))

1388-

.stdout,

1453+

(

1454+

await runOpenClaw(runner, ["plugins", "inspect", PLUGIN_ID, "--runtime", "--json"], env, {

1455+

...commandResourceOptions,

1456+

resourceLabel: "plugins inspect",

1457+

})

1458+

).stdout,

13891459

);

13901460

if (inspect?.plugin?.status !== "loaded") {

13911461

throw new Error(`Kitchen Sink plugin did not inspect as loaded: ${JSON.stringify(inspect)}`);

@@ -1510,6 +1580,7 @@ export async function main() {

15101580

const finalSample = await sampleGateway();

15111581

assertResourceCeiling(finalSample);

15121582

const peakSample = summarizeProcessSamples(processSamples);

1583+

const commandPeakSample = summarizeProcessSamples(commandSamples);

15131584

assertResourceCeiling(peakSample);

15141585

assertNoErrorLogs(logPath);

15151586

@@ -1521,6 +1592,7 @@ export async function main() {

15211592

commands: commandNames,

15221593

catalogTools: catalogToolIds.filter((id) => EXPECTED_TOOLS.includes(id)),

15231594

channelAccount,

1595+

commandPeakSample,

15241596

initialSample,

15251597

finalSample,

15261598

peakSample,