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

推荐订阅源

N
News and Events Feed by Topic
Malwarebytes
Malwarebytes
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
C
Cybersecurity and Infrastructure Security Agency CISA
F
Future of Privacy Forum
C
Cisco Blogs
T
The Exploit Database - CXSecurity.com
A
Arctic Wolf
S
Securelist
K
Kaspersky official blog
S
Schneier on Security
T
ThreatConnect
T
Tenable Blog
Spread Privacy
Spread Privacy
T
True Tiger Recordings
AWS News Blog
AWS News Blog
F
Fox-IT International blog
量子位
T
Threatpost
V
Vulnerabilities – Threatpost
C
CERT Recently Published Vulnerability Notes
Cisco Talos Blog
Cisco Talos Blog
GbyAI
GbyAI
宝玉的分享
宝玉的分享
腾讯CDC
G
Google Developers Blog
aimingoo的专栏
aimingoo的专栏
Cyberwarzone
Cyberwarzone
有赞技术团队
有赞技术团队
S
SegmentFault 最新的问题
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
V
Visual Studio Blog
U
Unit 42
雷峰网
雷峰网
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Simon Willison's Weblog
Simon Willison's Weblog
O
OpenAI News
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
The GitHub Blog
The GitHub Blog
The Register - Security
The Register - Security
MyScale Blog
MyScale Blog
小众软件
小众软件
A
About on SuperTechFans
Last Week in AI
Last Week in AI
Y
Y Combinator Blog
博客园 - 三生石上(FineUI控件)
美团技术团队
Google Online Security Blog
Google Online Security Blog
P
Proofpoint News Feed
MongoDB | Blog
MongoDB | Blog

Recent Commits to openclaw:main

