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

推荐订阅源

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

perf: reduce session and auth cache hotpath work (#86678) fix(qa): stream gateway gauntlet prebuild output fix(cli): route plugin packaging recovery hints · openclaw/openclaw@56633e4 fix(diagnostics): expose missing telemetry signals (#86682) perf: avoid extra session snapshot cloning fix: avoid compaction checkpoint transcript copies (#86666) · openclaw/openclaw@c59635a fix: preserve code mode failure output test: avoid message tool discovery in send helper · openclaw/openclaw@1514cc8 fix(scripts): bound guard inventory file reads · openclaw/openclaw@6defcb0 fix(test): isolate kitchen sink rpc home env feat(signal): support reaction approvals (#85894) fix(scripts): bound source scan file reads · openclaw/openclaw@57748a6 test(ollama): support cloud api live smoke · openclaw/openclaw@2a6b4ed test: serialize agents tools vitest files · openclaw/openclaw@978a2d0 fix(auto-reply): use context-aware overflow reserve hints (#84399) · openclaw/openclaw@3a4f2b1 feat(gateway): forward OpenAI sampling params (#84094) · openclaw/openclaw@6c7b3f3 perf: cache model cost indexes · openclaw/openclaw@068924e fix: hide unsupported best effort message option · openclaw/openclaw@5dc7043 refactor: reuse realtime output activity in google meet (#86665) fix(test): harden bundled plugin install sweep · openclaw/openclaw@84929e4 fix: prefer source public artifacts in source checkouts · openclaw/openclaw@c87957d test: type child process spawn mock · openclaw/openclaw@65a2105 test(installer): cover rocky cli installs · openclaw/openclaw@fe33747 docs: update changelog for landed fixes · openclaw/openclaw@da831e2 fix: dampen repeated device-required probes · openclaw/openclaw@399c692 fix(ui): keep local file markdown links inert · openclaw/openclaw@fc2d2d5 fix(update): avoid duplicate plugin smoke failures · openclaw/openclaw@342bde2 fix(gateway): cap retained compaction checkpoint bytes · openclaw/openclaw@d7361ef fix: stabilize tests and reduce plugin memory churn · openclaw/openclaw@c1a026a perf: reduce runtime metadata hotpath churn · openclaw/openclaw@1d21224 refactor: share realtime output activity tracking (#86661) fix(memory-wiki): bound compile page reads (#86660) · openclaw/openclaw@acbdb8c test(qa-matrix): use larger media coverage jpeg fix(cli): reject unknown command help roots (#81083) (thanks @YB0y) · openclaw/openclaw@bec7d56 test: improve test profiling helpers · openclaw/openclaw@68ab48b perf: reduce fuzzy matching allocations · openclaw/openclaw@ec7ad3b perf: reduce runtime cache churn · openclaw/openclaw@1531fe2 refactor: reuse forced consult coordinator in discord voice (#86656) · openclaw/openclaw@0164fd5 fix(scripts): drain codex-cli metadata stdout (#84239) (thanks @Iftek… fix(test): avoid discord voice tts activation tax · openclaw/openclaw@75ac0b5 fix(codex): disable native thread personality (#85891) (thanks @lastg… · openclaw/openclaw@0f35ec2 Refactor realtime voice turn context tracking (#86650) fix(discord): surface silent reply-delivery skips and remove runtime.… · openclaw/openclaw@3a48366 test(discord): cover deliver-lambda abort-skip path via processDiscor… · openclaw/openclaw@48adcb1 docs: update changelog for landed bug fixes · openclaw/openclaw@75c6cf2 test(qa-matrix): use valid media coverage jpeg · openclaw/openclaw@0f54221 fix(gmail-watcher): strip listeners from old process after settleProc… · openclaw/openclaw@0a38932 fix(gmail-watcher): prevent TDZ in settleProcess and guard exit handl… · openclaw/openclaw@94968c8 fix(hooks): stop existing Gmail watcher before re-entry to prevent leaks fix(codex): honor yolo app-server approval policy · openclaw/openclaw@7b30291 fix(usage-cost): invalidate durable cache on missing-cost semantics c… · openclaw/openclaw@9c79a0f fix(usage-cost): preserve transport-recorded positive cost for unpric… · openclaw/openclaw@6e85869 fix(usage-cost): only flag catalog-default zeros, preserve operator-c… · openclaw/openclaw@1670249 fix: treat zero-rate usage cost as unknown · openclaw/openclaw@116c600 fix(usage-cost): surface unpriced-model spend as missingCostEntries i… · openclaw/openclaw@1cc0a96 fix(irc): normalize channel route ids · openclaw/openclaw@9cb1e47 test(irc): cover transient channel join · openclaw/openclaw@c4c80ce fix(irc): store inbound channel routes as channel:#name and join befo… · openclaw/openclaw@63dee51 fix(test): harden macos onboarding e2e · openclaw/openclaw@cd96542 fix(agents): strip markdown code spans from IDENTITY.md values and la… · openclaw/openclaw@55c9a6b perf: reduce runtime cache churn · openclaw/openclaw@5b6d03e fix(pi-runner): flush blocks after compaction retry (#85288) (thanks … · openclaw/openclaw@0d4575a fix(gateway): abort stale agent runs on restart · openclaw/openclaw@a122d80 fix(ui): harden control e2e browser setup · openclaw/openclaw@4424daf fix(telegram): keep overlapping DM replies deliverable (#85361) (than… · openclaw/openclaw@0f67dfd fix(openai): route compaction through Codex auth provider (#86408) · openclaw/openclaw@f4cfa01 refactor: share realtime forced consult coordination · openclaw/openclaw@5dccba7 test(qa-lab): add runtime confidence reports build: refresh dependency pins (#86628) · openclaw/openclaw@cda7c30 test: port release validation stabilizers · openclaw/openclaw@9f7485e fix(cron): stop forcing message tool for delivery · openclaw/openclaw@c51fa0d 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
perf(agents): reuse model manifest context · openclaw/openclaw@ea2496b
TimToxopeus · 2026-05-26 · via Recent Commits to openclaw:main

@@ -127,4 +127,234 @@ describe("configured model manifest workspace scope", () => {

127127

]);

128128

expect(loadManifestMetadataSnapshotMock).not.toHaveBeenCalled();

129129

});

