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

推荐订阅源

Martin Fowler
Martin Fowler
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
T
Threat Research - Cisco Blogs
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
C
Cyber Attacks, Cyber Crime and Cyber Security
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
T
Troy Hunt's Blog
V
V2EX - 技术
Hacker News - Newest:
Hacker News - Newest: "LLM"
H
Heimdal Security Blog
T
Tor Project blog
IT之家
IT之家
Project Zero
Project Zero
GbyAI
GbyAI
Security Latest
Security Latest
S
Security Archives - TechRepublic
人人都是产品经理
人人都是产品经理
大猫的无限游戏
大猫的无限游戏
Spread Privacy
Spread Privacy
S
Security Affairs
A
Arctic Wolf
C
Cybersecurity and Infrastructure Security Agency CISA
I
Intezer
P
Palo Alto Networks Blog
宝玉的分享
宝玉的分享
Google DeepMind News
Google DeepMind News
T
Threatpost
I
InfoQ
F
Full Disclosure
Blog — PlanetScale
Blog — PlanetScale
Last Week in AI
Last Week in AI
Cisco Talos Blog
Cisco Talos Blog
N
Netflix TechBlog - Medium
MyScale Blog
MyScale Blog
H
Help Net Security
S
Securelist
Y
Y Combinator Blog
月光博客
月光博客
博客园_首页
Engineering at Meta
Engineering at Meta
酷 壳 – CoolShell
酷 壳 – CoolShell
J
Java Code Geeks
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
A
About on SuperTechFans
K
Kaspersky official blog
Microsoft Azure Blog
Microsoft Azure Blog
Vercel News
Vercel News
阮一峰的网络日志
阮一峰的网络日志
T
The Exploit Database - CXSecurity.com
B
Blog

Recent Commits to openclaw:main

