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

推荐订阅源

F
Full Disclosure
Recorded Future
Recorded Future
T
Tenable Blog
S
Securelist
C
CERT Recently Published Vulnerability Notes
T
Threatpost
S
Schneier on Security
A
Arctic Wolf
The Hacker News
The Hacker News
C
CXSECURITY Database RSS Feed - CXSecurity.com
Know Your Adversary
Know Your Adversary
P
Privacy International News Feed
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
The Register - Security
The Register - Security
Cisco Talos Blog
Cisco Talos Blog
AWS News Blog
AWS News Blog
K
Kaspersky official blog
T
True Tiger Recordings
T
Threat Research - Cisco Blogs
V
Vulnerabilities – Threatpost
P
Palo Alto Networks Blog
T
The Exploit Database - CXSecurity.com
小众软件
小众软件
B
Blog
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
Microsoft Azure Blog
Microsoft Azure Blog
Cyberwarzone
Cyberwarzone
C
Cybersecurity and Infrastructure Security Agency CISA
T
Tor Project blog
Spread Privacy
Spread Privacy
Malwarebytes
Malwarebytes
P
Proofpoint News Feed
F
Fox-IT International blog
F
Fortinet All Blogs
P
Privacy & Cybersecurity Law Blog
G
GRAHAM CLULEY
量子位
Latest news
Latest news
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
博客园 - 叶小钗
Project Zero
Project Zero
T
Tailwind CSS Blog
N
Netflix TechBlog - Medium
Martin Fowler
Martin Fowler
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
I
Intezer
博客园_首页
腾讯CDC
H
Hackread – Cybersecurity News, Data Breaches, AI and More
D
Darknet – Hacking Tools, Hacker News & Cyber Security

Recent Commits to openclaw:main

