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

推荐订阅源

N
News and Events Feed by Topic
Malwarebytes
Malwarebytes
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
C
Cybersecurity and Infrastructure Security Agency CISA
F
Future of Privacy Forum
C
Cisco Blogs
T
The Exploit Database - CXSecurity.com
A
Arctic Wolf
S
Securelist
K
Kaspersky official blog
S
Schneier on Security
T
ThreatConnect
T
Tenable Blog
Spread Privacy
Spread Privacy
T
True Tiger Recordings
AWS News Blog
AWS News Blog
F
Fox-IT International blog
量子位
T
Threatpost
V
Vulnerabilities – Threatpost
C
CERT Recently Published Vulnerability Notes
Cisco Talos Blog
Cisco Talos Blog
GbyAI
GbyAI
宝玉的分享
宝玉的分享
腾讯CDC
G
Google Developers Blog
aimingoo的专栏
aimingoo的专栏
Cyberwarzone
Cyberwarzone
有赞技术团队
有赞技术团队
S
SegmentFault 最新的问题
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
V
Visual Studio Blog
U
Unit 42
雷峰网
雷峰网
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Simon Willison's Weblog
Simon Willison's Weblog
O
OpenAI News
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
The GitHub Blog
The GitHub Blog
The Register - Security
The Register - Security
MyScale Blog
MyScale Blog
小众软件
小众软件
A
About on SuperTechFans
Last Week in AI
Last Week in AI
Y
Y Combinator Blog
博客园 - 三生石上(FineUI控件)
美团技术团队
Google Online Security Blog
Google Online Security Blog
P
Proofpoint News Feed
MongoDB | Blog
MongoDB | Blog

Recent Commits to openclaw:main