130+131+

it("does not load manifest metadata for empty configured model aliases", async () => {

132+

const { buildModelAliasIndex } = await import("./model-selection-shared.js");

133+

const cfg = {} as unknown as OpenClawConfig;

134+135+

const aliases = buildModelAliasIndex({ cfg, defaultProvider: "anthropic" });

136+137+

expect(aliases.byAlias.size).toBe(0);

138+

expect(aliases.byKey.size).toBe(0);

139+

expect(getCurrentPluginMetadataSnapshotMock).not.toHaveBeenCalled();

140+

expect(loadManifestMetadataSnapshotMock).not.toHaveBeenCalled();

141+

});

142+143+

it("does not load manifest metadata for wildcard-only configured model aliases", async () => {

144+

const { buildModelAliasIndex } = await import("./model-selection-shared.js");

145+

const cfg = {

146+

agents: {

147+

defaults: {

148+

models: {

149+

"anthropic/*": {},

150+

},

151+

},

152+

},

153+

} as unknown as OpenClawConfig;

154+155+

const aliases = buildModelAliasIndex({ cfg, defaultProvider: "anthropic" });

156+157+

expect(aliases.byAlias.size).toBe(0);

158+

expect(aliases.byKey.size).toBe(0);

159+

expect(getCurrentPluginMetadataSnapshotMock).not.toHaveBeenCalled();

160+

expect(loadManifestMetadataSnapshotMock).not.toHaveBeenCalled();

161+

});

162+163+

it("does not load manifest metadata for configured model entries without aliases", async () => {

164+

const { buildModelAliasIndex } = await import("./model-selection-shared.js");

165+

const cfg = {

166+

agents: {

167+

defaults: {

168+

models: {

169+

"anthropic/sonnet-4.6": {},

170+

},

171+

},

172+

},

173+

} as unknown as OpenClawConfig;

174+175+

const aliases = buildModelAliasIndex({ cfg, defaultProvider: "anthropic" });

176+177+

expect(aliases.byAlias.size).toBe(0);

178+

expect(aliases.byKey.size).toBe(0);

179+

expect(getCurrentPluginMetadataSnapshotMock).not.toHaveBeenCalled();

180+

expect(loadManifestMetadataSnapshotMock).not.toHaveBeenCalled();

181+

});

182+183+

it("does not load manifest metadata for statically resolved primary models", async () => {

184+

const { resolveConfiguredModelRef } = await import("./model-selection-shared.js");

185+

const cases: Array<{ cfg: OpenClawConfig; expected: { provider: string; model: string } }> = [

186+

{

187+

cfg: {

188+

agents: { defaults: { model: { primary: "sonnet-4.6" } } },

189+

} as unknown as OpenClawConfig,

190+

expected: { provider: "anthropic", model: "sonnet-4.6" },

191+

},

192+

{

193+

cfg: {

194+

agents: { defaults: { model: { primary: "gpt-5.5" } } },

195+

models: { providers: { openai: { models: [{ id: "gpt-5.5" }] } } },

196+

} as unknown as OpenClawConfig,

197+

expected: { provider: "openai", model: "gpt-5.5" },

198+

},

199+

];

200+201+

for (const { cfg, expected } of cases) {

202+

getCurrentPluginMetadataSnapshotMock.mockClear();

203+

loadManifestMetadataSnapshotMock.mockClear();

204+

expect(

205+

resolveConfiguredModelRef({

206+

cfg,

207+

defaultProvider: "anthropic",

208+

defaultModel: "claude-sonnet-4-6",

209+

}),

210+

).toEqual(expected);

211+

expect(getCurrentPluginMetadataSnapshotMock).not.toHaveBeenCalled();

212+

expect(loadManifestMetadataSnapshotMock).not.toHaveBeenCalled();

213+

}

214+

});

