561aa6891f
Big bang migration to Deno 🤯
165 lines
3.9 KiB
TypeScript
165 lines
3.9 KiB
TypeScript
import { createSandbox } from "./environments/deno_sandbox.ts";
|
|
import { System } from "./system.ts";
|
|
|
|
import {
|
|
assert,
|
|
assertEquals,
|
|
} from "https://deno.land/std@0.158.0/testing/asserts.ts";
|
|
|
|
Deno.test("Run a deno sandbox", async () => {
|
|
const system = new System("server");
|
|
system.registerSyscalls([], {
|
|
addNumbers: (_ctx, a, b) => {
|
|
return a + b;
|
|
},
|
|
failingSyscall: () => {
|
|
throw new Error("#fail");
|
|
},
|
|
});
|
|
system.registerSyscalls(["restricted"], {
|
|
restrictedSyscall: () => {
|
|
return "restricted";
|
|
},
|
|
});
|
|
system.registerSyscalls(["dangerous"], {
|
|
dangerousSyscall: () => {
|
|
return "yay";
|
|
},
|
|
});
|
|
const plug = await system.load(
|
|
{
|
|
name: "test",
|
|
requiredPermissions: ["dangerous"],
|
|
functions: {
|
|
addTen: {
|
|
code: `(() => {
|
|
return {
|
|
default: (n) => {
|
|
return n + 10;
|
|
}
|
|
};
|
|
})()`,
|
|
},
|
|
addNumbersSyscall: {
|
|
code: `(() => {
|
|
return {
|
|
default: async (a, b) => {
|
|
return await self.syscall("addNumbers", a, b);
|
|
}
|
|
};
|
|
})()`,
|
|
},
|
|
errorOut: {
|
|
code: `(() => {
|
|
return {
|
|
default: () => {
|
|
throw Error("BOOM");
|
|
}
|
|
};
|
|
})()`,
|
|
},
|
|
errorOutSys: {
|
|
code: `(() => {
|
|
return {
|
|
default: async () => {
|
|
await self.syscall("failingSyscall");
|
|
}
|
|
};
|
|
})()`,
|
|
},
|
|
restrictedTest: {
|
|
code: `(() => {
|
|
return {
|
|
default: async () => {
|
|
await self.syscall("restrictedSyscall");
|
|
}
|
|
};
|
|
})()`,
|
|
},
|
|
dangerousTest: {
|
|
code: `(() => {
|
|
return {
|
|
default: async () => {
|
|
return await self.syscall("dangerousSyscall");
|
|
}
|
|
};
|
|
})()`,
|
|
},
|
|
},
|
|
},
|
|
createSandbox,
|
|
);
|
|
assertEquals(await plug.invoke("addTen", [10]), 20);
|
|
for (let i = 0; i < 100; i++) {
|
|
assertEquals(await plug.invoke("addNumbersSyscall", [10, i]), 10 + i);
|
|
}
|
|
try {
|
|
await plug.invoke("errorOut", []);
|
|
assert(false);
|
|
} catch (e: any) {
|
|
assert(e.message.indexOf("BOOM") !== -1);
|
|
}
|
|
try {
|
|
await plug.invoke("errorOutSys", []);
|
|
assert(false);
|
|
} catch (e: any) {
|
|
assert(e.message.indexOf("#fail") !== -1);
|
|
}
|
|
try {
|
|
await plug.invoke("restrictedTest", []);
|
|
assert(false);
|
|
} catch (e: any) {
|
|
assert(
|
|
e.message.indexOf(
|
|
"Missing permission 'restricted' for syscall restrictedSyscall",
|
|
) !== -1,
|
|
);
|
|
}
|
|
assertEquals(await plug.invoke("dangerousTest", []), "yay");
|
|
|
|
await system.unloadAll();
|
|
});
|
|
|
|
import { bundle as plugOsBundle } from "./bin/plugos-bundle.ts";
|
|
import { esbuild } from "./compile.ts";
|
|
const __dirname = new URL(".", import.meta.url).pathname;
|
|
|
|
Deno.test("Preload dependencies", async () => {
|
|
const globalModules = await plugOsBundle(
|
|
`${__dirname}../plugs/global.plug.yaml`,
|
|
);
|
|
// const globalModules = JSON.parse(
|
|
// Deno.readTextFileSync(`${tmpDist}/global.plug.json`),
|
|
// );
|
|
const testPlugManifest = await plugOsBundle(
|
|
`${__dirname}test.plug.yaml`,
|
|
{ excludeModules: Object.keys(globalModules.dependencies!) },
|
|
);
|
|
esbuild.stop();
|
|
|
|
const system = new System("server");
|
|
system.on({
|
|
plugLoaded: async (plug) => {
|
|
for (
|
|
const [modName, code] of Object.entries(globalModules.dependencies!)
|
|
) {
|
|
await plug.sandbox.loadDependency(modName, code as string);
|
|
}
|
|
},
|
|
});
|
|
|
|
// Load test module
|
|
console.log("Loading test module");
|
|
const testPlug = await system.load(
|
|
testPlugManifest,
|
|
createSandbox,
|
|
);
|
|
console.log("Running");
|
|
|
|
const result = await testPlug.invoke("boot", []);
|
|
|
|
console.log("Result", result);
|
|
|
|
await system.unloadAll();
|
|
});
|