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

推荐订阅源

Google DeepMind News
Google DeepMind News
F
Fortinet All Blogs
阮一峰的网络日志
阮一峰的网络日志
Apple Machine Learning Research
Apple Machine Learning Research
爱范儿
爱范儿
WordPress大学
WordPress大学
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
J
Java Code Geeks
罗磊的独立博客
S
SegmentFault 最新的问题
V
V2EX
V
Visual Studio Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
美团技术团队
博客园 - 三生石上(FineUI控件)
Stack Overflow Blog
Stack Overflow Blog
Y
Y Combinator Blog
MyScale Blog
MyScale Blog
D
Docker
Google DeepMind News
Google DeepMind News
Blog — PlanetScale
Blog — PlanetScale
M
Microsoft Research Blog - Microsoft Research
Martin Fowler
Martin Fowler
S
Secure Thoughts
B
Blog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
www.infosecurity-magazine.com
www.infosecurity-magazine.com
Recent Announcements
Recent Announcements
MongoDB | Blog
MongoDB | Blog
C
Cisco Blogs
C
CERT Recently Published Vulnerability Notes
T
True Tiger Recordings
GbyAI
GbyAI
P
Proofpoint News Feed
P
Privacy International News Feed
Jina AI
Jina AI
The Cloudflare Blog
I
Intezer
AWS News Blog
AWS News Blog
Hacker News - Newest:
Hacker News - Newest: "LLM"
S
Security Archives - TechRepublic
NISL@THU
NISL@THU
The Register - Security
The Register - Security
Recent Commits to openclaw:main
Recent Commits to openclaw:main
P
Palo Alto Networks Blog
S
Schneier on Security
L
LINUX DO - 热门话题
C
CXSECURITY Database RSS Feed - CXSecurity.com
Security Latest
Security Latest
C
Cybersecurity and Infrastructure Security Agency CISA

Recent Commits to openclaw:main

