silverbullet/cmd/test/runtime.test.ts

93 lines
2.4 KiB
TypeScript
Raw Normal View History

import { createSandbox } from "../../lib/plugos/sandboxes/deno_worker_sandbox.ts";
import { System } from "../../lib/plugos/system.ts";
import { assert, assertEquals } from "$std/testing/asserts.ts";
import { compileManifest } from "../compile.ts";
import * as esbuild from "esbuild";
import {
createSandbox as createNoSandbox,
runWithSystemLock,
} from "../../lib/plugos/sandboxes/no_sandbox.ts";
import { SysCallMapping } from "../../lib/plugos/system.ts";
import { sleep } from "../../lib/async.ts";
2024-01-28 21:13:37 +08:00
Deno.test("Run a deno sandbox", {
sanitizeResources: false,
sanitizeOps: false,
}, async () => {
const system = new System("server");
system.registerSyscalls([], {
addNumbers: (_ctx, a, b) => {
return a + b;
},
failingSyscall: () => {
throw new Error("#fail");
},
} as SysCallMapping);
system.registerSyscalls(["restricted"], {
2022-03-25 19:03:06 +08:00
restrictedSyscall: () => {
return "restricted";
},
});
system.registerSyscalls(["dangerous"], {
2022-03-25 19:03:06 +08:00
dangerousSyscall: () => {
return "yay";
},
});
const tempDir = await Deno.makeTempDir();
2022-10-13 21:16:18 +08:00
const workerPath = await compileManifest(
new URL("test_runtime.plug.yaml", import.meta.url).pathname,
tempDir,
);
const plug = await system.load(
"test",
createSandbox(new URL(`file://${workerPath}`)),
);
2024-01-14 20:38:39 +08:00
assertEquals({
addedNumbers: 3,
yamlMessage: "hello: world\n",
}, await plug.invoke("boot", []));
2024-01-14 20:38:39 +08:00
await system.unloadAll();
// Now load directly from module
const { plug: plugExport } = await import(
`file://${workerPath}`
);
const plug2 = await system.load("test", createNoSandbox(plugExport));
2024-01-14 20:38:39 +08:00
let running = false;
await Promise.all([
runWithSystemLock(system, async () => {
console.log("Starting first run");
running = true;
await sleep(5);
assertEquals({
addedNumbers: 3,
yamlMessage: "hello: world\n",
}, await plug2.invoke("boot", []));
console.log("Done first run");
running = false;
}),
runWithSystemLock(system, async () => {
assert(!running);
console.log("Starting second run");
assertEquals({
addedNumbers: 3,
yamlMessage: "hello: world\n",
}, await plug2.invoke("boot", []));
console.log("Done second run");
}),
]);
2022-03-25 19:03:06 +08:00
2022-03-21 22:21:34 +08:00
await system.unloadAll();
await Deno.remove(tempDir, { recursive: true });
esbuild.stop();
});