fix(browser): move browser sdk helper seams into core

This commit is contained in:
Vincent Koc
2026-04-09 08:45:26 +01:00
parent 77e0e3bac5
commit f374fff3bd
7 changed files with 924 additions and 45 deletions

View File

@@ -1,27 +1,32 @@
import { beforeEach, describe, expect, it, vi } from "vitest";
const closeTrackedBrowserTabsForSessionsImpl = vi.hoisted(() => vi.fn());
const movePathToTrashImpl = vi.hoisted(() => vi.fn());
const loadBundledPluginPublicSurfaceModuleSync = vi.hoisted(() => vi.fn());
const runExec = vi.hoisted(() => vi.fn());
vi.mock("../../extensions/browser/browser-maintenance.js", () => ({
closeTrackedBrowserTabsForSessions: closeTrackedBrowserTabsForSessionsImpl,
movePathToTrash: movePathToTrashImpl,
vi.mock("./facade-loader.js", () => ({
loadBundledPluginPublicSurfaceModuleSync,
}));
vi.mock("../process/exec.js", () => ({
runExec,
}));
describe("browser maintenance", () => {
beforeEach(() => {
closeTrackedBrowserTabsForSessionsImpl.mockReset();
movePathToTrashImpl.mockReset();
loadBundledPluginPublicSurfaceModuleSync.mockReset();
runExec.mockReset();
loadBundledPluginPublicSurfaceModuleSync.mockReturnValue({
closeTrackedBrowserTabsForSessions: closeTrackedBrowserTabsForSessionsImpl,
});
});
it("skips browser cleanup when no session keys are provided", async () => {
closeTrackedBrowserTabsForSessionsImpl.mockResolvedValue(0);
const { closeTrackedBrowserTabsForSessions } = await import("./browser-maintenance.js");
await expect(closeTrackedBrowserTabsForSessions({ sessionKeys: [] })).resolves.toBe(0);
expect(closeTrackedBrowserTabsForSessionsImpl).toHaveBeenCalledWith({ sessionKeys: [] });
expect(movePathToTrashImpl).not.toHaveBeenCalled();
expect(loadBundledPluginPublicSurfaceModuleSync).not.toHaveBeenCalled();
});
it("delegates cleanup through the browser maintenance surface", async () => {
@@ -32,17 +37,26 @@ describe("browser maintenance", () => {
await expect(
closeTrackedBrowserTabsForSessions({ sessionKeys: ["agent:main:test"] }),
).resolves.toBe(2);
expect(loadBundledPluginPublicSurfaceModuleSync).toHaveBeenCalledWith({
dirName: "browser",
artifactBasename: "browser-maintenance.js",
});
expect(closeTrackedBrowserTabsForSessionsImpl).toHaveBeenCalledWith({
sessionKeys: ["agent:main:test"],
});
});
it("delegates move-to-trash through the browser maintenance surface", async () => {
movePathToTrashImpl.mockImplementation(async (targetPath: string) => `${targetPath}.trashed`);
it("uses the local trash command before falling back", async () => {
runExec.mockResolvedValue({
stdout: "",
stderr: "",
code: 0,
signal: null,
});
const { movePathToTrash } = await import("./browser-maintenance.js");
await expect(movePathToTrash("/tmp/demo")).resolves.toBe("/tmp/demo.trashed");
expect(movePathToTrashImpl).toHaveBeenCalledWith("/tmp/demo");
await expect(movePathToTrash("/tmp/demo")).resolves.toBe("/tmp/demo");
expect(runExec).toHaveBeenCalledWith("trash", ["/tmp/demo"], { timeoutMs: 10_000 });
});
});