test: merge chat side-result checks · openclaw/openclaw@ddd2c2a test: merge cron history checks · openclaw/openclaw@f7eb746 test: merge responsive navigation shell checks · openclaw/openclaw@c2e4b47 docs(changelog): add codex oauth fixes · openclaw/openclaw@628e6cd test: merge navigation routing cases · openclaw/openclaw@5d8cecb Tests: mock channel registry bundled fallback · openclaw/openclaw@2b08233 Secrets: avoid broad web search discovery for single plugin config · openclaw/openclaw@a464f59 test: merge config view browser checks · openclaw/openclaw@20cf511 fix(status): align oauth health with runtime · openclaw/openclaw@eed7116 feat: add macOS screen snapshots for monitor preview (#67954) thanks … · openclaw/openclaw@f377db1 fix: report shared auth scopes in hello-ok (#67810) thanks @BunsDev · openclaw/openclaw@0b6c39b Auto-reply: avoid eager bundled route fallback · openclaw/openclaw@3ea1bf4 Tests: narrow session binding contract setup · openclaw/openclaw@54e4e16 fix(macOS): enable undo/redo in webchat composer text input (#34962) · openclaw/openclaw@00951dc Tests: speed up channel setup promotion · openclaw/openclaw@82b529a Docs: refresh agent instructions · openclaw/openclaw@5775fe2 fix(auth): serialize OAuth refresh across agents to fix #26322 (#67876) · openclaw/openclaw@8e79080 test: allow ollama public surface boundary test · openclaw/openclaw@7d4f1a6 Docs: add test performance guardrails · openclaw/openclaw@89706d3 Tests: restore context-engine usage proof · openclaw/openclaw@e4c4f95 Tests: slim context engine runtime coverage · openclaw/openclaw@74c198f ci: retry failed custom checkouts · openclaw/openclaw@0ee5baf test: trim duplicate provider auth onboarding cases · openclaw/openclaw@1ffc02e matrix: fix sessions_spawn --thread subagent session spawning (#67643) · openclaw/openclaw@1ce2596 test: reduce auth choice fixture churn · openclaw/openclaw@857b9cd test: mock health status config boundaries · openclaw/openclaw@9d5ab4a test: mock onboard config io boundary · openclaw/openclaw@299694d test: mock legacy state plugin boundaries · openclaw/openclaw@2713089 test: mock channel install boundaries · openclaw/openclaw@b945248 test: mock doctor preview channel boundaries · openclaw/openclaw@b1a3ad4 test: trim doctor command hotspots · openclaw/openclaw@c66f16a test: isolate agent auth and spawn hotspots · openclaw/openclaw@9285935 test: stabilize MCP startup disposal race · openclaw/openclaw@dd9d2eb test: merge browser contract server suites · openclaw/openclaw@5817a76 test: narrow ollama provider discovery setup · openclaw/openclaw@a0d9598 build: declare qa-lab aimock runtime dependency · openclaw/openclaw@24431e5 test: speed up safe-bins exec harness · openclaw/openclaw@ee856ab test: preserve tool helpers in embedded runner mocks · openclaw/openclaw@acd86a0 refactor: move memory embeddings into provider plugins · openclaw/openclaw@77e6e4c test: reuse system-run temp fixtures · openclaw/openclaw@7e9ff0f test: trim hotspot wait overhead · openclaw/openclaw@12a59b0 Check: avoid duplicate boundary prep · openclaw/openclaw@baf11b8 test: reduce hotspot fixture overhead · openclaw/openclaw@3a59edd feat(ui): overhaul settings and slash command UX (#67819) thanks @Bun… · openclaw/openclaw@2cfb660 QA Matrix: exit cleanly on failure · openclaw/openclaw@42805d2 QA Matrix: isolate scenario coverage · openclaw/openclaw@7e659e1 Matrix: refresh crypto bootstrap state · openclaw/openclaw@94081d8 QA Lab: add provider registry · openclaw/openclaw@bb7e982 Matrix: add plugin changelog · openclaw/openclaw@4acab55 test: trim more hotspot overhead · openclaw/openclaw@f485311 test: trim remaining hotspot tests · openclaw/openclaw@6ba8626 test: narrow hotspot mocks · openclaw/openclaw@dbc8179 test: isolate gemini embedding request helpers · openclaw/openclaw@cd330f5 test: trim memory and mcp hotspots · openclaw/openclaw@fd48dfa test: slim provider registry mocks · openclaw/openclaw@2e08c77 test: harden Parallels update smoke · openclaw/openclaw@1a98090 feat: default Anthropic to Opus 4.7 · openclaw/openclaw@628b454 fix: harden node-host shell payload mutability checks · openclaw/openclaw@75c551e fix: land node-host approval binding for native binaries (#66731) (th… · openclaw/openclaw@29919bb CI: add daily schedule to CodeQL workflow (#67645) fix(gateway): capture config hash after plugin auto-enable to prevent… · openclaw/openclaw@8c11210 fix: repair sanitized replay tool results before send (#67620) (thank… fix: restrict HTML timeout short-circuit to transient statuses fix: keep TUI watchdog bound to active run (#67401) (thanks @xantorres) Gateway/skills: dedupe skills prefix-match + drop dead fallback on log Extensions/lmstudio: back off inference preload after consecutive fai… TUI/streaming: add watchdog that resets the activity indicator after … Agents/tool-loop: enable unknown-tool stream guard by default · openclaw/openclaw@36ed367 Gateway/skills: invalidate session skills snapshot on config write fix: classify HTML provider error pages correctly (#67642) (thanks @s… fix(skills): remove unused model-usage import (#67641) · openclaw/openclaw@55f05df docs(changelog): credit codex fix superseded PRs · openclaw/openclaw@e485f24 fix(openai-codex): normalize stale transport metadata in resolution a… · openclaw/openclaw@90801ba CI: pin Docker-related GitHub Actions (#67632) · openclaw/openclaw@f697b01 Android: modernize WebView and discovery API usage (#67627) · openclaw/openclaw@44a6e50 fix(deps): bump hono to 4.12.14 and @hono/node-server to 1.19.14 (GHS… fix(deps): bump dompurify to 3.4.0 (#67614) CI: add explicit permissions to all workflow jobs (fixes code-scannin… fix: register bundled TTS providers and route overrides correctly (#6… fix: align host tilde paths with OS home (#62804) (thanks @stainlu) fix: flush creds queue before reconnect socket open (#67464) (thanks … · openclaw/openclaw@405c63f fix: strip standalone <function> tool call tags from visible text (#6… · openclaw/openclaw@78df859 fix(agents): preserve cli session metadata before transcript persist … · openclaw/openclaw@898fd04 docs(changelog): move cli transcript entry · openclaw/openclaw@c1817c6 fix(agents): normalize cli transcript api field · openclaw/openclaw@3a3fae0 docs(changelog): note cli transcript persistence · openclaw/openclaw@6c343f1 fix(agents): persist cli transcript turns · openclaw/openclaw@b8ef507 fix(msteams): harden security-sensitive flows (#65841) · openclaw/openclaw@c56b56e [Dashboard] Fix exec approval modal overflow for long command content… · openclaw/openclaw@053c5b0 Docs: remove QA changelog entry · openclaw/openclaw@7fd5771 QA: fix private runtime source loading (#67428) · openclaw/openclaw@d5933af docs(gateway): correct protocol.md schema path, hello-ok example, aut… · openclaw/openclaw@489404d CI: pin Node 22 runners to 22.18.0 · openclaw/openclaw@4ffa621 models.authStatus: normalize provider ids + tighten env-backed escape… · openclaw/openclaw@f2fdb9d Update CHANGELOG.md · openclaw/openclaw@7694a92 test(parallels): clean up npm update guard jobs · openclaw/openclaw@045ea7b Plugins: prefer scanDir override paths · openclaw/openclaw@b2974da fix(dreaming): default storage.mode to "separate" so phase blocks sto… · openclaw/openclaw@8c392f0 fix(memory-core): skip dreaming transcript ingestion via session stor… · openclaw/openclaw@a1b01f0 fix: dedupe replayed exec.finished node events (#67281) · openclaw/openclaw@5dcf526
fix(hooks): avoid stale lancedb startup fallback · openclaw/openclaw@386a088
vincentkoc · 2026-04-23 · via Recent Commits to openclaw:main

@@ -511,6 +511,117 @@ describe("memory plugin e2e", () => {

511511

}

512512

});

