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

推荐订阅源

E
Exploit-DB.com RSS Feed
Last Week in AI
Last Week in AI
月光博客
月光博客
博客园 - 三生石上(FineUI控件)
爱范儿
爱范儿
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
罗磊的独立博客
S
SegmentFault 最新的问题
Jina AI
Jina AI
V
V2EX
博客园 - Franky
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
WordPress大学
WordPress大学
博客园 - 叶小钗
大猫的无限游戏
大猫的无限游戏
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
博客园_首页
P
Proofpoint News Feed
Recorded Future
Recorded Future
G
GRAHAM CLULEY
T
Tailwind CSS Blog
李成银的技术随笔
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
Hugging Face - Blog
Hugging Face - Blog
Apple Machine Learning Research
Apple Machine Learning Research
IT之家
IT之家
Latest news
Latest news
Recent Announcements
Recent Announcements
酷 壳 – CoolShell
酷 壳 – CoolShell
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
博客园 - 【当耐特】
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
宝玉的分享
宝玉的分享
P
Privacy International News Feed
Scott Helme
Scott Helme
Cyberwarzone
Cyberwarzone
N
News and Events Feed by Topic
小众软件
小众软件
Stack Overflow Blog
Stack Overflow Blog
D
Darknet – Hacking Tools, Hacker News & Cyber Security
C
CXSECURITY Database RSS Feed - CXSecurity.com
F
Full Disclosure
Blog — PlanetScale
Blog — PlanetScale
P
Proofpoint News Feed
G
Google Developers Blog
博客园 - 聂微东
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
The Cloudflare Blog
T
ThreatConnect
C
Cybersecurity and Infrastructure Security Agency CISA

Recent Commits to openclaw:main