215+216+

it("does not load manifest metadata for non-alias primary models with configured aliases", async () => {

217+

const { resolveConfiguredModelRef } = await import("./model-selection-shared.js");

218+

const cfg = {

219+

agents: {

220+

defaults: {

221+

model: { primary: "haiku-4.6" },

222+

models: {

223+

"anthropic/sonnet-4.6": { alias: "sonnet" },

224+

},

225+

},

226+

},

227+

} as unknown as OpenClawConfig;

228+229+

expect(

230+

resolveConfiguredModelRef({

231+

cfg,

232+

defaultProvider: "anthropic",

233+

defaultModel: "claude-sonnet-4-6",

234+

}),

235+

).toEqual({ provider: "anthropic", model: "haiku-4.6" });

236+

expect(getCurrentPluginMetadataSnapshotMock).not.toHaveBeenCalled();

237+

expect(loadManifestMetadataSnapshotMock).not.toHaveBeenCalled();

238+

});

239+240+

it("uses manifest-normalized configured refs to infer providers for bare defaults", async () => {

241+

loadManifestMetadataSnapshotMock.mockReturnValue({

242+

plugins: [

243+

{

244+

modelIdNormalization: {

245+

providers: {

246+

anthropic: {

247+

aliases: {

248+

"sonnet-4.6": "claude-sonnet-4-6",

249+

},

250+

},

251+

},

252+

},

253+

},

254+

],

255+

});

256+

const { resolveConfiguredModelRef } = await import("./model-selection-shared.js");

257+

const cfg = {

258+

agents: {

259+

defaults: {

260+

model: { primary: "claude-sonnet-4-6" },

261+

models: {

262+

"anthropic/sonnet-4.6": {},

263+

},

264+

},

265+

},

266+

} as unknown as OpenClawConfig;

267+268+

expect(

269+

resolveConfiguredModelRef({

270+

cfg,

271+

defaultProvider: "openai",

272+

defaultModel: "gpt-5.4",

273+

}),

274+

).toEqual({ provider: "anthropic", model: "claude-sonnet-4-6" });

275+

expect(loadManifestMetadataSnapshotMock).toHaveBeenCalledTimes(1);

276+

});

277+278+

it("reuses resolved manifest plugins while resolving configured model aliases", async () => {

279+

loadManifestMetadataSnapshotMock.mockReturnValue({

280+

plugins: [

281+

{

282+

modelIdNormalization: {

283+

providers: {

284+

anthropic: {

285+

aliases: {

286+

"sonnet-4.6": "claude-sonnet-4-6",

287+

},

288+

},

289+

openrouter: {

290+

prefixWhenBare: "openrouter",

291+

},

292+

},

293+

},

294+

},

295+

],

296+

});

297+

const { resolveConfiguredModelRef } = await import("./model-selection-shared.js");

298+

const cfg = {

299+

agents: {

300+

defaults: {

301+

model: { primary: "router-auto" },

302+

models: {

303+

"anthropic/sonnet-4.6": { alias: "sonnet" },

304+

"openrouter:auto": { alias: "router-auto" },

305+

},

306+

},

307+

},

308+

} as unknown as OpenClawConfig;

309+310+

expect(

311+

resolveConfiguredModelRef({

312+

cfg,

313+

defaultProvider: "anthropic",

314+

defaultModel: "claude-sonnet-4-6",

315+

}),

316+

).toEqual({ provider: "openrouter", model: "openrouter/auto" });

317+

expect(loadManifestMetadataSnapshotMock).toHaveBeenCalledTimes(1);

318+

});

319+320+

it("reuses resolved manifest plugins while resolving direct primary models", async () => {

321+

loadManifestMetadataSnapshotMock.mockReturnValue({

322+

plugins: [

323+

{

324+

modelIdNormalization: {

325+

providers: {

326+

anthropic: {

327+

aliases: {

328+

"sonnet-4.6": "claude-sonnet-4-6",

329+

},

330+

},

331+

openrouter: {

332+

prefixWhenBare: "openrouter",

333+

},

334+

},

335+

},

336+

},

337+

],

338+

});

339+

const { resolveConfiguredModelRef } = await import("./model-selection-shared.js");

340+

const cfg = {

341+

agents: {

342+

defaults: {

343+

model: { primary: "openrouter:auto" },

344+

models: {

345+

"anthropic/sonnet-4.6": { alias: "sonnet" },

346+

},

347+

},

348+

},

349+

} as unknown as OpenClawConfig;

350+351+

expect(

352+

resolveConfiguredModelRef({

353+

cfg,

354+

defaultProvider: "anthropic",

355+

defaultModel: "claude-sonnet-4-6",

356+

}),

357+

).toEqual({ provider: "openrouter", model: "openrouter/auto" });

358+

expect(loadManifestMetadataSnapshotMock).toHaveBeenCalledTimes(1);

359+

});

130360

});