perf(test): consolidate browser and canvas hotspot suites

This commit is contained in:
Peter Steinberger
2026-02-14 01:07:07 +00:00
parent 7f0d6b1fcb
commit 8796bfaaac
2 changed files with 115 additions and 237 deletions

View File

@@ -11,6 +11,10 @@ import { A2UI_PATH, CANVAS_HOST_PATH, CANVAS_WS_PATH, injectCanvasLiveReload } f
import { createCanvasHostHandler, startCanvasHost } from "./server.js";
describe("canvas host", () => {
const quietRuntime = {
...defaultRuntime,
log: (..._args: Parameters<typeof console.log>) => {},
};
let fixtureRoot = "";
let fixtureCount = 0;
@@ -40,7 +44,7 @@ describe("canvas host", () => {
const dir = await createCaseDir();
const server = await startCanvasHost({
runtime: defaultRuntime,
runtime: quietRuntime,
rootDir: dir,
port: 0,
listenHost: "127.0.0.1",
@@ -64,7 +68,7 @@ describe("canvas host", () => {
await fs.writeFile(path.join(dir, "index.html"), "<html><body>no-reload</body></html>", "utf8");
const server = await startCanvasHost({
runtime: defaultRuntime,
runtime: quietRuntime,
rootDir: dir,
port: 0,
listenHost: "127.0.0.1",
@@ -91,7 +95,7 @@ describe("canvas host", () => {
await fs.writeFile(path.join(dir, "index.html"), "<html><body>v1</body></html>", "utf8");
const handler = await createCanvasHostHandler({
runtime: defaultRuntime,
runtime: quietRuntime,
rootDir: dir,
basePath: CANVAS_HOST_PATH,
allowInTests: true,
@@ -139,7 +143,7 @@ describe("canvas host", () => {
await fs.writeFile(path.join(dir, "index.html"), "<html><body>v1</body></html>", "utf8");
const handler = await createCanvasHostHandler({
runtime: defaultRuntime,
runtime: quietRuntime,
rootDir: dir,
basePath: CANVAS_HOST_PATH,
allowInTests: true,
@@ -149,7 +153,7 @@ describe("canvas host", () => {
handler.close = closeSpy;
const server = await startCanvasHost({
runtime: defaultRuntime,
runtime: quietRuntime,
handler,
ownsHandler: false,
port: 0,
@@ -172,7 +176,7 @@ describe("canvas host", () => {
await fs.writeFile(index, "<html><body>v1</body></html>", "utf8");
const server = await startCanvasHost({
runtime: defaultRuntime,
runtime: quietRuntime,
rootDir: dir,
port: 0,
listenHost: "127.0.0.1",
@@ -215,82 +219,7 @@ describe("canvas host", () => {
}
}, 20_000);
it("serves the gateway-hosted A2UI scaffold", async () => {
const dir = await createCaseDir();
const a2uiRoot = path.resolve(process.cwd(), "src/canvas-host/a2ui");
const bundlePath = path.join(a2uiRoot, "a2ui.bundle.js");
let createdBundle = false;
try {
await fs.stat(bundlePath);
} catch {
await fs.writeFile(bundlePath, "window.openclawA2UI = {};", "utf8");
createdBundle = true;
}
const server = await startCanvasHost({
runtime: defaultRuntime,
rootDir: dir,
port: 0,
listenHost: "127.0.0.1",
allowInTests: true,
});
try {
const res = await fetch(`http://127.0.0.1:${server.port}/__openclaw__/a2ui/`);
const html = await res.text();
expect(res.status).toBe(200);
expect(html).toContain("openclaw-a2ui-host");
expect(html).toContain("openclawCanvasA2UIAction");
const bundleRes = await fetch(
`http://127.0.0.1:${server.port}/__openclaw__/a2ui/a2ui.bundle.js`,
);
const js = await bundleRes.text();
expect(bundleRes.status).toBe(200);
expect(js).toContain("openclawA2UI");
} finally {
await server.close();
if (createdBundle) {
await fs.rm(bundlePath, { force: true });
}
}
});
it("rejects traversal-style A2UI asset requests", async () => {
const dir = await createCaseDir();
const a2uiRoot = path.resolve(process.cwd(), "src/canvas-host/a2ui");
const bundlePath = path.join(a2uiRoot, "a2ui.bundle.js");
let createdBundle = false;
try {
await fs.stat(bundlePath);
} catch {
await fs.writeFile(bundlePath, "window.openclawA2UI = {};", "utf8");
createdBundle = true;
}
const server = await startCanvasHost({
runtime: defaultRuntime,
rootDir: dir,
port: 0,
listenHost: "127.0.0.1",
allowInTests: true,
});
try {
const res = await fetch(`http://127.0.0.1:${server.port}${A2UI_PATH}/%2e%2e%2fpackage.json`);
expect(res.status).toBe(404);
expect(await res.text()).toBe("not found");
} finally {
await server.close();
if (createdBundle) {
await fs.rm(bundlePath, { force: true });
}
}
});
it("rejects A2UI symlink escapes", async () => {
it("serves A2UI scaffold and blocks traversal/symlink escapes", async () => {
const dir = await createCaseDir();
const a2uiRoot = path.resolve(process.cwd(), "src/canvas-host/a2ui");
const bundlePath = path.join(a2uiRoot, "a2ui.bundle.js");
@@ -310,7 +239,7 @@ describe("canvas host", () => {
createdLink = true;
const server = await startCanvasHost({
runtime: defaultRuntime,
runtime: quietRuntime,
rootDir: dir,
port: 0,
listenHost: "127.0.0.1",
@@ -318,9 +247,26 @@ describe("canvas host", () => {
});
try {
const res = await fetch(`http://127.0.0.1:${server.port}${A2UI_PATH}/${linkName}`);
expect(res.status).toBe(404);
expect(await res.text()).toBe("not found");
const res = await fetch(`http://127.0.0.1:${server.port}/__openclaw__/a2ui/`);
const html = await res.text();
expect(res.status).toBe(200);
expect(html).toContain("openclaw-a2ui-host");
expect(html).toContain("openclawCanvasA2UIAction");
const bundleRes = await fetch(
`http://127.0.0.1:${server.port}/__openclaw__/a2ui/a2ui.bundle.js`,
);
const js = await bundleRes.text();
expect(bundleRes.status).toBe(200);
expect(js).toContain("openclawA2UI");
const traversalRes = await fetch(
`http://127.0.0.1:${server.port}${A2UI_PATH}/%2e%2e%2fpackage.json`,
);
expect(traversalRes.status).toBe(404);
expect(await traversalRes.text()).toBe("not found");
const symlinkRes = await fetch(`http://127.0.0.1:${server.port}${A2UI_PATH}/${linkName}`);
expect(symlinkRes.status).toBe(404);
expect(await symlinkRes.text()).toBe("not found");
} finally {
await server.close();
if (createdLink) {