fix(e2e): harden bundled lifecycle probe on Windows · openclaw/openclaw@4798264 test(e2e): sample kitchen sink rpc peak rss · openclaw/openclaw@60c0f24 fix(scripts): remove stale deadcode allowlist entries · openclaw/openclaw@ea3bb92 fix(telegram): route polling diagnostics away from errors · openclaw/openclaw@b5c1199 fix(plugins): support linked source checkouts on Windows · openclaw/openclaw@793e300 fix(gateway): back off session tool mirrors under pressure (#84846) · openclaw/openclaw@42bdc94 fix(config): skip shell env fallback on Windows (#85739) · openclaw/openclaw@06bf302 fix(gateway): avoid duplicate session message broadcasts · openclaw/openclaw@1459044 fix: repair anchorless iMessage watch payloads · openclaw/openclaw@f37fbc9 fix(cli): route node status hints to stdout (#85780) · openclaw/openclaw@749692e fix(oc-path): support deep config edits (#86060) · openclaw/openclaw@3a72a30 fix(config): quiet benign metadata anomaly output · openclaw/openclaw@f3f4f29 fix(test): fail multi-node update regressions · openclaw/openclaw@732cf54 fix(google-vertex): support production ADC modes (#83971) · openclaw/openclaw@f09b4eb test(e2e): expose corrupt plugin deps smoke · openclaw/openclaw@fa3ff4d fix(codex): log app-server approval promotion trigger · openclaw/openclaw@d9af23f test(e2e): harden multi-node update smoke Clean up browser MCP subprocess tree (#85832) · openclaw/openclaw@8dc6b4d fix(agents): log warnings instead of swallowing subagent errors (#82943) · openclaw/openclaw@907bc03 fix(compaction): preserve partial summary on mid-chain chunk failure … · openclaw/openclaw@f0061dd fix(config): do not suppress recovery retry after failed backup resto… · openclaw/openclaw@5d174a5 chore: release 2026.5.25 fix(installer): support alpine cli installs · openclaw/openclaw@f68ed72 test(agents): keep runtime-plan provider mock current fix(scripts): launch env package scripts on Windows · openclaw/openclaw@4d4ce9e fix(agents): cache fallback provider resolution · openclaw/openclaw@3c8d101 fix(test): make import timing scripts Windows-safe · openclaw/openclaw@8ae9977 fix(telegram): transient Telegram pairing prompts (#85555) · openclaw/openclaw@8209426 fix(test): make max Vitest scripts Windows-safe · openclaw/openclaw@b681d5d fix(doctor): migrate Feishu account bot names (#86081) · openclaw/openclaw@9e8cc7e fix(scripts): prefilter conflict marker scans docs: add ClawSweeper review policy to AGENTS (#86197) · openclaw/openclaw@242e876 fix(installer): avoid before with npm release-age configs (#85491) · openclaw/openclaw@4742db6 fix(e2e): retry Windows kitchen sink probes · openclaw/openclaw@3e275a5 fix(installer): install node with apk on alpine fix(installer): detect musl linux shells · openclaw/openclaw@acfed37 perf(plugins,gateway): thread metadata snapshot + discovery through h… · openclaw/openclaw@8ccb11c fix(ui): split control ui runtime chunks · openclaw/openclaw@8bf4f7d refactor(config): extract GoogleChat schema into zod-schema.providers… · openclaw/openclaw@fe34141 fix(update): suppress internal handoff version warnings · openclaw/openclaw@6cc8244 test(e2e): select installable bundled plugins · openclaw/openclaw@0acc3e3 fix(scripts): harden Windows native opus install · openclaw/openclaw@43252c8 fix(agents): match runtime policy entries when session provider is em… fix(scripts): harden Windows generated formatting · openclaw/openclaw@0a98559 fix(mcp): bound tools/list during catalog discovery (#85063) · openclaw/openclaw@07f500a fix(test): focus plugin binding Docker smoke · openclaw/openclaw@dfa1a51 test(e2e): fail release memory indexing errors test(daemon): fail launchd integration bootstrap errors · openclaw/openclaw@af07769 feat(imessage): support thumb approval reactions (#85952) · openclaw/openclaw@5c7980f fix(crabbox): default macos aws runs on demand fix(scripts): preserve test passthrough args · openclaw/openclaw@e4332f7 fix(e2e): harden Windows plugin assertions fix(test): mount upgrade survivor helper · openclaw/openclaw@5f03154 fix(android): prevent stale chat during session switches fix(android): keep permission setup action visible · openclaw/openclaw@94bc18a style(android): sharpen voice mode surfaces · openclaw/openclaw@c452510 fix(android): hide internal chat content blocks · openclaw/openclaw@d86ed21 style(android): refine list surface spacing · openclaw/openclaw@955909c feat(android): add pair new gateway action · openclaw/openclaw@cc5eb97 Advance iMessage catchup cursor after live handling (#85475) · openclaw/openclaw@102555c fix(scripts): ignore forwarded arg separator · openclaw/openclaw@79ee70c fix(test): fail empty gateway startup samples · openclaw/openclaw@5a8ce6a fix(e2e): harden Windows kitchen sink assertions · openclaw/openclaw@87a2eba fix(e2e): harden Telegram credential paths on Windows · openclaw/openclaw@c643370 fix(android): align setup pairing scopes fix(android): complete qr setup operator handoff · openclaw/openclaw@be9bb77 fix(test): copy cleanup smoke prepare hook · openclaw/openclaw@dbc08f6 fix(secrets): allow hash in exec SecretRef ids (#86072) · openclaw/openclaw@675158c fix(media): use static image compression metadata · openclaw/openclaw@694d45e fix(release): verify large plugin npm packs fix(test): require kitchen sink diagnostic canaries · openclaw/openclaw@7e51f83 fix(scripts): harden Windows upgrade survivor recipe · openclaw/openclaw@483d7be fix(installer): count verify progress stage fix: Refine PR template for review state (#86054) fix(test): repair split agent shard runs · openclaw/openclaw@125d82c fix(codex): harden Windows protocol formatting · openclaw/openclaw@ce48e4c fix(openrouter): use endpoint context limits (#86041) · openclaw/openclaw@dd01a2e test(qa): remove brittle capability flip setup turn fix(telegram): migrate legacy cache sidecars · openclaw/openclaw@eb9b882 fix(telegram): migrate account topic cache sidecars · openclaw/openclaw@5cfb12f fix(scripts): harden Windows ZAI fallback repro · openclaw/openclaw@5be62e7 style(android): sharpen v2 screen rhythm · openclaw/openclaw@400d90a test(qa): extend capability flip setup budget · openclaw/openclaw@c91c3c6 fix(android): simplify gateway status copy fix(android): route offline voice to gateway setup fix(scripts): harden Windows control UI i18n commands · openclaw/openclaw@581c8a6 fix(android): stop operator chat subscription · openclaw/openclaw@5c15859 fix(test): fail missing kitchen sink rss samples test(qa): widen capability flip restart budget · openclaw/openclaw@c7d4e9e fix(android): smooth gateway pairing recovery · openclaw/openclaw@60e6ccd fix(test): suppress rolldown timing noise · openclaw/openclaw@6d9b388 style(android): fix talk mode ktlint formatting · openclaw/openclaw@01b284c fix(telegram): store topic cache in plugin state fix(telegram): store bot info cache in plugin state · openclaw/openclaw@2ed5296 fix(test): sync sparse AWS Crabbox runs from full checkout · openclaw/openclaw@0f82c81 fix(release): harden Windows cross-os command shims · openclaw/openclaw@7154767 fix(test): harden Docker resource ceilings test(telegram): keep startup limiter coverage focused test(telegram): isolate startup probe limiter timing · openclaw/openclaw@04d86e0 test(release): harden plugin prerelease checks · openclaw/openclaw@578e73f
fix(scripts): prebuild gateway cpu bench · openclaw/openclaw@ca70015
vincentkoc · 2026-05-25 · via Recent Commits to openclaw:main

@@ -1,9 +1,10 @@

11

#!/usr/bin/env node

223-

import { spawnSync } from "node:child_process";

3+

import { spawnSync as defaultSpawnSync } from "node:child_process";

44

import fs from "node:fs";

55

import path from "node:path";

66

import process from "node:process";

7+

import { pathToFileURL } from "node:url";

78

import { collectGatewayCpuObservations } from "./lib/plugin-gateway-gauntlet.mjs";

89

import { createPnpmRunnerSpawnSpec } from "./pnpm-runner.mjs";

910

@@ -137,9 +138,10 @@ function readJsonIfExists(filePath) {

137138

return JSON.parse(fs.readFileSync(filePath, "utf8"));

138139

}

139140140-

function runStep(name, command, args, options = {}) {

141+

function runStep(name, command, args, options = {}, params = {}) {

141142

console.error(`[gateway-cpu] start ${name}`);

142-

const result = spawnSync(command, args, {

143+

const spawn = params.spawnSync ?? defaultSpawnSync;

144+

const result = spawn(command, args, {

143145

cwd: process.cwd(),

144146

env: process.env,

145147

stdio: "inherit",

@@ -167,8 +169,7 @@ function toRepoRelativePath(absolutePath) {

167169

return relativePath;

168170

}

169171170-

async function main() {

171-

const options = parseArgs(process.argv.slice(2));

172+

async function runGatewayCpuScenarios(options, params = {}) {

172173

fs.mkdirSync(options.outputDir, { recursive: true });

173174174175

const startupOutput = path.join(options.outputDir, "gateway-startup-bench.json");

@@ -177,19 +178,35 @@ async function main() {

177178

const steps = [];

178179179180

if (!options.skipStartup) {

181+

const startupBuild = runStep(

182+

"startup build",

183+

process.execPath,

184+

["scripts/ensure-cli-startup-build.mjs"],

185+

{},

186+

params,

187+

);

188+

steps.push(startupBuild);

180189

steps.push(

181-

runStep("startup bench", process.execPath, [

182-

"--import",

183-

"tsx",

184-

"scripts/bench-gateway-startup.ts",

185-

"--runs",

186-

String(options.runs),

187-

"--warmup",

188-

String(options.warmup),

189-

"--output",

190-

startupOutput,

191-

...options.startupCases.flatMap((id) => ["--case", id]),

192-

]),

190+

startupBuild.status === 0

191+

? runStep(

192+

"startup bench",

193+

process.execPath,

194+

[

195+

"--import",

196+

"tsx",

197+

"scripts/bench-gateway-startup.ts",

198+

"--runs",

199+

String(options.runs),

200+

"--warmup",

201+

String(options.warmup),

202+

"--output",

203+

startupOutput,

204+

...options.startupCases.flatMap((id) => ["--case", id]),

205+

],

206+

{},

207+

params,

208+

)

209+

: { name: "startup bench", signal: null, status: 1 },

193210

);

194211

}

195212

@@ -207,7 +224,7 @@ async function main() {

207224

...options.qaScenarios.flatMap((id) => ["--scenario", id]),

208225

]);

209226

steps.push(

210-

runStep("qa suite", qaCommand.command, qaCommand.args, qaCommand.options),

227+

runStep("qa suite", qaCommand.command, qaCommand.args, qaCommand.options, params),

211228

);

212229

}

213230

@@ -239,14 +256,30 @@ async function main() {

239256

};

240257

const summaryPath = path.join(options.outputDir, "summary.json");

241258

fs.writeFileSync(summaryPath, `${JSON.stringify(summary, null, 2)}\n`);

242-

console.log(JSON.stringify(summary, null, 2));

259+

if (!params.silent) {

260+

console.log(JSON.stringify(summary, null, 2));

261+

}

262+263+

const exitCode = steps.some((step) => step.status !== 0) ? 1 : 0;

264+

return { exitCode, summary };

265+

}

243266244-

if (steps.some((step) => step.status !== 0)) {

267+

async function main(params = {}) {

268+

const options = parseArgs(params.argv ?? process.argv.slice(2));

269+

const result = await runGatewayCpuScenarios(options, params);

270+

if (result.exitCode !== 0) {

245271

process.exitCode = 1;

246272

}

247273

}

248274249-

main().catch((error) => {

250-

console.error(error instanceof Error ? error.stack : String(error));

251-

process.exitCode = 1;

252-

});

275+

export const testing = {

276+

parseArgs,

277+

runGatewayCpuScenarios,

278+

};

279+280+

if (process.argv[1] && import.meta.url === pathToFileURL(process.argv[1]).href) {

281+

main().catch((error) => {

282+

console.error(error instanceof Error ? error.stack : String(error));

283+

process.exitCode = 1;

284+

});

285+

}