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

推荐订阅源

Stack Overflow Blog
Stack Overflow Blog
酷 壳 – CoolShell
酷 壳 – CoolShell
P
Proofpoint News Feed
Apple Machine Learning Research
Apple Machine Learning Research
T
Tailwind CSS Blog
罗磊的独立博客
F
Future of Privacy Forum
The Register - Security
The Register - Security
MyScale Blog
MyScale Blog
P
Privacy & Cybersecurity Law Blog
V
Visual Studio Blog
T
Tenable Blog
F
Fortinet All Blogs
D
Docker
V
Vulnerabilities – Threatpost
Cyberwarzone
Cyberwarzone
A
Arctic Wolf
T
Threat Research - Cisco Blogs
I
Intezer
T
Tor Project blog
大猫的无限游戏
大猫的无限游戏
MongoDB | Blog
MongoDB | Blog
博客园 - 司徒正美
AWS News Blog
AWS News Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
G
GRAHAM CLULEY
T
Threatpost
美团技术团队
K
Kaspersky official blog
F
Fox-IT International blog
Hugging Face - Blog
Hugging Face - Blog
Vercel News
Vercel News
P
Palo Alto Networks Blog
Google DeepMind News
Google DeepMind News
T
The Blog of Author Tim Ferriss
S
Schneier on Security
腾讯CDC
Cisco Talos Blog
Cisco Talos Blog
C
Check Point Blog
博客园 - 叶小钗
I
InfoQ
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
Blog — PlanetScale
Blog — PlanetScale
F
Full Disclosure
T
True Tiger Recordings
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
E
Exploit-DB.com RSS Feed
L
LINUX DO - 热门话题
J
Java Code Geeks
C
CERT Recently Published Vulnerability Notes

Recent Commits to openclaw:main