chore(skills): normalize release skill routing · openclaw/openclaw@4737e19 docs(release): require early performance regression check · openclaw/openclaw@0336938 fix(qa): capture Windows gateway metrics fix(perf): avoid duplicate docker package ui build build: enable modern TypeScript module syntax · openclaw/openclaw@bbc1772 ci: include performance evidence in release validation fix(providers): stream ordinary tool-like prose promptly fix(perf): harden gateway restart bench exits · openclaw/openclaw@82bbcf6 fix(gateway): gate talk secret bootstrap handoff (#85690) · openclaw/openclaw@c791e42 fix: suppress async media incomplete-turn errors (#85933) · openclaw/openclaw@35dcd42 migrate auth credentials · openclaw/openclaw@f036bac fix migrate auth lint · openclaw/openclaw@50e6cb0 fix migrate supported auth imports · openclaw/openclaw@44bb2be fix migrate auth opt-out precedence · openclaw/openclaw@2016a51 honor migrate auth opt-out in plan · openclaw/openclaw@17edec7 address migrate auth review comments · openclaw/openclaw@0a98c2d fix ci blockers for migrate auth docs: add migrate auth changelog (#85667) · openclaw/openclaw@f7fcbdb fix(scripts): avoid duplicate install smoke ui build · openclaw/openclaw@b1b2841 fix(telegram): preserve inbound text entities (#83873) · openclaw/openclaw@b552919 chore: ignore Python bytecode caches · openclaw/openclaw@b6b2755 fix: make autoreview progress visible · openclaw/openclaw@236edb2 ci(release): fix plugin prerelease extension batch invocation test(telegram): provide topic cache store in message context harness · openclaw/openclaw@ff1fde1 test(agents): complete provider runtime test mocks · openclaw/openclaw@be8cd12 test(telegram): type topic cache harness store · openclaw/openclaw@84ab206 test(agents): sync provider runtime mocks · openclaw/openclaw@a289dd9 refactor: keep plain text tool-call promotion private (#86374) · openclaw/openclaw@c3ab2de fix(discord): suppress self-reply prompt echoes (#86238) docs: clarify config migration policy · openclaw/openclaw@c44367f fix(perf): fail startup bench on early gateway exit · openclaw/openclaw@a8fc28c fix: prevent plain text tool call leaks (#86222) · openclaw/openclaw@cd62780 fix: handle npm min-release-age in installers · openclaw/openclaw@316d97c fix(scripts): include ui:build in build-all full and ciArtifacts prof… · openclaw/openclaw@6704d0a fix(e2e): sample Windows kitchen sink gateway RSS · openclaw/openclaw@73189e3 fix(cron): respect isolated target and error on missing remove id (#8… · openclaw/openclaw@6709f4e fix(pi-embedded-runner): propagate trigger-derived priority to the gl… · openclaw/openclaw@0580f57 fix(cli): suppress self-update version warnings · openclaw/openclaw@e2bd20f fix: preserve webchat source reply details · openclaw/openclaw@aa50c51 docs: replace OpenClaw docs skill and add plugin permissions guide · openclaw/openclaw@0dabb70 fix(codex): preserve source reply mode for active runs (#86325) · openclaw/openclaw@b962110 fix: make compaction reinjection opt-in · openclaw/openclaw@ab910f8 fix codex usage-limit recovery copy (#86305) · openclaw/openclaw@c3c8a65 feat(ui): add ephemeral Activity tab · openclaw/openclaw@3dd0e8e fix(tests): harden native macos plugin proof · openclaw/openclaw@a5d5604 fix(commitments): serialize load-modify-save with in-process queue + … · openclaw/openclaw@d3c293d Fail Codex compaction at the Codex boundary (#85958) · openclaw/openclaw@dd47e47 fix(docker): restore config parent ownership · openclaw/openclaw@908b894 docs: clarify config default review policy (#86329) · openclaw/openclaw@3a03dd5 docs: clean changelog script entries · openclaw/openclaw@0eead19 fix(scripts): budget restart benchmark timeouts · openclaw/openclaw@5bd5509 fix: align ui vitest config assertion · openclaw/openclaw@730fd19 fix: route unit ui vitest targets narrowly · openclaw/openclaw@777402e fix: route explicit ui vitest targets narrowly · openclaw/openclaw@56a383c fix(android): harden play media permission removal fix(webchat): stabilize live transcript run state · openclaw/openclaw@119a01c fix(scripts): fail restart benchmark regressions · openclaw/openclaw@95d1b39 fix(openai): scope external codex auth to realtime fix(openai): prefer codex auth for GPT realtime · openclaw/openclaw@48c4f57 fix(openai): discover codex cli auth for provider checks · openclaw/openclaw@4656275 fix(android): keep talk mode on realtime relay · openclaw/openclaw@70614f8 test(android): add gateway connect adb probe · openclaw/openclaw@d7aa1f3 fix(android): stabilize realtime talk connection state · openclaw/openclaw@ffb02a5 test(android): add voice mode adb e2e harness · openclaw/openclaw@e52a3b3 fix(ci): stabilize deadcode and catalog checks · openclaw/openclaw@3db1508 fix(scripts): prebuild gateway cpu bench · openclaw/openclaw@ca70015 fix(e2e): harden bundled lifecycle probe on Windows · openclaw/openclaw@4798264 test(e2e): sample kitchen sink rpc peak rss · openclaw/openclaw@60c0f24 fix(scripts): remove stale deadcode allowlist entries · openclaw/openclaw@ea3bb92 fix(telegram): route polling diagnostics away from errors · openclaw/openclaw@b5c1199 fix(plugins): support linked source checkouts on Windows · openclaw/openclaw@793e300 fix(gateway): back off session tool mirrors under pressure (#84846) · openclaw/openclaw@42bdc94 fix(config): skip shell env fallback on Windows (#85739) · openclaw/openclaw@06bf302 fix(gateway): avoid duplicate session message broadcasts · openclaw/openclaw@1459044 fix: repair anchorless iMessage watch payloads · openclaw/openclaw@f37fbc9 fix(cli): route node status hints to stdout (#85780) · openclaw/openclaw@749692e fix(oc-path): support deep config edits (#86060) · openclaw/openclaw@3a72a30 fix(config): quiet benign metadata anomaly output · openclaw/openclaw@f3f4f29 fix(test): fail multi-node update regressions · openclaw/openclaw@732cf54 fix(google-vertex): support production ADC modes (#83971) · openclaw/openclaw@f09b4eb test(e2e): expose corrupt plugin deps smoke · openclaw/openclaw@fa3ff4d fix(codex): log app-server approval promotion trigger · openclaw/openclaw@d9af23f test(e2e): harden multi-node update smoke Clean up browser MCP subprocess tree (#85832) · openclaw/openclaw@8dc6b4d fix(agents): log warnings instead of swallowing subagent errors (#82943) · openclaw/openclaw@907bc03 fix(compaction): preserve partial summary on mid-chain chunk failure … · openclaw/openclaw@f0061dd fix(config): do not suppress recovery retry after failed backup resto… · openclaw/openclaw@5d174a5 chore: release 2026.5.25 fix(installer): support alpine cli installs · openclaw/openclaw@f68ed72 test(agents): keep runtime-plan provider mock current fix(scripts): launch env package scripts on Windows · openclaw/openclaw@4d4ce9e fix(agents): cache fallback provider resolution · openclaw/openclaw@3c8d101 fix(test): make import timing scripts Windows-safe · openclaw/openclaw@8ae9977 fix(telegram): transient Telegram pairing prompts (#85555) · openclaw/openclaw@8209426 fix(test): make max Vitest scripts Windows-safe · openclaw/openclaw@b681d5d fix(doctor): migrate Feishu account bot names (#86081) · openclaw/openclaw@9e8cc7e fix(scripts): prefilter conflict marker scans docs: add ClawSweeper review policy to AGENTS (#86197) · openclaw/openclaw@242e876 fix(installer): avoid before with npm release-age configs (#85491) · openclaw/openclaw@4742db6 fix(e2e): retry Windows kitchen sink probes · openclaw/openclaw@3e275a5
feat(qa): add coverage scenario matching · openclaw/openclaw@a1fe86a
steipete · 2026-05-25 · via Recent Commits to openclaw:main

@@ -13,6 +13,16 @@ type QaCoverageScenarioSummary = {

1313

risk: string;

1414

};

151516+

type QaScenarioSearchMatch = QaCoverageScenarioSummary & {

17+

coverageIds: string[];

18+

docsRefs: string[];

19+

codeRefs: string[];

20+

runtimeParityTier?: string;

21+

requiredProviderMode?: string;

22+

requiredProvider?: string;

23+

requiredModel?: string;

24+

};

25+1626

type QaCoverageIntent = "primary" | "secondary";

17271828

type QaCoverageScenarioReference = QaCoverageScenarioSummary & {

@@ -70,6 +80,85 @@ function summarizeScenario(scenario: QaSeedScenarioWithSource): QaCoverageScenar

7080

};

7181

}

