silverbullet/packages/plugos/runtime.test.ts

116 lines
2.7 KiB
TypeScript
Raw Normal View History

2022-04-05 23:02:17 +08:00
import { createSandbox } from "./environments/node_sandbox";
import { expect, test } from "@jest/globals";
import { System } from "./system";
test("Run a Node sandbox", async () => {
2022-03-23 22:41:12 +08:00
let system = new System("server");
system.registerSyscalls([], {
2022-03-25 19:03:06 +08:00
addNumbers: (ctx, a, b) => {
return a + b;
},
failingSyscall: () => {
throw new Error("#fail");
},
});
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";
},
});
let plug = await system.load(
{
2022-04-27 01:04:36 +08:00
name: "test",
2022-03-25 19:03:06 +08:00
requiredPermissions: ["dangerous"],
functions: {
addTen: {
code: `(() => {
return {
default: (n) => {
return n + 10;
}
};
})()`,
},
addNumbersSyscall: {
code: `(() => {
return {
default: async (a, b) => {
2022-03-24 17:48:56 +08:00
return await self.syscall("addNumbers", a, b);
}
};
})()`,
},
errorOut: {
code: `(() => {
return {
default: () => {
throw Error("BOOM");
}
};
})()`,
},
errorOutSys: {
code: `(() => {
return {
default: async () => {
2022-03-24 17:48:56 +08:00
await self.syscall("failingSyscall");
}
};
})()`,
},
2022-03-25 19:03:06 +08:00
restrictedTest: {
code: `(() => {
return {
default: async () => {
await self.syscall("restrictedSyscall");
}
};
})()`,
},
dangerousTest: {
code: `(() => {
return {
default: async () => {
return await self.syscall("dangerousSyscall");
}
};
})()`,
},
},
},
2022-03-25 19:03:06 +08:00
createSandbox
);
expect(await plug.invoke("addTen", [10])).toBe(20);
for (let i = 0; i < 100; i++) {
expect(await plug.invoke("addNumbersSyscall", [10, i])).toBe(10 + i);
}
try {
await plug.invoke("errorOut", []);
expect(true).toBe(false);
} catch (e: any) {
expect(e.message).toContain("BOOM");
}
try {
await plug.invoke("errorOutSys", []);
expect(true).toBe(false);
} catch (e: any) {
expect(e.message).toContain("#fail");
}
2022-03-25 19:03:06 +08:00
try {
await plug.invoke("restrictedTest", []);
expect(true).toBe(false);
} catch (e: any) {
expect(e.message).toContain(
2022-03-25 19:03:06 +08:00
"Missing permission 'restricted' for syscall restrictedSyscall"
);
}
expect(await plug.invoke("dangerousTest", [])).toBe("yay");
2022-03-21 22:21:34 +08:00
await system.unloadAll();
});