fix(installer): copy portable Node into place · openclaw/openclaw@c21ca88 fix(cli): recover replaced device approvals (#85342) · openclaw/openclaw@6ea907c test(release): align prerelease validation · openclaw/openclaw@0def3e2 fix(installer): install portable Node directory atomically · openclaw/openclaw@2890b1a fix(runtime-llm): avoid duplicate provider prefix in allowlist diagno… · openclaw/openclaw@937a756 fix(gateway): include openclaw bin in service PATH (#84475) · openclaw/openclaw@66d1d13 fix(gateway): handle concurrent launchd bootstrap restart race (#84722) · openclaw/openclaw@ba86716 feat: support pi and opencode autoreview engines · openclaw/openclaw@31a189d ci(package): gate acceptance on package integrity · openclaw/openclaw@5275929 ci(release): bypass pnpm for tsdown package build · openclaw/openclaw@fea89cd test(release): align prerelease validation baselines · openclaw/openclaw@04ebdc6 ci(release): harden docker package build · openclaw/openclaw@7b1fbe1 fix(codex): skip native web search transcript mirroring (#85346) · openclaw/openclaw@c3531fc fix(gateway): harden launchd reload handoff race recovery (#84641) · openclaw/openclaw@fc7a531 fix: honor per-model provider transport overrides (#80488) fix(skills): dedupe shared-directory watchers across agent workspaces… · openclaw/openclaw@3e94290 fix(skills): type watcher mock calls in dedupe regression tests · openclaw/openclaw@bb73f0a fix(skills): document watcher edge cases, add teardown/rebuild tests,… · openclaw/openclaw@19ff77e fix(infra): allow macos browser open over ssh env (#85340) · openclaw/openclaw@47d66fe fix(update): preserve package service state during cutover (#83026) · openclaw/openclaw@a15797a fix(gateway): broadcast agent-run error payloads (#85355) · openclaw/openclaw@07e61fc test(e2e): avoid synthetic channel config in plugin smoke fix(cli): suppress systemd hints for live gateway (#85336) · openclaw/openclaw@a00c583 fix(cli): honor agent for model auth logout (#85326) · openclaw/openclaw@fc47c1f fix(gateway): eager-load lifecycle runtime to survive in-place upgrad… · openclaw/openclaw@4a91385 fix(doctor): point codex asset warning at migrate plan (#85324) fix(update): harden managed handoff cwd (#83875) · openclaw/openclaw@1bafc23 docs(release): prepare 2026.5.21 notes ci(crabbox): harden docker hydration refactor(crabbox): parse provider list from binary help instead of ha… test(plugins): run kitchen sink rpc lane without tsx test(plugins): keep rpc source walk on source call gateway test(plugins): add kitchen sink rpc docker lane · openclaw/openclaw@6f6da5f test(qa-lab): add bus tool trace scenario · openclaw/openclaw@2b39613 fix(cron): classify network retry errors (#85344) fix(installer): bootstrap portable Windows Node · openclaw/openclaw@3551e98 fix(ui): move chat session search into picker (#85303) · openclaw/openclaw@1fdc73a chore: refresh shrinkwrap metadata fix: keep bundled plugin peers nested · openclaw/openclaw@86faf65 chore: add shrinkwrap to plugin npm packages · openclaw/openclaw@b6c8807 fix: publish explicit plugin bundled dependencies · openclaw/openclaw@976da39 fix: include plugin shrinkwraps in dependency reports · openclaw/openclaw@82f69a2 fix: honor shrinkwrap when bundling plugin deps feat: bundle plugin npm dependencies · openclaw/openclaw@de022bb chore: refresh shrinkwrap for Testbox npm · openclaw/openclaw@b2dc449 fix: make bundled plugin packages portable fix: opt codex out of bundled runtime deps · openclaw/openclaw@fcecbd8 fix: cover plugin package locks in dependency review · openclaw/openclaw@bfa5b39 fix: honor overrides in npm shrinkwrap generation · openclaw/openclaw@0d28040 test: refresh shrinkwrap after rebase · openclaw/openclaw@8b0537c chore: harden npm shrinkwrap release path fix: opt acpx out of bundled runtime deps · openclaw/openclaw@9914e25 test: update shrinkwrap packaging expectations · openclaw/openclaw@a1b05aa fix: limit subagent bootstrap defaults · openclaw/openclaw@56308a7 feat: update autoreview engine coverage · openclaw/openclaw@ab1fedb fix(messages): strip unsupported citation markers (#85204) (thanks @n… · openclaw/openclaw@0a95e53 test(qa-lab): report live transport coverage lanes · openclaw/openclaw@fda0baf fix(gateway): close child ACP sessions on parent reset/delete · openclaw/openclaw@136c927 fix: preserve Google Gemini 3 cron thinking (#85300) docs(skills): exclude SDK boundary bug sweeps · openclaw/openclaw@85e468d feat(plugin-sdk): add generic channel poll sender (#85299) · openclaw/openclaw@c9a0f03 fix(agents): preserve OpenAI reasoning token usage · openclaw/openclaw@0ddf51c test(e2e): harden plugin smoke cleanup fix(plugins): resolve native plugin sdk aliases (#85298) · openclaw/openclaw@6b1c868 fix(update): keep service logs out of json output · openclaw/openclaw@03f61cd fix(agent): retry transient gateway handshake closes · openclaw/openclaw@ff79299 fix(codex): keep interrupted turns visible-answer eligible (#84494) · openclaw/openclaw@8523e09 test(agents): narrow bundle mcp e2e setup · openclaw/openclaw@6bd430e test: add mocked Control UI E2E tests and playwright for local verifi… fix(code-mode): return structured worker error codes · openclaw/openclaw@edab653 fix: land code-mode structured worker errors (#83444) (thanks @Kaspre) · openclaw/openclaw@70dd315 fix: preserve route-bound direct thread events · openclaw/openclaw@0d8c9ca fix: route direct thread event wakes to main DMs · openclaw/openclaw@0acfb7b test: align exec event routing proof (#83743) (thanks @Kaspre) · openclaw/openclaw@7b48956 fix: break plugin metadata snapshot cycle · openclaw/openclaw@4ee8a2a fix heartbeat event routing for main-scoped DMs test node exec event wake metadata · openclaw/openclaw@37207c6 test(plugins): retry bundled smoke health probes test(gateway): bind auth-free websocket harness to loopback · openclaw/openclaw@2b1c01f test(plugins): keep npm peer prune mock directory-safe · openclaw/openclaw@a12e302 chore(ui): refresh fa control ui locale fix(ci): allow release update restarts · openclaw/openclaw@b859654 chore(ui): refresh nl control ui locale · openclaw/openclaw@cc6d222 chore(ui): refresh vi control ui locale · openclaw/openclaw@b59ab5b chore(ui): refresh th control ui locale · openclaw/openclaw@f483f59 chore(ui): refresh id control ui locale · openclaw/openclaw@c222ef0 chore(ui): refresh pl control ui locale · openclaw/openclaw@0050b8e chore(ui): refresh uk control ui locale · openclaw/openclaw@6b4aec9 chore(ui): refresh tr control ui locale · openclaw/openclaw@940a950 chore(ui): refresh ar control ui locale · openclaw/openclaw@d11c2e4 chore(ui): refresh it control ui locale · openclaw/openclaw@c99a29d chore(ui): refresh fr control ui locale · openclaw/openclaw@a7ba47c chore(ui): refresh ko control ui locale · openclaw/openclaw@a5fa944 chore(ui): refresh ja-JP control ui locale · openclaw/openclaw@f3a984d chore(ui): refresh es control ui locale · openclaw/openclaw@4711bb5 chore(ui): refresh zh-TW control ui locale · openclaw/openclaw@4d6b384 chore(ui): refresh pt-BR control ui locale · openclaw/openclaw@d6fc2f3 chore(ui): refresh zh-CN control ui locale · openclaw/openclaw@3222e35 chore(ui): refresh de control ui locale · openclaw/openclaw@ea5b5d7 Add chat picker search and pagination · openclaw/openclaw@5d01be1
fix(cli): preserve first line of channels logs at window boundary (#8… · openclaw/openclaw@b7ba7c3
BSG2000 · 2026-05-19 · via Recent Commits to openclaw:main

@@ -141,6 +141,65 @@ describe("channelsLogsCommand", () => {

141141

expect(payload.lines.map((line) => line.message)).toEqual(["current sent"]);

142142

});

143143144+

it("returns the first line of the tail window when start aligns with a line boundary", async () => {

145+

// MAX_BYTES in readTailLines is 1_000_000. We build a file of 2_000_000 bytes

146+

// made of 10_000 lines each exactly 200 bytes (199 payload + "\n"), so the

147+

// read window starts at byte offset 1_000_000 which is exactly on a line

148+

// boundary (byte 999_999 is the trailing "\n" of the previous line).

149+

// Without checking the byte before the window, readTailLines drops line 5000 silently.

150+

const LINE_SIZE = 200;

151+

const TOTAL_LINES = 10_000;

152+

const FIRST_INDEX = 5000; // first line of the tail window after alignment

153+154+

const buildLine = (message: string) => {

155+

const base = logLine({

156+

module: "gateway/channels/slack/send",

157+

message,

158+

});

159+

const payloadLen = LINE_SIZE - 1; // reserve 1 byte for newline

160+

// Re-emit with a padded message so total byte length is constant.

161+

const padNeeded = payloadLen - Buffer.byteLength(base);

162+

if (padNeeded < 0) {

163+

throw new Error(`base log line too long: ${Buffer.byteLength(base)} > ${payloadLen}`);

164+

}

165+

const padded = logLine({

166+

module: "gateway/channels/slack/send",

167+

message: message + " ".repeat(padNeeded),

168+

});

169+

if (Buffer.byteLength(padded) !== payloadLen) {

170+

throw new Error(`padded line wrong size: ${Buffer.byteLength(padded)} vs ${payloadLen}`);

171+

}

172+

return padded + "\n";

173+

};

174+175+

const handle = await fs.open(logPath, "w");

176+

try {

177+

for (let i = 0; i < TOTAL_LINES; i++) {

178+

let message: string;

179+

if (i === FIRST_INDEX) {

180+

message = "first-line-in-window";

181+

} else if (i === TOTAL_LINES - 1) {

182+

message = "last-line";

183+

} else {

184+

message = "filler";

185+

}

186+

await handle.write(buildLine(message));

187+

}

188+

} finally {

189+

await handle.close();

190+

}

191+192+

await channelsLogsCommand(

193+

{ channel: "slack", json: true, lines: String(TOTAL_LINES) },

194+

runtime,

195+

);

196+197+

const payload = readJsonPayload();

198+

const messages = payload.lines.map((line) => line.message.trimEnd());

199+

expect(messages[0]).toBe("first-line-in-window");

200+

expect(messages[messages.length - 1]).toBe("last-line");

201+

});

202+144203

it("does not fall back to rolling logs for a missing custom log file", async () => {

145204

const configuredFile = path.join(tempDir, "custom-channel.log");

146205

const fallbackFile = path.join(tempDir, "openclaw-2026-04-25.log");