728283+

function normalizeSearchText(value: string) {

84+

return value.toLowerCase();

85+

}

86+87+

function tokenizeScenarioSearchQuery(query: string) {

88+

return query

89+

.toLowerCase()

90+

.split(/\s+/u)

91+

.map((token) => token.trim())

92+

.filter(Boolean);

93+

}

94+95+

function scenarioSearchText(scenario: QaSeedScenarioWithSource) {

96+

const config = scenario.execution.config ?? {};

97+

return normalizeSearchText(

98+

[

99+

scenario.id,

100+

scenario.title,

101+

scenario.sourcePath,

102+

scenario.surface,

103+

...(scenario.surfaces ?? []),

104+

scenario.category ?? "",

105+

scenario.runtimeParityTier ?? "",

106+

scenario.risk ?? "",

107+

scenario.riskLevel ?? "",

108+

scenario.objective,

109+

...scenario.successCriteria,

110+

...(scenario.capabilities ?? []),

111+

...(scenario.plugins ?? []),

112+

...(scenario.docsRefs ?? []),

113+

...(scenario.codeRefs ?? []),

114+

...(scenario.coverage?.primary ?? []),

115+

...(scenario.coverage?.secondary ?? []),

116+

...Object.entries(config).flatMap(([key, value]) => [

117+

key,

118+

typeof value === "string" ? value : "",

119+

]),

120+

].join("\n"),

121+

);

122+

}

123+124+

function stringifyConfigValue(value: unknown) {

125+

return typeof value === "string" && value.trim() ? value.trim() : undefined;

126+

}

