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

推荐订阅源

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: prevent plain text tool call leaks (#86222) fix: handle npm min-release-age in installers fix(scripts): include ui:build in build-all full and ciArtifacts prof… · openclaw/openclaw@6704d0a fix(e2e): sample Windows kitchen sink gateway RSS · openclaw/openclaw@73189e3 fix(cron): respect isolated target and error on missing remove id (#8… · openclaw/openclaw@6709f4e fix(pi-embedded-runner): propagate trigger-derived priority to the gl… · openclaw/openclaw@0580f57 fix(cli): suppress self-update version warnings · openclaw/openclaw@e2bd20f fix: preserve webchat source reply details · openclaw/openclaw@aa50c51 docs: replace OpenClaw docs skill and add plugin permissions guide · openclaw/openclaw@0dabb70 fix(codex): preserve source reply mode for active runs (#86325) · openclaw/openclaw@b962110 fix: make compaction reinjection opt-in · openclaw/openclaw@ab910f8 fix codex usage-limit recovery copy (#86305) · openclaw/openclaw@c3c8a65 feat(ui): add ephemeral Activity tab · openclaw/openclaw@3dd0e8e fix(tests): harden native macos plugin proof · openclaw/openclaw@a5d5604 fix(commitments): serialize load-modify-save with in-process queue + … · openclaw/openclaw@d3c293d Fail Codex compaction at the Codex boundary (#85958) · openclaw/openclaw@dd47e47 fix(docker): restore config parent ownership · openclaw/openclaw@908b894 docs: clarify config default review policy (#86329) · openclaw/openclaw@3a03dd5 docs: clean changelog script entries · openclaw/openclaw@0eead19 fix(scripts): budget restart benchmark timeouts · openclaw/openclaw@5bd5509 fix: align ui vitest config assertion · openclaw/openclaw@730fd19 fix: route unit ui vitest targets narrowly · openclaw/openclaw@777402e fix: route explicit ui vitest targets narrowly · openclaw/openclaw@56a383c fix(android): harden play media permission removal fix(webchat): stabilize live transcript run state · openclaw/openclaw@119a01c fix(scripts): fail restart benchmark regressions · openclaw/openclaw@95d1b39 fix(openai): scope external codex auth to realtime fix(openai): prefer codex auth for GPT realtime · openclaw/openclaw@48c4f57 fix(openai): discover codex cli auth for provider checks · openclaw/openclaw@4656275 fix(android): keep talk mode on realtime relay · openclaw/openclaw@70614f8 test(android): add gateway connect adb probe · openclaw/openclaw@d7aa1f3 fix(android): stabilize realtime talk connection state · openclaw/openclaw@ffb02a5 test(android): add voice mode adb e2e harness · openclaw/openclaw@e52a3b3 fix(ci): stabilize deadcode and catalog checks · openclaw/openclaw@3db1508 fix(scripts): prebuild gateway cpu bench · openclaw/openclaw@ca70015 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(perf): fail startup bench on early gateway exit · openclaw/openclaw@a8fc28c
vincentkoc · 2026-05-25 · via Recent Commits to openclaw:main

@@ -1,10 +1,11 @@

11

import { spawnSync } from "node:child_process";

2+

import { EventEmitter } from "node:events";

23

import fs from "node:fs";

34

import { createServer } from "node:http";

45

import os from "node:os";

56

import path from "node:path";

67

import { performance } from "node:perf_hooks";

7-

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

8+

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

89

import { testing } from "../../scripts/bench-gateway-startup.ts";

9101011

async function listenOnLoopback(handler: Parameters<typeof createServer>[0]) {

@@ -154,6 +155,176 @@ describe("gateway startup benchmark script", () => {

154155

]);

155156

});

156157158+

it("flags samples that become ready and then exit nonzero", () => {

159+

const result = testing.summarizeCase({ config: {}, id: "demo", name: "demo" }, [

160+

{

161+

cpuCoreRatio: 0.5,

162+

cpuMs: 100,

163+

exitedBeforeTeardown: true,

164+

exitCode: 1,

165+

firstOutputMs: 1,

166+

gatewayReadyLogLine: "[gateway] ready",

167+

gatewayReadyLogMs: 20,

168+

healthz: {

169+

firstErrorKind: "econnrefused",

170+

firstRecoveryMs: 10,

171+

ms: 10,

172+

status: 200,

173+

transitions: [],

174+

},

175+

httpListenLogLine: "[gateway] http server listening (0 plugins)",

176+

httpListenLogMs: 5,

177+

maxRssMb: 120,

178+

outputTail: "ready\\nError: startup sidecar crashed",

179+

readyz: {

180+

firstErrorKind: "http-503",

181+

firstRecoveryMs: 18,

182+

ms: 18,

183+

status: 200,

184+

transitions: [],

185+

},

186+

signal: null,

187+

startupTrace: {},

188+

},

189+

]);

190+191+

expect(testing.collectResultFailures([result], { processMetricsRequired: true })).toEqual([

192+

{

193+

id: "demo",

194+

reason: "child exited 1",

195+

sampleIndex: 1,

196+

},

197+

]);

198+

});

