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

推荐订阅源

Apple Machine Learning Research
Apple Machine Learning Research
The GitHub Blog
The GitHub Blog
Hugging Face - Blog
Hugging Face - Blog
阮一峰的网络日志
阮一峰的网络日志
爱范儿
爱范儿
量子位
宝玉的分享
宝玉的分享
人人都是产品经理
人人都是产品经理
博客园_首页
博客园 - 【当耐特】
Last Week in AI
Last Week in AI
Martin Fowler
Martin Fowler
Microsoft Azure Blog
Microsoft Azure Blog
美团技术团队
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
aimingoo的专栏
aimingoo的专栏
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
GbyAI
GbyAI
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
腾讯CDC

Recent Commits to openclaw:main

feat(diagnostics): trace gateway secret preparation (#83019) · openclaw/openclaw@4f0c902 fix(stepfun): drop stale auth choice metadata test(e2e): sample kitchen sink RSS on Windows · openclaw/openclaw@73c1e37 test(plugins): fail gauntlet on load diagnostics fix(build): preserve tsdown heap floor · openclaw/openclaw@9ff1a43 fix(tools): honor config apiKey in media tool preflight (#85570) · openclaw/openclaw@31c269f fix(e2e): support macOS script wrappers fix(ci): scope changed shrinkwrap checks · openclaw/openclaw@743fd4c chore(ui): refresh fa control ui locale chore(ui): refresh nl control ui locale · openclaw/openclaw@908464b chore(ui): refresh vi control ui locale · openclaw/openclaw@62b75f4 chore(ui): refresh th control ui locale · openclaw/openclaw@fc4ba31 chore(ui): refresh id control ui locale · openclaw/openclaw@5b1bdd1 chore(ui): refresh pl control ui locale · openclaw/openclaw@534d4b1 chore(ui): refresh uk control ui locale · openclaw/openclaw@055c3bd chore(ui): refresh ar control ui locale · openclaw/openclaw@89c5a68 chore(ui): refresh it control ui locale · openclaw/openclaw@44ca805 chore(ui): refresh tr control ui locale chore(ui): refresh fr control ui locale · openclaw/openclaw@2240b0e chore(ui): refresh ko control ui locale · openclaw/openclaw@5fa250b chore(ui): refresh ja-JP control ui locale · openclaw/openclaw@f4ea401 chore(ui): refresh es control ui locale · openclaw/openclaw@751dde0 chore(ui): refresh de control ui locale · openclaw/openclaw@72a9b5b chore(ui): refresh pt-BR control ui locale · openclaw/openclaw@501b6e0 chore(ui): refresh zh-CN control ui locale chore(ui): refresh zh-TW control ui locale · openclaw/openclaw@88dee79 Add Slack approval QA checkpoints (#85141) fix(agents): mirror internal ui message tool replies (#85564) perf(whatsapp): narrow runtime setter entry (#85589) · openclaw/openclaw@463929d fix: smooth chat focus mode layout · openclaw/openclaw@bb5abef Fix Telegram missing harness spool poison (#85605) · openclaw/openclaw@b745082 fix(session): surface previous-transcript archive failures on /new ro… · openclaw/openclaw@679a46d Policy: add agent workspace conformance checks (#85096) · openclaw/openclaw@a94f344 fix(installer): fail failed Windows git builds · openclaw/openclaw@2edd6e2 fix(codex): honor node exec policy for native surfaces (#85534) · openclaw/openclaw@e0405ec fix(qa-lab): stabilize codex runtime parity fixtures fix(github): preserve sufficient proof against negative relabel (#85567) · openclaw/openclaw@6b52dff docs: add changelog for context pressure preflight · openclaw/openclaw@5ca734f Fix context pressure preflight for tool-heavy sessions (#85541) · openclaw/openclaw@c08400e fix(doctor): classify codex asset notice as info (#85119) · openclaw/openclaw@959b935 fix(ui): keep chat picker search current (#85547) fix: preserve message-tool delivery evidence · openclaw/openclaw@f022b05 fix(codex): add API key paste auth (#85533) fix: satisfy openai video test typecheck · openclaw/openclaw@743caed fix: route openai video edits to edits endpoint · openclaw/openclaw@6c3fcb8 fix(qmd): normalize direct file collection paths (#65212) · openclaw/openclaw@227b4bf fix(testbox): preserve clean sparse checkouts · openclaw/openclaw@58e9628 fix(ui): run ui script through junction paths (#85525) · openclaw/openclaw@ad19dd8 docs: fix troubleshooting logs link (#85545) · openclaw/openclaw@60582b6 Revert chat session picker inline search (#85527) · openclaw/openclaw@d69bcfd fix: preserve guarded video operation cleanup · openclaw/openclaw@ed7d99a fix: honor openai video provider request network policy fix: retry guarded video downloads · openclaw/openclaw@efbf9f3 fix: thread openai video request policy · openclaw/openclaw@31b5145 docs(changelog): note heartbeat message-tool fix · openclaw/openclaw@c127334 fix: use fs-safe trash for agent delete (#84394) · openclaw/openclaw@951bbe6 Fix heartbeat message-tool delivery policy (#85357) · openclaw/openclaw@bd9c78f Scope config preflight note suppression (#84439) · openclaw/openclaw@91d85e7 fix(cron): document best-effort edit delivery mode (#84526) fix(dreaming): open report cards from memory palace (#85144) · openclaw/openclaw@2e15830 fix(openai-codex): preserve image input capability (#85393) · openclaw/openclaw@49ce171 fix(codex): stabilize heartbeat dynamic tool schema (#84681) · openclaw/openclaw@c52daa4 docs: absorb small documentation PRs · openclaw/openclaw@658be7f fix(scripts): preserve bws resolver parse errors (#85528) · openclaw/openclaw@13a4c57 fix(telegram): honor outbound media max bytes (#83478) · openclaw/openclaw@f2d4f93 fix(skills): restore executable bit on bundled whisper script + relea… · openclaw/openclaw@1dd3b52 fix(google): print Gemini OAuth URL before browser launch (#71469) · openclaw/openclaw@2d5bda9 docs: absorb contributor documentation fixes docs: tighten landable bug sweep gates · openclaw/openclaw@8f86383 fix: reuse provider auth lookup facts (#85499) · openclaw/openclaw@299ed80 fix: keep session picker focus separate · openclaw/openclaw@7e12370 feat: start onboarding for fresh CLI installs (#85519) · openclaw/openclaw@464ffc1 docs: refresh contributor docs · openclaw/openclaw@64d13c0 fix(update): prepack npm git update specs · openclaw/openclaw@84f6b5c fix: simplify chat session search · openclaw/openclaw@7e16a50 fix: use native mac settings sidebar · openclaw/openclaw@0556958 chore: ignore antigravity cli state · openclaw/openclaw@dd07fb4 fix(media): replace Gemini CLI fallback with sandboxed Antigravity (#… · openclaw/openclaw@0622fb6 docs: add bugbash landing changelog entries · openclaw/openclaw@faad2b0 fix(diffs): continue after card hydration errors (#84775) · openclaw/openclaw@9b5c281 fix(proxy): add missing clientSocket error handler in CONNECT tunnel … · openclaw/openclaw@e008bc9 fix(memory): report qmd workspace cwd probe failures (#63167) · openclaw/openclaw@7134a95 fix(agents): handle parallel tool call deltas in openai-completions s… test: align release validation package acceptance check (#85515) · openclaw/openclaw@423f525 fix: recover stuck Codex compaction · openclaw/openclaw@44d5330 docs: require visual proof for control ui e2e (#85513) · openclaw/openclaw@8174bfc Policy: add gateway exposure checks (#81981) · openclaw/openclaw@dcc5e45 ci: unblock advisory Tideclaw alpha release checks · openclaw/openclaw@dcfc7e5 fix(installer): tolerate WSL UNC launch cwd · openclaw/openclaw@684a9b2 docs: absorb docs sweep · openclaw/openclaw@bb5010b fix: cancel stale provider auth prewarms (#85503) · openclaw/openclaw@60e3749 Add TUI PTY integration coverage (#85485) · openclaw/openclaw@0a50cbd fix(security): escape entry.id in HTML export to prevent attribute XS… · openclaw/openclaw@7bc4a33 fix: guard openai-completions tool payload with supportsTools compat … · openclaw/openclaw@76a025c fix(slack): surface auth.test failure + normalize explicit-bot mentio… · openclaw/openclaw@995a020 chore(release): bump version to 2026.5.22 fix(ui): keep chat session search inline (#85490) · openclaw/openclaw@2601453 Policy: add secret and auth conformance checks (#81974) · openclaw/openclaw@c85feac fix(delivery): log failDelivery errors instead of silently swallowing… · openclaw/openclaw@f75789f fix(cli): validate debug proxy numeric options (#84260) · openclaw/openclaw@5c866a1
fix(diagnostics): harden observability exports and smokes (#85371) · openclaw/openclaw@7f05be0
vincentkoc · 2026-05-23 · via Recent Commits to openclaw:main

@@ -297,10 +297,13 @@ function histogramCreateOptions(name: string) {

297297298298

async function emitAndCaptureLog(

299299

event: Omit<Extract<Parameters<typeof emitDiagnosticEvent>[0], { type: "log.record" }>, "type">,

300-

options: { trusted?: boolean } = {},

300+

options: { captureContent?: OtelContextFlags["captureContent"]; trusted?: boolean } = {},

301301

) {

302302

const service = createDiagnosticsOtelService();

303-

const ctx = createOtelContext(OTEL_TEST_ENDPOINT, { logs: true });

303+

const ctx = createOtelContext(OTEL_TEST_ENDPOINT, {

304+

logs: true,

305+

...(options.captureContent !== undefined ? { captureContent: options.captureContent } : {}),

306+

});

304307

await service.start(ctx);

305308

const emit = options.trusted ? emitTrustedDiagnosticEvent : emitDiagnosticEvent;

306309

emit({

@@ -1060,12 +1063,33 @@ describe("diagnostics-otel service", () => {

10601063

await service.stop?.(ctx);

10611064

});

106210651063-

test("redacts sensitive data from log messages before export", async () => {

1066+

test("omits log message bodies from OTLP logs unless broad content capture is enabled", async () => {

10641067

const emitCall = await emitAndCaptureLog({

10651068

level: "INFO",

1066-

message: "Using API key sk-1234567890abcdef1234567890abcdef",

1069+

message: "model replied OTEL-QA-OK",

10671070

});

106810711072+

expect(emitCall?.body).toBe("log");

1073+

});

1074+1075+

test("keeps granular content capture from enabling OTLP log bodies", async () => {

1076+

const emitCall = await emitAndCaptureLog(

1077+

{

1078+

level: "INFO",

1079+

message: "model replied OTEL-QA-OK",

1080+

},

1081+

{ captureContent: { enabled: true, inputMessages: true } },

1082+

);

1083+1084+

expect(emitCall?.body).toBe("log");

1085+

});

1086+1087+

test("redacts sensitive data from log messages before export when broad content capture is enabled", async () => {

1088+

const emitCall = await emitAndCaptureLog({

1089+

level: "INFO",

1090+

message: "Using API key sk-1234567890abcdef1234567890abcdef",

1091+

}, { captureContent: true });

1092+10691093

expect(emitCall?.body).not.toContain("sk-1234567890abcdef1234567890abcdef");

10701094

expect(emitCall?.body).toContain("sk-123");

10711095

expect(emitCall?.body).toContain("…");

@@ -1332,6 +1356,81 @@ describe("diagnostics-otel service", () => {

13321356

await service.stop?.(ctx);

13331357

});

133413581359+

test("drops session-shaped agent identifiers from model usage metric attributes", async () => {

1360+

const service = createDiagnosticsOtelService();

1361+

const ctx = createOtelContext(OTEL_TEST_ENDPOINT, { metrics: true });

1362+

await service.start(ctx);

1363+1364+

emitDiagnosticEvent({

1365+

type: "model.usage",

1366+

agentId: "Agent:qa:otel-trace-smoke",

1367+

provider: "openai",

1368+

model: "gpt-5.4",

1369+

usage: { input: 2 },

1370+

});

1371+

await flushDiagnosticEvents();

1372+1373+

expect(telemetryState.counters.get("openclaw.tokens")?.add).toHaveBeenCalledWith(2, {

1374+

"openclaw.channel": "unknown",

1375+

"openclaw.agent": "unknown",

1376+

"openclaw.provider": "openai",

1377+

"openclaw.model": "gpt-5.4",

1378+

"openclaw.token": "input",

1379+

});

1380+

expect(

1381+

JSON.stringify(telemetryState.counters.get("openclaw.tokens")?.add.mock.calls),

1382+

).not.toContain("Agent:qa:otel-trace-smoke");

1383+

await service.stop?.(ctx);

1384+

});

1385+1386+

test("drops session-shaped queue lane metric attributes", async () => {

1387+

const service = createDiagnosticsOtelService();

1388+

const ctx = createOtelContext(OTEL_TEST_ENDPOINT, { metrics: true });

1389+

await service.start(ctx);

1390+1391+

emitDiagnosticEvent({

1392+

type: "queue.lane.enqueue",

1393+

lane: "session:Agent:qa:otel-trace-smoke",

1394+

queueSize: 2,

1395+

});

1396+

await flushDiagnosticEvents();

1397+1398+

expect(telemetryState.counters.get("openclaw.queue.lane.enqueue")?.add).toHaveBeenCalledWith(

1399+

1,

1400+

{

1401+

"openclaw.lane": "session",

1402+

},

1403+

);

1404+

expect(

1405+

JSON.stringify(telemetryState.counters.get("openclaw.queue.lane.enqueue")?.add.mock.calls),

1406+

).not.toContain("Agent:qa:otel-trace-smoke");

1407+

await service.stop?.(ctx);

1408+

});

1409+1410+

test("keeps only the bounded prefix from scoped queue lane metric attributes", async () => {

1411+

const service = createDiagnosticsOtelService();

1412+

const ctx = createOtelContext(OTEL_TEST_ENDPOINT, { metrics: true });

1413+

await service.start(ctx);

1414+1415+

emitDiagnosticEvent({

1416+

type: "queue.lane.enqueue",

1417+

lane: "dreaming-narrative:session-main",

1418+

queueSize: 2,

1419+

});

1420+

await flushDiagnosticEvents();

1421+1422+

expect(telemetryState.counters.get("openclaw.queue.lane.enqueue")?.add).toHaveBeenCalledWith(

1423+

1,

1424+

{

1425+

"openclaw.lane": "dreaming-narrative",

1426+

},

1427+

);

1428+

expect(

1429+

JSON.stringify(telemetryState.counters.get("openclaw.queue.lane.enqueue")?.add.mock.calls),

1430+

).not.toContain("session-main");

1431+

await service.stop?.(ctx);

1432+

});

1433+13351434

test("keeps GenAI token usage metric model attribute present when model is unavailable", async () => {

13361435

const service = createDiagnosticsOtelService();

13371436

const ctx = createOtelContext(OTEL_TEST_ENDPOINT, { metrics: true });

@@ -1677,6 +1776,26 @@ describe("diagnostics-otel service", () => {

16771776

await service.stop?.(ctx);

16781777

});

167917781779+

test("drops session-shaped queue lanes from model failover spans", async () => {

1780+

const service = createDiagnosticsOtelService();

1781+

const ctx = createOtelContext(OTEL_TEST_ENDPOINT, { traces: true });

1782+

await service.start(ctx);

1783+1784+

emitDiagnosticEvent({

1785+

type: "model.failover",

1786+

lane: "session:Agent:qa:otel-trace-smoke",

1787+

reason: "overloaded",

1788+

fromProvider: "anthropic",

1789+

fromModel: "claude-opus-4-6",

1790+

});

1791+

await flushDiagnosticEvents();

1792+1793+

const failoverOptions = startedSpanOptions("openclaw.model.failover");

1794+

expect(failoverOptions?.attributes?.["openclaw.lane"]).toBe("session");

1795+

expect(JSON.stringify(failoverOptions?.attributes)).not.toContain("Agent:qa:otel-trace-smoke");

1796+

await service.stop?.(ctx);

1797+

});

1798+16801799

test("maps model call APIs to GenAI operation names and error type", async () => {

16811800

const service = createDiagnosticsOtelService();

16821801

const ctx = createOtelContext(OTEL_TEST_ENDPOINT, { traces: true, metrics: true });