513513514+

test("fails closed for auto-recall when the live plugin entry is removed", async () => {

515+

const embeddingsCreate = vi.fn(async () => ({

516+

data: [{ embedding: [0.1, 0.2, 0.3] }],

517+

}));

518+

const ensureGlobalUndiciEnvProxyDispatcher = vi.fn();

519+

const loadLanceDbModule = vi.fn(async () => ({

520+

connect: vi.fn(async () => ({

521+

tableNames: vi.fn(async () => ["memories"]),

522+

openTable: vi.fn(async () => ({

523+

vectorSearch: vi.fn(() => ({ limit: vi.fn(() => ({ toArray: vi.fn(async () => []) })) })),

524+

countRows: vi.fn(async () => 0),

525+

add: vi.fn(async () => undefined),

526+

delete: vi.fn(async () => undefined),

527+

})),

528+

})),

529+

}));

530+

let configFile: Record<string, unknown> = {

531+

plugins: {

532+

entries: {

533+

"memory-lancedb": {

534+

config: {

535+

embedding: {

536+

apiKey: OPENAI_API_KEY,

537+

model: "text-embedding-3-small",

538+

},

539+

dbPath: getDbPath(),

540+

autoCapture: false,

541+

autoRecall: true,

542+

},

543+

},

544+

},

545+

},

546+

};

547+548+

vi.resetModules();

549+

vi.doMock("openclaw/plugin-sdk/runtime-env", () => ({

550+

ensureGlobalUndiciEnvProxyDispatcher,

551+

}));

552+

vi.doMock("openai", () => ({

553+

default: class MockOpenAI {

554+

embeddings = { create: embeddingsCreate };

555+

},

556+

}));

557+

vi.doMock("./lancedb-runtime.js", () => ({

558+

loadLanceDbModule,

559+

}));

560+561+

try {

562+

const { default: dynamicMemoryPlugin } = await import("./index.js");

563+

const on = vi.fn();

564+

const mockApi = {

565+

id: "memory-lancedb",

566+

name: "Memory (LanceDB)",

567+

source: "test",

568+

config: {},

569+

pluginConfig: {

570+

embedding: {

571+

apiKey: OPENAI_API_KEY,

572+

model: "text-embedding-3-small",

573+

},

574+

dbPath: getDbPath(),

575+

autoCapture: false,

576+

autoRecall: true,

577+

},

578+

runtime: {

579+

config: {

580+

loadConfig: () => configFile,

581+

},

582+

},

583+

logger: {

584+

info: vi.fn(),

585+

warn: vi.fn(),

586+

error: vi.fn(),

587+

debug: vi.fn(),

588+

},

589+

registerTool: vi.fn(),

590+

registerCli: vi.fn(),

591+

registerService: vi.fn(),

592+

on,

593+

resolvePath: (p: string) => p,

594+

};

595+596+

dynamicMemoryPlugin.register(mockApi as any);

597+598+

configFile = {

599+

plugins: {

600+

entries: {},

601+

},

602+

};

603+604+

const beforePromptBuild = on.mock.calls.find(

605+

([hookName]) => hookName === "before_prompt_build",

606+

)?.[1];

607+

expect(beforePromptBuild).toBeTypeOf("function");

608+609+

const result = await beforePromptBuild?.(

610+

{ prompt: "what editor should i use after memory is removed?", messages: [] },

611+

{},

612+

);

613+614+

expect(result).toBeUndefined();

615+

expect(embeddingsCreate).not.toHaveBeenCalled();

616+

expect(loadLanceDbModule).not.toHaveBeenCalled();

617+

} finally {

618+

vi.doUnmock("openclaw/plugin-sdk/runtime-env");

619+

vi.doUnmock("openai");

620+

vi.doUnmock("./lancedb-runtime.js");

621+

vi.resetModules();

622+

}

623+

});