test(qa): annotate live transport RTT measurements fix(qqbot): derive outbound watchdog from configured timeouts (#85267… fix: quiet missing daily memory reads fix: tighten empty plugin registry reuse perf: speed up agent transcript lookup fix: guard QMD session stem fallback (#86482) · openclaw/openclaw@2e3b59b Guard OpenAI chat payload turns (#86497) · openclaw/openclaw@489e415 fix(gateway): keep session tool mirrors under pressure · openclaw/openclaw@459e89a docs: route github creation through agent transcript test(tools): add unmocked image custom-provider auth regression (#85733) · openclaw/openclaw@f0bfb3f refactor(plugin-sdk): rename plain text tool-call compat wrapper docs(skills): defer private release locators · openclaw/openclaw@23d38e4 Replace Sharp image backend with Photon (#86437) · openclaw/openclaw@b9f975b fix(agents): release embedded-attempt session lock on every exit path… · openclaw/openclaw@32ddfc2 fix: accept OpenClaw voice wake confusions (#86507) fix(crabbox): bootstrap macos js toolchain chore: add agent transcript skill · openclaw/openclaw@d63e8d4 fix(gateway): dedupe session tool fanout · openclaw/openclaw@89a21db fix: Hook ingress token unlocks password-mode gateway auth (#86453) · openclaw/openclaw@d51f268 fix #86077: keep fallback errors candidate scoped (#86134) · openclaw/openclaw@d6b7fe8 fix(diagnostics): reclaim wedged session lanes with a stale leaked ac… · openclaw/openclaw@6f76d9f fix: derive plugin media trust from metadata (#86410) · openclaw/openclaw@e761eb8 fix(media-understanding): normalize HEIC before image descriptions (#… · openclaw/openclaw@75c7236 fix: accept leading fuzzy Discord voice wake names (#86484) · openclaw/openclaw@8fe4f34 feat: promote provider tool call stream wrapper (#86489) fix(test): dedupe kitchen sink command assertions test: derive deprecated sdk usage guard (#86403) fix(qa): extend memory fallback Windows budget fix(ui): move control ui chunking helper out of runtime source · openclaw/openclaw@968c87d fix: quiet retained lost task noise (#86475) fix(build): keep control ui chunking out of deadcode · openclaw/openclaw@dc26069 fix: rotate realtime voice sessions on max duration · openclaw/openclaw@dc2c4aa fix(test): stream bundled plugin sweep logs · openclaw/openclaw@fc3cd49 docs: add bugfix changelog credits · openclaw/openclaw@2e7e4bc fix(models): show oauth marker auth status (#86378) · openclaw/openclaw@a6df39d fix: seed cron task progress summaries (#86313) · openclaw/openclaw@92afd8b fix(update): exclude prerelease tags from stable git channel (#86260) · openclaw/openclaw@28f169b fix(doctor): warn and continue when cron job store is unreadable (#86… fix(gateway): clear runtime config snapshot before in-process restart… · openclaw/openclaw@90caa3b fix(scripts): restore sparse crabbox changed gates · openclaw/openclaw@d270879 fix(build): support Windows UI builds · openclaw/openclaw@0bb9b42 Fix local embedding worker safety (#85348) · openclaw/openclaw@7ff29a9 fix(ui): scope chat session picker to active agent (#85965) · openclaw/openclaw@70c7d6f [codex] improve iOS realtime talk mode (#86355) · openclaw/openclaw@9ca52ce fix(scripts): dedupe docker lane resources · openclaw/openclaw@5e94469 docs: add code size guidance · openclaw/openclaw@9a60fcf fix(test): avoid source gateway import in rpc walk · openclaw/openclaw@e9b8a6e docs: add bugfix changelog entries · openclaw/openclaw@f950132 Fix heartbeat response loop guard (#86324) (#86357) · openclaw/openclaw@e2c174e fix(memory-core): filter REM dreaming candidates to light-staged entr… · openclaw/openclaw@8b42771 fix(telegram): propagate forum topic names into agent context (#86299) fix(slack): keep downloaded files out of reply media (#86318) · openclaw/openclaw@2fcd481 fix(cron): accept plus durations for one-shot jobs (#86341) · openclaw/openclaw@9239f94 fix(plugins): clear metadata memo at lifecycle boundaries · openclaw/openclaw@e7c696a 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 · openclaw/openclaw@9afbfc1 feat(qa): add coverage scenario matching · openclaw/openclaw@a1fe86a 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(test): clean kitchen sink rpc temp state · openclaw/openclaw@6f695c1
vincentkoc · 2026-05-25 · via Recent Commits to openclaw:main

@@ -54,7 +54,7 @@ function resolveOpenClawRunner() {

5454

return { pnpm: true, baseArgs: ["openclaw"], label: "pnpm openclaw" };

5555

}

565657-

function makeEnv() {

57+

export function makeEnv() {

5858

const root = fs.mkdtempSync(path.join(os.tmpdir(), "openclaw-kitchen-sink-rpc-"));

5959

const home = path.join(root, "home");

6060

const stateDir = path.join(home, ".openclaw");

@@ -75,6 +75,31 @@ function makeEnv() {

7575

};

7676

}

777778+

export async function cleanupKitchenSinkEnv(root, options = {}) {

79+

if (root) {

80+

const attempts = Math.max(1, options.attempts ?? 5);

81+

const delayMs = Math.max(0, options.delayMs ?? 250);

82+

let lastError;

83+

for (let attempt = 1; attempt <= attempts; attempt += 1) {

84+

try {

85+

fs.rmSync(root, { recursive: true, force: true });

86+

return true;

87+

} catch (error) {

88+

lastError = error;

89+

if (attempt < attempts) {

90+

await delay(delayMs);

91+

}

92+

}

93+

}

94+

if (options.warn !== false) {

95+

const message = lastError instanceof Error ? lastError.message : String(lastError);

96+

console.error(`Kitchen Sink RPC temp root cleanup failed; preserved ${root}: ${message}`);

97+

}

98+

return false;

99+

}

100+

return true;

101+

}

102+78103

function writeJson(file, value) {

79104

fs.mkdirSync(path.dirname(file), { recursive: true });

80105

fs.writeFileSync(file, `${JSON.stringify(value, null, 2)}\n`);

@@ -841,53 +866,57 @@ export async function main() {

841866

const port = readPositiveInt(process.env.OPENCLAW_KITCHEN_SINK_RPC_PORT, DEFAULT_PORT);

842867

const { root, env } = makeEnv();

843868

const logPath = path.join(root, "gateway.log");

869+

const keepTmp = process.env.OPENCLAW_KITCHEN_SINK_KEEP_TMP === "1";

870+

let failed = false;

871+

let child;

844872845-

console.log(`Kitchen Sink RPC walk using ${PLUGIN_SPEC} via ${runner.label}`);

846-

await runOpenClaw(runner, ["plugins", "install", PLUGIN_SPEC], env, {

847-

timeoutMs: INSTALL_TIMEOUT_MS,

848-

});

849-

runner = resolveOpenClawRunner();

850-

console.log(`Kitchen Sink RPC runtime runner: ${runner.label}`);

851-

configureKitchenSink(env, port);

852-

await runOpenClaw(runner, ["plugins", "enable", PLUGIN_ID], env, { timeoutMs: 60000 });

853-

const inspect = parseJsonOutput(

854-

(await runOpenClaw(runner, ["plugins", "inspect", PLUGIN_ID, "--runtime", "--json"], env))

855-

.stdout,

856-

);

857-

if (inspect?.plugin?.status !== "loaded") {

858-

throw new Error(`Kitchen Sink plugin did not inspect as loaded: ${JSON.stringify(inspect)}`);

859-

}

860-

const inspectPlugin = inspect.plugin ?? {};

861-

const inspectProviders = [

862-

...(Array.isArray(inspectPlugin.providerIds) ? inspectPlugin.providerIds : []),

863-

...(Array.isArray(inspectPlugin.providers) ? inspectPlugin.providers : []),

864-

];

865-

assertIncludesAny(inspectProviders, EXPECTED_PROVIDERS, "plugins inspect providers");

866-867-

const child = await startGateway(runner, port, env, logPath);

868873

const processSamples = [];

869-

const sampleGateway = async () => {

870-

const windowsSampleOptions = runner.pnpm

871-

? { windowsCommandLineNeedles: ["gateway", "--port", String(port)] }

872-

: {};

873-

let sample = await sampleProcess(child.pid, windowsSampleOptions);

874-

if (!sample && process.platform === "win32") {

875-

sample = await sampleWindowsProcessByPort(port);

876-

}

877-

if (sample) {

878-

processSamples.push(sample);

879-

}

880-

return sample;

881-

};

882874

let sampleInFlight = null;

883-

const collectTimedSample = () => {

884-

sampleInFlight ??= sampleGateway().finally(() => {

885-

sampleInFlight = null;

886-

});

887-

return sampleInFlight;

888-

};

889875

let sampleTimer;

890876

try {

877+

console.log(`Kitchen Sink RPC walk using ${PLUGIN_SPEC} via ${runner.label}`);

878+

await runOpenClaw(runner, ["plugins", "install", PLUGIN_SPEC], env, {

879+

timeoutMs: INSTALL_TIMEOUT_MS,

880+

});

881+

runner = resolveOpenClawRunner();

882+

console.log(`Kitchen Sink RPC runtime runner: ${runner.label}`);

883+

configureKitchenSink(env, port);

884+

await runOpenClaw(runner, ["plugins", "enable", PLUGIN_ID], env, { timeoutMs: 60000 });

885+

const inspect = parseJsonOutput(

886+

(await runOpenClaw(runner, ["plugins", "inspect", PLUGIN_ID, "--runtime", "--json"], env))

887+

.stdout,

888+

);

889+

if (inspect?.plugin?.status !== "loaded") {

890+

throw new Error(`Kitchen Sink plugin did not inspect as loaded: ${JSON.stringify(inspect)}`);

891+

}

892+

const inspectPlugin = inspect.plugin ?? {};

893+

const inspectProviders = [

894+

...(Array.isArray(inspectPlugin.providerIds) ? inspectPlugin.providerIds : []),

895+

...(Array.isArray(inspectPlugin.providers) ? inspectPlugin.providers : []),

896+

];

897+

assertIncludesAny(inspectProviders, EXPECTED_PROVIDERS, "plugins inspect providers");

898+899+

child = await startGateway(runner, port, env, logPath);

900+

const sampleGateway = async () => {

901+

const windowsSampleOptions = runner.pnpm

902+

? { windowsCommandLineNeedles: ["gateway", "--port", String(port)] }

903+

: {};

904+

let sample = await sampleProcess(child.pid, windowsSampleOptions);

905+

if (!sample && process.platform === "win32") {

906+

sample = await sampleWindowsProcessByPort(port);

907+

}

908+

if (sample) {

909+

processSamples.push(sample);

910+

}

911+

return sample;

912+

};

913+

const collectTimedSample = () => {

914+

sampleInFlight ??= sampleGateway().finally(() => {

915+

sampleInFlight = null;

916+

});

917+

return sampleInFlight;

918+

};

919+891920

await waitForGatewayReady(child, port, logPath);

892921

const initialSample = await sampleGateway();

893922

sampleTimer = setInterval(() => {

@@ -996,13 +1025,19 @@ export async function main() {

9961025

);

9971026

console.log("Kitchen Sink RPC walk passed");

9981027

} catch (error) {

1028+

failed = true;

9991029

console.error(tailFile(logPath));

10001030

throw error;

10011031

} finally {

10021032

if (sampleTimer) {

10031033

clearInterval(sampleTimer);

10041034

}

10051035

await stopGateway(child);

1036+

if (!failed && !keepTmp) {

1037+

await cleanupKitchenSinkEnv(root);

1038+

} else if (failed || keepTmp) {

1039+

console.error(`Kitchen Sink RPC temp root preserved: ${root}`);

1040+

}

10061041

}

10071042

}

10081043