fix(scripts): harden Windows generated formatting fix(mcp): bound tools/list during catalog discovery (#85063) · openclaw/openclaw@07f500a test(e2e): fail release memory indexing errors test(daemon): fail launchd integration bootstrap errors · openclaw/openclaw@af07769 feat(imessage): support thumb approval reactions (#85952) · openclaw/openclaw@5c7980f fix(crabbox): default macos aws runs on demand fix(scripts): preserve test passthrough args · openclaw/openclaw@e4332f7 fix(e2e): harden Windows plugin assertions fix(test): mount upgrade survivor helper · openclaw/openclaw@5f03154 fix(android): prevent stale chat during session switches fix(android): keep permission setup action visible · openclaw/openclaw@94bc18a style(android): sharpen voice mode surfaces · openclaw/openclaw@c452510 fix(android): hide internal chat content blocks · openclaw/openclaw@d86ed21 style(android): refine list surface spacing · openclaw/openclaw@955909c feat(android): add pair new gateway action · openclaw/openclaw@cc5eb97 Advance iMessage catchup cursor after live handling (#85475) · openclaw/openclaw@102555c fix(scripts): ignore forwarded arg separator · openclaw/openclaw@79ee70c fix(test): fail empty gateway startup samples · openclaw/openclaw@5a8ce6a fix(e2e): harden Windows kitchen sink assertions · openclaw/openclaw@87a2eba fix(e2e): harden Telegram credential paths on Windows · openclaw/openclaw@c643370 fix(android): align setup pairing scopes fix(android): complete qr setup operator handoff · openclaw/openclaw@be9bb77 fix(test): copy cleanup smoke prepare hook · openclaw/openclaw@dbc08f6 fix(secrets): allow hash in exec SecretRef ids (#86072) · openclaw/openclaw@675158c fix(media): use static image compression metadata · openclaw/openclaw@694d45e fix(release): verify large plugin npm packs fix(test): require kitchen sink diagnostic canaries · openclaw/openclaw@7e51f83 fix(scripts): harden Windows upgrade survivor recipe · openclaw/openclaw@483d7be fix(installer): count verify progress stage fix: Refine PR template for review state (#86054) fix(test): repair split agent shard runs · openclaw/openclaw@125d82c fix(codex): harden Windows protocol formatting · openclaw/openclaw@ce48e4c fix(openrouter): use endpoint context limits (#86041) · openclaw/openclaw@dd01a2e test(qa): remove brittle capability flip setup turn fix(telegram): migrate legacy cache sidecars · openclaw/openclaw@eb9b882 fix(telegram): migrate account topic cache sidecars · openclaw/openclaw@5cfb12f fix(scripts): harden Windows ZAI fallback repro · openclaw/openclaw@5be62e7 style(android): sharpen v2 screen rhythm · openclaw/openclaw@400d90a test(qa): extend capability flip setup budget · openclaw/openclaw@c91c3c6 fix(android): simplify gateway status copy fix(android): route offline voice to gateway setup fix(scripts): harden Windows control UI i18n commands · openclaw/openclaw@581c8a6 fix(android): stop operator chat subscription · openclaw/openclaw@5c15859 fix(test): fail missing kitchen sink rss samples test(qa): widen capability flip restart budget · openclaw/openclaw@c7d4e9e fix(android): smooth gateway pairing recovery · openclaw/openclaw@60e6ccd fix(test): suppress rolldown timing noise · openclaw/openclaw@6d9b388 style(android): fix talk mode ktlint formatting · openclaw/openclaw@01b284c fix(telegram): store topic cache in plugin state fix(telegram): store bot info cache in plugin state · openclaw/openclaw@2ed5296 fix(test): sync sparse AWS Crabbox runs from full checkout · openclaw/openclaw@0f82c81 fix(release): harden Windows cross-os command shims · openclaw/openclaw@7154767 fix(test): harden Docker resource ceilings test(telegram): keep startup limiter coverage focused test(telegram): isolate startup probe limiter timing · openclaw/openclaw@04d86e0 test(release): harden plugin prerelease checks · openclaw/openclaw@578e73f fix(telegram): serialize topic dispatch replies (#85709) · openclaw/openclaw@62b51a6 test(release): stabilize plugin prerelease checks · openclaw/openclaw@3679151 fix(test): fail live gateway false greens · openclaw/openclaw@295339d fix(test): build startup artifacts for smoke scripts · openclaw/openclaw@3838e45 test(telegram): wait for startup probe slots · openclaw/openclaw@0a8af67 test(codex): match sandbox exec-server yolo policy · openclaw/openclaw@783290f fix(test): fail missing explicit test targets · openclaw/openclaw@9ff4d36 test(codex): avoid full sandbox exec-server turn run · openclaw/openclaw@558c1bc fix(ci): keep Crabbox pnpm hydration shims writable · openclaw/openclaw@bca1ac0 fix(release): harden Windows release-check npm probes · openclaw/openclaw@75ac11a fix(docker): parse peer-suffixed lockfile packages · openclaw/openclaw@cf46f2e fix(docker): seed lockfile packages before prune · openclaw/openclaw@f799da0 fix(docker): seed lockfile snapshot tarballs before prune · openclaw/openclaw@2cd93f1 test(codex): type thread start mock params · openclaw/openclaw@a4ef3a2 test(codex): avoid full sandbox run in thread-start test · openclaw/openclaw@11bf642 fix(plugins): harden Windows npm package staging · openclaw/openclaw@abdd8a4 test(codex): complete sandbox turn inline · openclaw/openclaw@c14a0c6 fix(release): harden Windows npm shim verification · openclaw/openclaw@a56f452 test(release): type metadata snapshot mock params · openclaw/openclaw@f878959 test(release): finish plugin metadata prerelease sync fix(update): avoid broad tag fetches for dev updates (#84737) · openclaw/openclaw@501f2cb Fix iMessage slash command acknowledgements (#82642) · openclaw/openclaw@4d15020 test(release): align prerelease contracts · openclaw/openclaw@02f53e6 test(release): align plugin prerelease checks fix(docker): copy prepare hook before install · openclaw/openclaw@0ba6b23 fix: share signed thinking replay policy fix(memory): strip invalid thinking signatures for signed-thinking pr… · openclaw/openclaw@41329c0 fix: preserve signed thinking tool ids · openclaw/openclaw@906476a fix(scripts): harden Windows install checks · openclaw/openclaw@d21abb8 fix(release): keep private QA markers out of bundled alias code · openclaw/openclaw@b972ac1 fix(discord): harden realtime voice wake joins · openclaw/openclaw@fdfcb07 test(parallels): harden release VM smoke isolation · openclaw/openclaw@3839b48 fix: keep blank agent allowlists fail closed (#85849) · openclaw/openclaw@0f83c93 fix: harden session allowlist glob matching (#85849) (thanks @SebTardif) · openclaw/openclaw@88aa713 fix(security): replace regex wildcard matching with linear-time glob … fix(telegram): normalize legacy action targets · openclaw/openclaw@32631eb fix: notify chat when main session recovery fails · openclaw/openclaw@cf61b87 docs(changelog): note restart recovery notice · openclaw/openclaw@ae9308b fix(minimax): normalize OAuth token expiry to absolute millisecond ti… fix(memory-wiki): show vault totals in palace summary (#85824) Isolate boot-md startup sessions (#85919) · openclaw/openclaw@8deb1ef Guard OpenAI image compression for PNG outputs (#85776) · openclaw/openclaw@d075111 fix(agents): clamp proxy completions caps after payload shaping (#85889) · openclaw/openclaw@1d1a7c2 fix: gate discord realtime voice by wake name (#85915) · openclaw/openclaw@17dcdea
fix(test): focus plugin binding Docker smoke · openclaw/openclaw@dfa1a51
vincentkoc · 2026-05-25 · via Recent Commits to openclaw:main
Original file line numberDiff line numberDiff line change

@@ -10,6 +10,7 @@ Docs: https://docs.openclaw.ai

1010
1111

- Channels/iMessage: advance the startup catchup cursor from live-handled rows after a completed catchup pass, including rows received while catchup is still running, so restarts do not replay them. (#85475) Thanks @TurboTheTurtle.

1212

- Tests: mount the shared Windows command helper into bare Docker E2E harness containers so published upgrade-survivor config walks can start on Linux.

13+

- Tests: keep the plugin binding command escape Docker smoke focused on its intended Vitest cases and skip source-only install lifecycle scripts.

1314

- Tests: let the generic plugin install E2E assertions use a configurable temp root and Windows home-relative install paths.

1415

- Tests: keep kitchen-sink plugin assertion fixtures on a configurable temp root so native Windows runs no longer skip full-surface diagnostic coverage.

1516

- Tests: fail Gateway startup benchmarks when a child startup never produces ready probes or process metrics instead of reporting all `n/a` samples as passing.

Original file line numberDiff line numberDiff line change

@@ -32,7 +32,7 @@ docker run --rm \

3232

-e "FOCUSED_TEST_REGEX=$FOCUSED_TEST_REGEX" \

3333

-e OPENCLAW_VITEST_FS_MODULE_CACHE_PATH=/tmp/openclaw-vitest-cache \

3434

"$IMAGE_NAME" \

35-

bash -lc 'set -euo pipefail; corepack enable; node scripts/run-vitest.mjs src/auto-reply/reply/dispatch-from-config.test.ts -- --reporter=verbose -t "$FOCUSED_TEST_REGEX"' \

35+

bash -lc 'set -euo pipefail; corepack enable; node scripts/run-vitest.mjs src/auto-reply/reply/dispatch-from-config.test.ts --reporter=verbose -t "$FOCUSED_TEST_REGEX"' \

3636

>"$RUN_LOG" 2>&1

3737

status=$?

3838

set -e

@@ -43,4 +43,23 @@ if [ "$status" -ne 0 ]; then

4343

exit "$status"

4444

fi

4545
46-

echo "OK"

46+

if ! node - "$RUN_LOG" <<'NODE'

47+

const fs = require("node:fs");

48+

const logPath = process.argv[2];

49+

const text = fs

50+

.readFileSync(logPath, "utf8")

51+

.replace(/\x1B\[[0-?]*[ -/]*[@-~]/gu, "");

52+
53+

if (!/(?:^|\n)\s*Tests\s+3 passed\b/u.test(text)) {

54+

console.error("expected focused Vitest summary for exactly 3 passed tests");

55+

console.error(text.slice(-4000));

56+

process.exit(1);

57+

}

58+

NODE

59+

then

60+

echo "Docker plugin binding command escape smoke did not stay focused"

61+

cat "$RUN_LOG"

62+

exit 1

63+

fi

64+
65+

echo "OK (3 focused tests)"

Original file line numberDiff line numberDiff line change

@@ -9,6 +9,6 @@ RUN corepack enable

99

WORKDIR /workspace/openclaw

1010

COPY . .

1111
12-

RUN pnpm install --frozen-lockfile

12+

RUN OPENCLAW_DISABLE_BUNDLED_PLUGIN_POSTINSTALL=1 pnpm install --frozen-lockfile --ignore-scripts --filter openclaw

1313
1414

CMD ["bash"]

Original file line numberDiff line numberDiff line change

@@ -18,6 +18,10 @@ const OPENAI_WEB_SEARCH_MINIMAL_SCENARIO_PATH =

1818

const OPENAI_WEB_SEARCH_MINIMAL_CLIENT_PATH =

1919

"scripts/e2e/lib/openai-web-search-minimal/client.mjs";

2020

const OPENWEBUI_DOCKER_E2E_PATH = "scripts/e2e/openwebui-docker.sh";

21+

const PLUGIN_BINDING_COMMAND_ESCAPE_DOCKER_E2E_PATH =

22+

"scripts/e2e/plugin-binding-command-escape-docker.sh";

23+

const PLUGIN_BINDING_COMMAND_ESCAPE_DOCKERFILE_PATH =

24+

"scripts/e2e/plugin-binding-command-escape.Dockerfile";

2125

const BUNDLED_PLUGIN_INSTALL_UNINSTALL_E2E_PATH =

2226

"scripts/e2e/bundled-plugin-install-uninstall-docker.sh";

2327

const BUNDLED_PLUGIN_INSTALL_UNINSTALL_SWEEP_PATH =

@@ -383,6 +387,17 @@ describe("docker build helper", () => {

383387

expect(clawhub).toContain("unset OPENCLAW_CLAWHUB_URL CLAWHUB_URL");

384388

});

385389
390+

it("keeps the plugin binding command escape Docker smoke focused", () => {

391+

const runner = readFileSync(PLUGIN_BINDING_COMMAND_ESCAPE_DOCKER_E2E_PATH, "utf8");

392+

const dockerfile = readFileSync(PLUGIN_BINDING_COMMAND_ESCAPE_DOCKERFILE_PATH, "utf8");

393+
394+

expect(runner).toContain("--reporter=verbose -t");

395+

expect(runner).not.toContain("-- --reporter=verbose");

396+

expect(runner).toContain("expected focused Vitest summary for exactly 3 passed tests");

397+

expect(dockerfile).toContain("OPENCLAW_DISABLE_BUNDLED_PLUGIN_POSTINSTALL=1");

398+

expect(dockerfile).toContain("pnpm install --frozen-lockfile --ignore-scripts --filter openclaw");

399+

});

400+
386401

it("covers plugin install/update sources in the Docker plugin sweep", () => {

387402

const sweep = readFileSync(PLUGINS_DOCKER_SWEEP_PATH, "utf8");

388403

const clawhub = readFileSync(PLUGINS_DOCKER_CLAWHUB_PATH, "utf8");