624+514625

test("runs auto-capture through the registered agent_end hook", async () => {

515626

const embeddingsCreate = vi.fn(async () => ({

516627

data: [{ embedding: [0.1, 0.2, 0.3] }],

@@ -744,6 +855,119 @@ describe("memory plugin e2e", () => {

744855

}

745856

});

746857858+

test("fails closed for auto-capture when the live plugin entry is removed", async () => {

859+

const embeddingsCreate = vi.fn(async () => ({

860+

data: [{ embedding: [0.1, 0.2, 0.3] }],

861+

}));

862+

const ensureGlobalUndiciEnvProxyDispatcher = vi.fn();

863+

const add = vi.fn(async () => undefined);

864+

const loadLanceDbModule = vi.fn(async () => ({

865+

connect: vi.fn(async () => ({

866+

tableNames: vi.fn(async () => ["memories"]),

867+

openTable: vi.fn(async () => ({

868+

vectorSearch: vi.fn(() => ({ limit: vi.fn(() => ({ toArray: vi.fn(async () => []) })) })),

869+

countRows: vi.fn(async () => 0),

870+

add,

871+

delete: vi.fn(async () => undefined),

872+

})),

873+

})),

874+

}));

875+

let configFile: Record<string, unknown> = {

876+

plugins: {

877+

entries: {

878+

"memory-lancedb": {

879+

config: {

880+

embedding: {

881+

apiKey: OPENAI_API_KEY,

882+

model: "text-embedding-3-small",

883+

},

884+

dbPath: getDbPath(),

885+

autoCapture: true,

886+

autoRecall: false,

887+

},

888+

},

889+

},

890+

},

891+

};

892+893+

vi.resetModules();

894+

vi.doMock("openclaw/plugin-sdk/runtime-env", () => ({

895+

ensureGlobalUndiciEnvProxyDispatcher,

896+

}));

897+

vi.doMock("openai", () => ({

898+

default: class MockOpenAI {

899+

embeddings = { create: embeddingsCreate };

900+

},

901+

}));

902+

vi.doMock("./lancedb-runtime.js", () => ({

903+

loadLanceDbModule,

904+

}));

905+906+

try {

907+

const { default: dynamicMemoryPlugin } = await import("./index.js");

908+

const on = vi.fn();

909+

const mockApi = {

910+

id: "memory-lancedb",

911+

name: "Memory (LanceDB)",

912+

source: "test",

913+

config: {},

914+

pluginConfig: {

915+

embedding: {

916+

apiKey: OPENAI_API_KEY,

917+

model: "text-embedding-3-small",

918+

},

919+

dbPath: getDbPath(),

920+

autoCapture: true,

921+

autoRecall: false,

922+

},

923+

runtime: {

924+

config: {

925+

loadConfig: () => configFile,

926+

},

927+

},

928+

logger: {

929+

info: vi.fn(),

930+

warn: vi.fn(),

931+

error: vi.fn(),

932+

debug: vi.fn(),

933+

},

934+

registerTool: vi.fn(),

935+

registerCli: vi.fn(),

936+

registerService: vi.fn(),

937+

on,

938+

resolvePath: (p: string) => p,

939+

};

940+941+

dynamicMemoryPlugin.register(mockApi as any);

942+943+

configFile = {

944+

plugins: {

945+

entries: {},

946+

},

947+

};

948+949+

const agentEnd = on.mock.calls.find(([hookName]) => hookName === "agent_end")?.[1];

950+

expect(agentEnd).toBeTypeOf("function");

951+952+

await agentEnd?.(

953+

{

954+

success: true,

955+

messages: [{ role: "user", content: "I prefer Helix for editing code every day." }],

956+

},

957+

{},

958+

);

959+960+

expect(embeddingsCreate).not.toHaveBeenCalled();

961+

expect(loadLanceDbModule).not.toHaveBeenCalled();

962+

expect(add).not.toHaveBeenCalled();

963+

} finally {

964+

vi.doUnmock("openclaw/plugin-sdk/runtime-env");

965+

vi.doUnmock("openai");

966+

vi.doUnmock("./lancedb-runtime.js");

967+

vi.resetModules();

968+

}

969+

});

970+747971

test("passes configured dimensions to OpenAI embeddings API", async () => {

748972

const embeddingsCreate = vi.fn(async () => ({

749973

data: [{ embedding: [0.1, 0.2, 0.3] }],