199+200+

it("does not flag nonzero exits from intentional teardown", () => {

201+

const result = testing.summarizeCase({ config: {}, id: "demo", name: "demo" }, [

202+

{

203+

cpuCoreRatio: 0.5,

204+

cpuMs: 100,

205+

exitedBeforeTeardown: false,

206+

exitCode: 1,

207+

firstOutputMs: 1,

208+

gatewayReadyLogLine: "[gateway] ready",

209+

gatewayReadyLogMs: 20,

210+

healthz: {

211+

firstErrorKind: "econnrefused",

212+

firstRecoveryMs: 10,

213+

ms: 10,

214+

status: 200,

215+

transitions: [],

216+

},

217+

httpListenLogLine: "[gateway] http server listening (0 plugins)",

218+

httpListenLogMs: 5,

219+

maxRssMb: 120,

220+

outputTail: "",

221+

readyz: {

222+

firstErrorKind: "http-503",

223+

firstRecoveryMs: 18,

224+

ms: 18,

225+

status: 200,

226+

transitions: [],

227+

},

228+

signal: null,

229+

startupTrace: {},

230+

},

231+

]);

232+233+

expect(testing.collectResultFailures([result], { processMetricsRequired: true })).toEqual([]);

234+

});

235+236+

it("flags samples that become ready and then die from a signal", () => {

237+

const result = testing.summarizeCase({ config: {}, id: "demo", name: "demo" }, [

238+

{

239+

cpuCoreRatio: 0.5,

240+

cpuMs: 100,

241+

exitedBeforeTeardown: true,

242+

exitCode: null,

243+

firstOutputMs: 1,

244+

gatewayReadyLogLine: "[gateway] ready",

245+

gatewayReadyLogMs: 20,

246+

healthz: {

247+

firstErrorKind: "econnrefused",

248+

firstRecoveryMs: 10,

249+

ms: 10,

250+

status: 200,

251+

transitions: [],

252+

},

253+

httpListenLogLine: "[gateway] http server listening (0 plugins)",

254+

httpListenLogMs: 5,

255+

maxRssMb: 120,

256+

outputTail: "ready\\nsegmentation fault",

257+

readyz: {

258+

firstErrorKind: "http-503",

259+

firstRecoveryMs: 18,

260+

ms: 18,

261+

status: 200,

262+

transitions: [],

263+

},

264+

signal: "SIGSEGV",

265+

startupTrace: {},

266+

},

267+

]);

268+269+

expect(testing.collectResultFailures([result], { processMetricsRequired: true })).toEqual([

270+

{

271+

id: "demo",

272+

reason: "child exited by SIGSEGV",

273+

sampleIndex: 1,

274+

},

275+

]);

276+

});

277+278+

it("classifies queued child exits before sending teardown signals", async () => {

279+

const child = new EventEmitter() as EventEmitter & {

280+

exitCode: number | null;

281+

kill: ReturnType<typeof vi.fn>;

282+

signalCode: NodeJS.Signals | null;

283+

};

284+

child.exitCode = null;

285+

child.signalCode = null;

286+

child.kill = vi.fn(() => true);

287+288+

const stopped = testing.stopChild(child as unknown as Parameters<typeof testing.stopChild>[0]);

289+

queueMicrotask(() => {

290+

child.exitCode = 7;

291+

child.emit("exit", 7, null);

292+

});

293+294+

await expect(stopped).resolves.toEqual({

295+

exitedBeforeTeardown: true,

296+

exitCode: 7,

297+

signal: null,

298+

});

299+

expect(child.kill).not.toHaveBeenCalled();

300+

});

301+302+

it("classifies failed teardown signaling as a pre-teardown child exit", async () => {

303+

const child = new EventEmitter() as EventEmitter & {

304+

exitCode: number | null;

305+

kill: ReturnType<typeof vi.fn>;

306+

signalCode: NodeJS.Signals | null;

307+

};

308+

child.exitCode = null;

309+

child.signalCode = null;

310+

child.kill = vi.fn(() => {

311+

setImmediate(() => {

312+

child.exitCode = 8;

313+

child.emit("exit", 8, null);

314+

});

315+

return false;

316+

});

317+318+

await expect(

319+

testing.stopChild(child as unknown as Parameters<typeof testing.stopChild>[0]),

320+

).resolves.toEqual({

321+

exitedBeforeTeardown: true,

322+

exitCode: 8,

323+

signal: null,

324+

});

325+

expect(child.kill).toHaveBeenCalledWith("SIGTERM");

326+

});

327+157328

it("collects Count-suffixed startup trace metrics", () => {

158329

const startupTrace: Record<string, number> = {};

159330