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

推荐订阅源

H
Help Net Security
T
ThreatConnect
SecWiki News
SecWiki News
F
Future of Privacy Forum
AWS News Blog
AWS News Blog
C
Cisco Blogs
A
Arctic Wolf
Vercel News
Vercel News
The GitHub Blog
The GitHub Blog
Scott Helme
Scott Helme
V
V2EX
博客园 - 叶小钗
阮一峰的网络日志
阮一峰的网络日志
K
Kaspersky official blog
G
Google Developers Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
P
Privacy International News Feed
C
Cyber Attacks, Cyber Crime and Cyber Security
N
News | PayPal Newsroom
Schneier on Security
Schneier on Security
NISL@THU
NISL@THU
Microsoft Azure Blog
Microsoft Azure Blog
量子位
The Hacker News
The Hacker News
Stack Overflow Blog
Stack Overflow Blog
Security Latest
Security Latest
M
Microsoft Research Blog - Microsoft Research
Google Online Security Blog
Google Online Security Blog
博客园_首页
C
CXSECURITY Database RSS Feed - CXSecurity.com
I
InfoQ
Google DeepMind News
Google DeepMind News
Y
Y Combinator Blog
The Cloudflare Blog
Microsoft Security Blog
Microsoft Security Blog
Martin Fowler
Martin Fowler
Cisco Talos Blog
Cisco Talos Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
T
Troy Hunt's Blog
F
Fox-IT International blog
S
Security @ Cisco Blogs
博客园 - 司徒正美
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
C
Comments on: Blog
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
L
LINUX DO - 最新话题
GbyAI
GbyAI
Project Zero
Project Zero
腾讯CDC
T
Tailwind CSS Blog

Recent Commits to openclaw:main