fix(usage): forward cached token usage in chat completions (#82062) · openclaw/openclaw@12e5876 perf(gateway): cache stable plugin index fingerprints · openclaw/openclaw@2babe03 test(codex): align provider claim expectation · openclaw/openclaw@42387af fix(test): scan kitchen rpc readiness logs incrementally · openclaw/openclaw@1d4537a fix(test): fail startup bench on bad samples · openclaw/openclaw@8c6da93 fix(onboard): preserve agents.list and bindings on rerun · openclaw/openclaw@bbdff39 fix: send bare direct Anthropic model ids · openclaw/openclaw@aa0a290 fix(deepinfra): load all DeepInfra models when user wants to browse t… fix(qa): harden Matrix tool progress scenario · openclaw/openclaw@32b3fb6 fix(package): match npm globstar exclusions · openclaw/openclaw@f4bcd61 fix(package): honor dist package exclusions in inventory · openclaw/openclaw@296fbde fix: preserve channel runResolved mock compatibility · openclaw/openclaw@c89298f fix(test): bound config reload log polling · openclaw/openclaw@329dad2 fix(lint): preserve JSONL parse cause · openclaw/openclaw@d6949d5 test(e2e): preserve macos smoke entrypoint path · openclaw/openclaw@5eba765 fix(test): await mcp timeout cleanup · openclaw/openclaw@109ba23 fix(test): harden mcp channel ws timeout · openclaw/openclaw@a4a75a8 fix(test): harden gateway network ws timeout · openclaw/openclaw@e50b20f fix(agents/harness): validate forced plugin harness support before pi… · openclaw/openclaw@730ac1a test: align extension inbound context assertions · openclaw/openclaw@98c0ad8 fix(install): skip Homebrew until macOS packages need it · openclaw/openclaw@527b7c2 fix(ci): bound additional boundary checks · openclaw/openclaw@351aac9 fix(release): reject empty beta smoke runs · openclaw/openclaw@4dfc2cf fix(build): cap tsdown heap in containers · openclaw/openclaw@e8dde30 fix(docker): skip declarations in runtime packages · openclaw/openclaw@cc662ba fix(package): omit unpacked test helpers from inventory · openclaw/openclaw@6c42fea fix(crabbox): reinitialize invalid changed-gate git dirs · openclaw/openclaw@ecdc925 fix(lint): shard core lint checks · openclaw/openclaw@1ba4448 fix(lint): cap oxlint helper memory locally · openclaw/openclaw@8caa44f fix(lint): split source lint shards · openclaw/openclaw@158bc69 fix(crabbox): full-sync local sparse container runs · openclaw/openclaw@b3e3b1b fix(test): enable live cache script gates · openclaw/openclaw@72c6813 fix(test): reject unknown live media providers · openclaw/openclaw@51dd548 fix(cli): reject loose model and gateway numeric options · openclaw/openclaw@6b391ef refactor: centralize inbound supplemental context · openclaw/openclaw@1507a97 fix(test): reject empty gateway cpu runs · openclaw/openclaw@ad3d197 fix(test): fail empty plugin gauntlet runs · openclaw/openclaw@b460ee4 fix: load Claude CLI OAuth for PI auth profiles (#87167) · openclaw/openclaw@cc704ca fix(agents): ignore failed subagent placeholders fix(agents): report approval resolutions in bridge mode · openclaw/openclaw@88bbc5b fix(qa): keep fallback delivery on latest targets fix(agents): preserve bridge hook context · openclaw/openclaw@2c3190d fix(qa): close remaining mock qa e2e regressions · openclaw/openclaw@14198a1 fix(qa): isolate mock bridge hook state · openclaw/openclaw@35248be fix(qa): stabilize mock QA scenario contracts · openclaw/openclaw@81c1892 fix(agents): classify direct fallback targets by channel grammar · openclaw/openclaw@79f7b93 fix(qa): scope mock image prompts to latest turn · openclaw/openclaw@c2d059d fix(agents): suppress Write/Edit failed warning on response-timeout f… · openclaw/openclaw@7e702bb fix(cron): surface classified run failure causes · openclaw/openclaw@3104f36 fix(test): fail empty extension test requests · openclaw/openclaw@57b1c0b fix(cli): reject loose numeric options · openclaw/openclaw@c95d348 docs(providers/openai): clarify OpenAI Realtime Platform credits · openclaw/openclaw@717003a fix(codex): keep attempt watchdog for queued terminal turns · openclaw/openclaw@ca990f2 fix(qqbot): gate fallback approval buttons (#87154) · openclaw/openclaw@08a73db fix(test): fail explicit empty vitest runs · openclaw/openclaw@7615c31 ci: fall back from stale workflow dispatch refs · openclaw/openclaw@8d99037 fix(lint): serialize oxlint shards on constrained hosts · openclaw/openclaw@c93b7d8 fix: reject partial numeric CLI options fix(agents): avoid duplicate Claude CLI skill prompts · openclaw/openclaw@f4e20f8 test: harden e2e instance package fixture fix(codex): preserve raw reasoning source-reply guard · openclaw/openclaw@284098d test(codex): verify completion idle watch arms after non-assistant ra… · openclaw/openclaw@4d6bcf9 fix(codex): keep raw assistant release path intact · openclaw/openclaw@4314ead test(codex): mirror raw reasoning event order · openclaw/openclaw@e718d47 fix(codex): arm completion idle watch after rawResponseItem/completed… · openclaw/openclaw@a36c82b fix(node-host): restart stale node host on version mismatch · openclaw/openclaw@819fd9f fix(e2e): bound tool search gateway proof · openclaw/openclaw@761c802 fix(discord): harden requester checks for guild actions · openclaw/openclaw@9ed1b02 fix: let skills JSON output flush naturally · openclaw/openclaw@84b1123 fix: support plugin generated help targets · openclaw/openclaw@ec377dd fix: route generated help targets to subcommands · openclaw/openclaw@1de9848 fix: validate gateway call timeouts · openclaw/openclaw@f407e4e fix: mark plugin command groups in root help · openclaw/openclaw@482018e fix: route nested root help targets · openclaw/openclaw@2bbef6c fix: keep root help plugin descriptor loading quiet · openclaw/openclaw@ef2ebee fix: preserve root options in generated help · openclaw/openclaw@b31c9e9 fix: route root help targets to command help · openclaw/openclaw@5f6293a fix: normalize generated help self-help · openclaw/openclaw@9015d0c perf(secrets): propagate snapshots and eliminate esm side-effects in … test: stabilize main ci lanes · openclaw/openclaw@f327df8 perf(gateway): keep agent session working store active-only · openclaw/openclaw@54eca3f test(e2e): harden shell helper env assertions · openclaw/openclaw@e6937f9 fix(doctor): warn on unsupported active tool schemas · openclaw/openclaw@4976851 test: fix main ci expectations · openclaw/openclaw@3684696 fix(e2e): bound Telegram credential setup · openclaw/openclaw@9b28603 perf(gateway): borrow agent session lookup safely · openclaw/openclaw@3b9fa16 fix(crabbox): prefer Azure for Windows targets (#87186) · openclaw/openclaw@6afe3e8 test(e2e): isolate shell helper env · openclaw/openclaw@b28f9e0 fix(e2e): bound MCP channel connect · openclaw/openclaw@aa40174 perf(gateway): borrow read-only session metadata · openclaw/openclaw@8c8162f fix(gateway): persist model auth profile suffixes · openclaw/openclaw@152f68d fix(googlechat): suppress thread sends in DMs · openclaw/openclaw@da822dd Fix embedded session file ownership race (#87159) · openclaw/openclaw@3349fe2 ci(ui): refresh raw copy baseline · openclaw/openclaw@ebe09be fix(pi-embedded): route Codex OAuth compaction through OpenAI-Codex · openclaw/openclaw@1710dac fix(commands): enforce /allowlist configWrites origin policy · openclaw/openclaw@ce64d74 fix(plugin-sdk): stop exporting vitest test helpers (#87120) · openclaw/openclaw@780bc79 perf(gateway): borrow session reads on turn hot paths · openclaw/openclaw@9c2a6a8 fix(reply): keep visible turn admission unbounded (#87044) · openclaw/openclaw@455d5e8 fix(e2e): bound Telegram proof Bot API calls · openclaw/openclaw@4b40197
fix(test): bound codex media path log polling · openclaw/openclaw@40a2600
vincentkoc · 2026-05-27 · via Recent Commits to openclaw:main

@@ -0,0 +1,127 @@

1+

import { EventEmitter } from "node:events";

2+

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

3+

import { tmpdir } from "node:os";

4+

import path from "node:path";

5+

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

6+

import { createJsonlRequestTailer } from "../../scripts/e2e/lib/codex-media-path/jsonl-request-tail.mjs";

7+

import { waitForWebSocketOpen } from "../../scripts/e2e/lib/codex-media-path/open-websocket.mjs";

8+9+

const tempRoots: string[] = [];

10+11+

function makeTempRoot(): string {

12+

const root = mkdtempSync(path.join(tmpdir(), "openclaw-codex-media-path-"));

13+

tempRoots.push(root);

14+

return root;

15+

}

16+17+

function jsonl(value: unknown): string {

18+

return `${JSON.stringify(value)}\n`;

19+

}

20+21+

class FakeWebSocket extends EventEmitter {

22+

terminated = false;

23+

closed = false;

24+25+

terminate(): void {

26+

this.terminated = true;

27+

queueMicrotask(() => {

28+

this.emit("error", new Error("socket abort after terminate"));

29+

this.emit("close");

30+

});

31+

}

32+33+

close(): void {

34+

this.closed = true;

35+

}

36+

}

37+38+

afterEach(() => {

39+

for (const root of tempRoots.splice(0)) {

40+

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

41+

}

42+

});

43+44+

describe("codex media path JSONL tailer", () => {

45+

it("keeps parsed app-server requests and reads only appended lines", () => {

46+

const logPath = path.join(makeTempRoot(), "app-server.jsonl");

47+

const tailer = createJsonlRequestTailer(logPath, { maxReadBytes: 1024, historyLimit: 10 });

48+49+

expect(tailer.read()).toEqual([]);

50+51+

writeFileSync(logPath, jsonl({ method: "initialize" }));

52+

expect(tailer.read()).toEqual([{ method: "initialize" }]);

53+54+

appendFileSync(logPath, JSON.stringify({ method: "turn/start" }));

55+

expect(tailer.read()).toEqual([{ method: "initialize" }]);

56+57+

appendFileSync(logPath, "\n");

58+

expect(tailer.read()).toEqual([{ method: "initialize" }, { method: "turn/start" }]);

59+

});

60+61+

it("starts from a bounded tail of oversized logs", () => {

62+

const logPath = path.join(makeTempRoot(), "app-server.jsonl");

63+

const lastLine = jsonl({ method: "turn/start" });

64+

writeFileSync(logPath, `${"x".repeat(256)}\n${jsonl({ method: "old" })}${lastLine}`);

65+66+

const tailer = createJsonlRequestTailer(logPath, {

67+

maxReadBytes: lastLine.length + 2,

68+

historyLimit: 10,

69+

});

70+71+

expect(tailer.read()).toEqual([{ method: "turn/start" }]);

72+

});

73+74+

it("keeps a complete line when the bounded tail starts on its boundary", () => {

75+

const logPath = path.join(makeTempRoot(), "app-server.jsonl");

76+

const lastLine = jsonl({ method: "turn/start" });

77+

writeFileSync(logPath, `${"x".repeat(256)}\n${lastLine}`);

78+79+

const tailer = createJsonlRequestTailer(logPath, {

80+

maxReadBytes: lastLine.length,

81+

historyLimit: 10,

82+

});

83+84+

expect(tailer.read()).toEqual([{ method: "turn/start" }]);

85+

});

86+87+

it("resets request history when the app-server log is truncated", () => {

88+

const logPath = path.join(makeTempRoot(), "app-server.jsonl");

89+

const tailer = createJsonlRequestTailer(logPath, { maxReadBytes: 1024, historyLimit: 10 });

90+91+

writeFileSync(logPath, jsonl({ method: "initialize", payload: "long enough to rotate" }));

92+

expect(tailer.read()).toEqual([{ method: "initialize", payload: "long enough to rotate" }]);

93+94+

writeFileSync(logPath, jsonl({ method: "turn/start" }));

95+

expect(tailer.read()).toEqual([{ method: "turn/start" }]);

96+

});

97+

});

98+99+

describe("codex media path WebSocket open guard", () => {

100+

it("terminates sockets that never open", async () => {

101+

const ws = new FakeWebSocket();

102+

const keepAlive = setTimeout(() => {}, 100);

103+104+

try {

105+

await expect(waitForWebSocketOpen(ws, 1)).rejects.toThrow("gateway ws open timeout");

106+

} finally {

107+

clearTimeout(keepAlive);

108+

}

109+110+

expect(ws.terminated).toBe(true);

111+

await new Promise((resolve) => setImmediate(resolve));

112+

expect(ws.listenerCount("open")).toBe(0);

113+

expect(ws.listenerCount("error")).toBe(0);

114+

});

115+116+

it("cleans listeners after successful opens", async () => {

117+

const ws = new FakeWebSocket();

118+

const opened = waitForWebSocketOpen(ws, 100);

119+120+

ws.emit("open");

121+122+

await expect(opened).resolves.toBeUndefined();

123+

expect(ws.terminated).toBe(false);

124+

expect(ws.listenerCount("open")).toBe(0);

125+

expect(ws.listenerCount("error")).toBe(0);

126+

});

127+

});