127+128+

function summarizeScenarioSearchMatch(scenario: QaSeedScenarioWithSource): QaScenarioSearchMatch {

129+

const config = scenario.execution.config ?? {};

130+

return {

131+

...summarizeScenario(scenario),

132+

coverageIds: [

133+

...(scenario.coverage?.primary ?? []),

134+

...(scenario.coverage?.secondary ?? []),

135+

].toSorted((left, right) => left.localeCompare(right)),

136+

docsRefs: [...(scenario.docsRefs ?? [])],

137+

codeRefs: [...(scenario.codeRefs ?? [])],

138+

runtimeParityTier: scenario.runtimeParityTier,

139+

requiredProviderMode: stringifyConfigValue(config.requiredProviderMode),

140+

requiredProvider: stringifyConfigValue(config.requiredProvider),

141+

requiredModel: stringifyConfigValue(config.requiredModel),

142+

};

143+

}

144+145+

export function findQaScenarioMatches(

146+

scenarios: readonly QaSeedScenarioWithSource[],

147+

query: string,

148+

) {

149+

const tokens = tokenizeScenarioSearchQuery(query);

150+

if (tokens.length === 0) {

151+

return [];

152+

}

153+

return scenarios

154+

.filter((scenario) => {

155+

const haystack = scenarioSearchText(scenario);

156+

return tokens.every((token) => haystack.includes(token));

157+

})

158+

.map(summarizeScenarioSearchMatch)

159+

.toSorted((left, right) => left.id.localeCompare(right.id));

160+

}

161+73162

function sortFeatures(features: readonly QaCoverageFeatureSummary[]) {

74163

return features.toSorted((left, right) => left.id.localeCompare(right.id));

75164

}

@@ -280,3 +369,52 @@ export function renderQaCoverageMarkdownReport(inventory: QaCoverageInventory):

280369281370

return `${lines.join("\n").trimEnd()}\n`;

282371

}

372+373+

function formatOptionalScenarioMetadata(match: QaScenarioSearchMatch) {

374+

const metadata = [

375+

match.runtimeParityTier ? `runtimeParityTier=${match.runtimeParityTier}` : "",

376+

match.requiredProviderMode ? `providerMode=${match.requiredProviderMode}` : "",

377+

match.requiredProvider ? `provider=${match.requiredProvider}` : "",

378+

match.requiredModel ? `model=${match.requiredModel}` : "",

379+

].filter(Boolean);

380+

return metadata.length > 0 ? metadata.join("; ") : "none";

381+

}

382+383+

export function renderQaScenarioMatchesMarkdownReport(params: {

384+

query: string;

385+

matches: readonly QaScenarioSearchMatch[];

386+

}) {

387+

const scenarioArgs = params.matches.map((match) => `--scenario ${match.id}`).join(" ");

388+

const lines = [

389+

"# QA Scenario Matches",

390+

"",

391+

`- Query: ${params.query}`,

392+

`- Matches: ${params.matches.length}`,

393+

];

394+395+

if (scenarioArgs) {

396+

lines.push(`- Suite command: \`pnpm openclaw qa suite ${scenarioArgs}\``);

397+

}

398+

lines.push("");

399+400+

if (params.matches.length === 0) {

401+

lines.push("No QA scenarios matched the query.", "");

402+

return lines.join("\n");

403+

}

404+405+

for (const match of params.matches) {

406+

lines.push(`- ${match.id}: ${match.title}`);

407+

lines.push(` - source: ${match.sourcePath}`);

408+

lines.push(` - surface: ${match.surfaces.join(", ")}`);

409+

lines.push(` - coverage: ${match.coverageIds.join(", ") || "none"}`);

410+

lines.push(` - live requirements: ${formatOptionalScenarioMetadata(match)}`);

411+

if (match.codeRefs.length > 0) {

412+

lines.push(` - code refs: ${match.codeRefs.join(", ")}`);

413+

}

414+

if (match.docsRefs.length > 0) {

415+

lines.push(` - docs refs: ${match.docsRefs.join(", ")}`);

416+

}

417+

}

418+419+

return `${lines.join("\n").trimEnd()}\n`;

420+

}