build: refresh dependency pins (#86628) test: port release validation stabilizers fix(google): omit request config with cached content test: stabilize release validation test harnesses fix(test): bound kitchen sink command output · openclaw/openclaw@f1197ed fix(discord): stabilize realtime wake-name feedback test(config): guard legacy agentRuntime regression perf: precompute audio resample kernels fix(codex): allow env api-key app-server bootstrap · openclaw/openclaw@009b18c refactor: reuse shared coercion helpers (#86419) · openclaw/openclaw@77d9ac3 fix(cron): preserve runtime snapshot for isolated delivery · openclaw/openclaw@a98660e fix(test): model active assistant failover attempts · openclaw/openclaw@c55bee5 docs: update changelog for bug sweep landings test: fix mock signatures for tsgo · openclaw/openclaw@aa05c5c docs: document fail-closed behavior for rejected modelPatterns · openclaw/openclaw@36f269d fix(security): guard plugin modelPatterns with compileSafeRegex · openclaw/openclaw@117e082 docs(manifest): note safe-regex validation for modelPatterns · openclaw/openclaw@e7c7ee4 style: use bracket notation for __openclaw to satisfy no-underscore-d… · openclaw/openclaw@9a6c161 fix(security): escape field names in transcript regex extraction · openclaw/openclaw@fe8d99d test: tighten oversized metadata assertion to check exact id in __ope… · openclaw/openclaw@aff8e64 fix(logging): exit on stdout/stderr EPIPE instead of spinning · openclaw/openclaw@2aa5f17 fix(logging): preserve failure exit on EPIPE · openclaw/openclaw@623a60a fix(logging): keep string failure codes on EPIPE · openclaw/openclaw@78a1e7d fix(scripts): docs-spellcheck.sh fails on bash 3.2 with set -u · openclaw/openclaw@fef57f9 fix(docs): keep spellcheck bash 3.2-compatible · openclaw/openclaw@778fa87 fix(test): assert e2e agent reply payloads · openclaw/openclaw@74f3a1e test(gateway): pin live gateway models to pi runtime · openclaw/openclaw@c88f660 perf: speed up local TUI startup · openclaw/openclaw@a0023fb refactor: share realtime voice activation helpers (#86615) · openclaw/openclaw@d0ab0d9 fix(feishu): render native presentation buttons (#86588) · openclaw/openclaw@170e0aa fix(test): narrow plugin gauntlet prebuild · openclaw/openclaw@423f7d2 fix: route Discord gateway metadata through proxy (#86601) · openclaw/openclaw@5b6d409 fix: tighten Discord voice wake matching (#86595) · openclaw/openclaw@f00a912 refactor(logging): share diagnostic message lifecycle · openclaw/openclaw@baab4cf fix(cron): restore suspended lanes to default concurrency · openclaw/openclaw@e844d1d fix(auth): emit one-shot doctor-pointer warning for Keychain-only leg… · openclaw/openclaw@a61d530 fix(codex): recover stale preflight bindings (#86602) · openclaw/openclaw@9b9d897 fix(cron): preserve unsupported payload rows on writes · openclaw/openclaw@c916906 fix(cron): canonicalize preserved row ids · openclaw/openclaw@985bc93 test(cron): pin sequential duration regression · openclaw/openclaw@8351556 docs: update changelog for cron preservation (#86415) · openclaw/openclaw@bdc6b32 build: bump qs to patched release · openclaw/openclaw@9330b76 fix(status): prefer active OAuth for runtime aliases chore(acpx): bump bundled acpx to 0.10.0 · openclaw/openclaw@407cf8e docs: make changelog release-owned · openclaw/openclaw@c0f2d89 fix(google): stop appending preview to flash lite · openclaw/openclaw@915c820 docs: update changelog for bug sweep landings · openclaw/openclaw@cd7994f fix(crabbox): detect timed macos js commands · openclaw/openclaw@44bb0be fix(mantis): release telegram user leases on startup failure · openclaw/openclaw@cf27567 fix(agents): keep cron media completions run-scoped · openclaw/openclaw@f5d2db2 fix(agents): deliver stale cron media completions · openclaw/openclaw@f01b2a8 fix(agents): notify stale cron media failures · openclaw/openclaw@baf469f guide workspace-only scratch paths fix(cron): gate lifecycle diagnostic events behind isDiagnosticsEnabled · openclaw/openclaw@4853222 fix(cron): emit message.queued/processed for isolated-agent turns fix(cron): address review — drop unsupported taskLabel, pair with ses… · openclaw/openclaw@804a31e fix(cron): report rotated session in final diagnostics · openclaw/openclaw@207a5a2 fix: hydrate current turn image attachments · openclaw/openclaw@b5ada80 fix(gateway): ignore inherited launchd env for respawn · openclaw/openclaw@177ebdc fix(test): preserve undici exports in discord proxy tests · openclaw/openclaw@b0c8a4d fix: raise default cron concurrency · openclaw/openclaw@bc12e04 fix(doctor): skip restart prompt when gateway is healthy after recent… · openclaw/openclaw@6e8d2db fix: emit agent.send lifecycle hooks on rotation (#85875) · openclaw/openclaw@8129dba fix(crabbox): bootstrap macos shell js commands · openclaw/openclaw@7cd15d2 fix: preflight malformed openshell exec commands fix: tighten openshell exec preflight · openclaw/openclaw@822ee62 docs: clarify unshipped compat policy · openclaw/openclaw@f87aa0f fix(update): allow package-manager hardlinks in swaps · openclaw/openclaw@8061d66 docs: ban repo-hosted proof artifacts · openclaw/openclaw@17954a4 fix(discord): restore bare numeric channel sends (#86571) · openclaw/openclaw@c5b9872 fix(installer): handle alpine apk runtime floors · openclaw/openclaw@b83dfcb fix(security): audit Claude permission overrides under YOLO (#86557) · openclaw/openclaw@bd65b42 fix: speed up Discord voice wake consults · openclaw/openclaw@5ae91f0 fix(qa): harden restart inflight Windows scenario · openclaw/openclaw@3eb06e3 Recover Codex context overflow prompt errors (#85542) · openclaw/openclaw@5cfa577 docs: update changelog for #70473 · openclaw/openclaw@d967760 fix(agents): derive overflow budgets from provider errors · openclaw/openclaw@d5b0174 fix(plugins): only memoize complete metadata snapshots · openclaw/openclaw@3137622 docs: update changelog for media wake fallback (#85489) · openclaw/openclaw@a11d4e6 fix: fallback after active media wake failure (#85489) · openclaw/openclaw@1b64ccb perf(plugins): reuse derived metadata snapshots · openclaw/openclaw@159e440 docs: require maintainer-editable PR branches · openclaw/openclaw@f271f00 fix: scan OpenClaw sessions in agent transcript finder · openclaw/openclaw@4012ae4 docs: note agent transcript OpenClaw session scan · openclaw/openclaw@dd375f9 docs: require generic local fixes · openclaw/openclaw@fc93af5 fix: broaden leading voice wake fuzzing · openclaw/openclaw@a9c91ca test(agents): preserve provider hook mock exports (#86523) · openclaw/openclaw@657b246 Policy: add agent-scoped policy overlays (#85817) · openclaw/openclaw@fbb6340 fix(kilocode): normalize string stop param to array in stream wrapper… · openclaw/openclaw@abe9923 Doctor: expose shell completion health findings (#85566) · openclaw/openclaw@dc17412 fix(agents): honor effective exec policy for Claude live Bash (#86330) fix(test): stabilize e2e runtime imports fix(test): clean plugin gauntlet temp roots · openclaw/openclaw@633e4b8 perf: cache plugin package realpaths (#86517) · openclaw/openclaw@69d728a fix(qa): settle restart races with live budget · openclaw/openclaw@2cac9e5 fix(crabbox): sync full sparse lease runs · openclaw/openclaw@e97e831 fix(qa): extend config mutation Windows budget fix(qa): extend config cleanup Windows budget · openclaw/openclaw@8a93851 test(crabbox): tolerate Windows shell capture · openclaw/openclaw@50d6611 fix(sessions): stop doctor OOM on large session stores and reclaim st… · openclaw/openclaw@89aea9b
fix(cron): stop forcing message tool for delivery · openclaw/openclaw@c51fa0d
bryanpearson · 2026-05-26 · via Recent Commits to openclaw:main

@@ -204,7 +204,7 @@ describe("runCronIsolatedAgentTurn message tool policy", () => {

204204

expect(runEmbeddedPiAgentMock).toHaveBeenCalledTimes(1);

205205

expectEmbeddedRunFields({

206206

disableMessageTool: false,

207-

forceMessageTool: true,

207+

forceMessageTool: false,

208208

});

209209

}

210210

@@ -229,7 +229,7 @@ describe("runCronIsolatedAgentTurn message tool policy", () => {

229229

expect(runEmbeddedPiAgentMock).toHaveBeenCalledTimes(1);

230230

expectEmbeddedRunFields({

231231

disableMessageTool: false,

232-

forceMessageTool: true,

232+

forceMessageTool: false,

233233

messageChannel: "messagechat",

234234

messageTo: "123",

235235

currentChannelId: "123",

@@ -335,7 +335,7 @@ describe("runCronIsolatedAgentTurn message tool policy", () => {

335335

timeoutMs: 60_000,

336336

suppressExecNotifyOnExit: true,

337337

sourceDelivery: createSourceDeliveryPlan({

338-

owner: "message_tool_then_direct_fallback",

338+

owner: "direct_fallback",

339339

reason: "cron_announce",

340340

target: {

341341

channel: resolvedDelivery.channel ?? "messagechat",

@@ -344,7 +344,7 @@ describe("runCronIsolatedAgentTurn message tool policy", () => {

344344

threadId: resolvedDelivery.threadId,

345345

},

346346

messageToolEnabled: true,

347-

messageToolForced: true,

347+

messageToolForced: false,

348348

directFallback: true,

349349

}),

350350

skillsSnapshot: emptySkillsSnapshot,

@@ -388,7 +388,7 @@ describe("runCronIsolatedAgentTurn message tool policy", () => {

388388

expect(runEmbeddedPiAgentMock).toHaveBeenCalledTimes(1);

389389

const embeddedRun = expectEmbeddedRunFields({

390390

disableMessageTool: false,

391-

forceMessageTool: true,

391+

forceMessageTool: false,

392392

});

393393

expect(embeddedRun.messageChannel).toBeUndefined();

394394

expect(embeddedRun.messageTo).toBeUndefined();

@@ -425,7 +425,7 @@ describe("runCronIsolatedAgentTurn message tool policy", () => {

425425

expect(runEmbeddedPiAgentMock).toHaveBeenCalledTimes(1);

426426

expectEmbeddedRunFields({

427427

disableMessageTool: false,

428-

forceMessageTool: true,

428+

forceMessageTool: false,

429429

messageChannel: "topicchat",

430430

messageTo: "room#42",

431431

messageThreadId: 42,

@@ -568,7 +568,7 @@ describe("runCronIsolatedAgentTurn message tool policy", () => {

568568

expect(runEmbeddedPiAgentMock).toHaveBeenCalledTimes(1);

569569

const embeddedRun = expectEmbeddedRunFields({

570570

disableMessageTool: false,

571-

forceMessageTool: true,

571+

forceMessageTool: false,

572572

});

573573

expect(embeddedRun.messageChannel).toBeUndefined();

574574

expect(embeddedRun.messageTo).toBeUndefined();

@@ -643,7 +643,7 @@ describe("runCronIsolatedAgentTurn message tool policy", () => {

643643

});

644644

});

645645646-

it("keeps cron announce source replies message-tool-only", async () => {

646+

it("keeps cron announce delivery out of message-tool-only source replies", async () => {

647647

mockRunCronFallbackPassthrough();

648648

resolveCronDeliveryPlanMock.mockReturnValue(makeAnnounceDeliveryPlan());

649649

@@ -654,8 +654,8 @@ describe("runCronIsolatedAgentTurn message tool policy", () => {

654654655655

expect(runEmbeddedPiAgentMock).toHaveBeenCalledTimes(1);

656656

expectEmbeddedRunFields({

657-

sourceReplyDeliveryMode: "message_tool_only",

658-

forceMessageTool: true,

657+

sourceReplyDeliveryMode: undefined,

658+

forceMessageTool: false,

659659

messageChannel: "messagechat",

660660

messageTo: "123",

661661

currentChannelId: "123",

@@ -1157,6 +1157,103 @@ describe("runCronIsolatedAgentTurn delivery instruction", () => {

11571157

expect(prompt).toContain("Return your response as plain text");

11581158

});

115911591160+

it("does not prompt for the message tool when toolsAllow is explicitly empty", async () => {

1161+

mockRunCronFallbackPassthrough();

1162+

resolveCronDeliveryPlanMock.mockReturnValue({

1163+

requested: true,

1164+

mode: "announce",

1165+

channel: "messagechat",

1166+

to: "123",

1167+

});

1168+1169+

await runCronIsolatedAgentTurn({

1170+

...makeParams(),

1171+

job: makeMessageToolPolicyJob(

1172+

{ mode: "announce", channel: "messagechat", to: "123" },

1173+

{ kind: "agentTurn", message: "send a message", toolsAllow: [] },

1174+

),

1175+

});

1176+1177+

expect(runEmbeddedPiAgentMock).toHaveBeenCalledTimes(1);

1178+

expectEmbeddedRunFields({

1179+

disableMessageTool: false,

1180+

forceMessageTool: false,

1181+

toolsAllow: [],

1182+

});

1183+

const prompt = expectEmbeddedRunPrompt();

1184+

expect(prompt).not.toContain("Use the message tool");

1185+

expect(prompt).toContain("Return your response as plain text");

1186+

});

1187+1188+

it("prompts for the message tool when toolsAllow uses wildcard access", async () => {

1189+

mockRunCronFallbackPassthrough();

1190+

resolveCronDeliveryPlanMock.mockReturnValue({

1191+

requested: true,

1192+

mode: "announce",

1193+

channel: "messagechat",

1194+

to: "123",

1195+

});

1196+1197+

await runCronIsolatedAgentTurn({

1198+

...makeParams(),

1199+

job: makeMessageToolPolicyJob(

1200+

{ mode: "announce", channel: "messagechat", to: "123" },

1201+

{ kind: "agentTurn", message: "send a message", toolsAllow: ["*"] },

1202+

),

1203+

});

1204+1205+

expect(runEmbeddedPiAgentMock).toHaveBeenCalledTimes(1);

1206+

const prompt = expectEmbeddedRunPrompt();

1207+

expect(prompt).toContain("Use the message tool");

1208+

expect(prompt).toContain("will be delivered automatically");

1209+

});

1210+1211+

it("prompts for the message tool when toolsAllow uses a group containing message", async () => {

1212+

mockRunCronFallbackPassthrough();

1213+

resolveCronDeliveryPlanMock.mockReturnValue({

1214+

requested: true,

1215+

mode: "announce",

1216+

channel: "messagechat",

1217+

to: "123",

1218+

});

1219+1220+

await runCronIsolatedAgentTurn({

1221+

...makeParams(),

1222+

job: makeMessageToolPolicyJob(

1223+

{ mode: "announce", channel: "messagechat", to: "123" },

1224+

{ kind: "agentTurn", message: "send a message", toolsAllow: ["group:messaging"] },

1225+

),

1226+

});

1227+1228+

expect(runEmbeddedPiAgentMock).toHaveBeenCalledTimes(1);

1229+

const prompt = expectEmbeddedRunPrompt();

1230+

expect(prompt).toContain("Use the message tool");

1231+

expect(prompt).toContain("will be delivered automatically");

1232+

});

1233+1234+

it("prompts for the message tool when toolsAllow names message with different casing", async () => {

1235+

mockRunCronFallbackPassthrough();

1236+

resolveCronDeliveryPlanMock.mockReturnValue({

1237+

requested: true,

1238+

mode: "announce",

1239+

channel: "messagechat",

1240+

to: "123",

1241+

});

1242+1243+

await runCronIsolatedAgentTurn({

1244+

...makeParams(),

1245+

job: makeMessageToolPolicyJob(

1246+

{ mode: "announce", channel: "messagechat", to: "123" },

1247+

{ kind: "agentTurn", message: "send a message", toolsAllow: ["MESSAGE"] },

1248+

),

1249+

});

1250+1251+

expect(runEmbeddedPiAgentMock).toHaveBeenCalledTimes(1);

1252+

const prompt = expectEmbeddedRunPrompt();

1253+

expect(prompt).toContain("Use the message tool");

1254+

expect(prompt).toContain("will be delivered automatically");

1255+

});

1256+11601257

it("does not append a delivery instruction when delivery is not requested", async () => {

11611258

mockRunCronFallbackPassthrough();

11621259

resolveCronDeliveryPlanMock.mockReturnValue({ requested: false, mode: "none" });