2022-10-10 12:50:21 +00:00
|
|
|
import { assertEquals } from "../../test_deps.ts";
|
|
|
|
import { SQLite } from "../../server/deps.ts";
|
2022-10-11 09:43:28 +00:00
|
|
|
import { sandboxFactory } from "../environments/deno_sandbox.ts";
|
2022-10-10 12:50:21 +00:00
|
|
|
import { System } from "../system.ts";
|
|
|
|
import { ensureTable, storeSyscalls } from "./store.deno.ts";
|
2022-03-25 11:03:06 +00:00
|
|
|
|
2022-10-11 09:43:28 +00:00
|
|
|
import assetBundle from "../../dist/asset_bundle.json" assert { type: "json" };
|
|
|
|
import { AssetBundle } from "../asset_bundle_reader.ts";
|
|
|
|
|
2022-10-10 12:50:21 +00:00
|
|
|
Deno.test("Test store", async () => {
|
2022-10-11 09:43:28 +00:00
|
|
|
const createSandbox = sandboxFactory(assetBundle as AssetBundle);
|
2022-10-10 12:50:21 +00:00
|
|
|
const db = new SQLite(":memory:");
|
2022-03-25 11:03:06 +00:00
|
|
|
await ensureTable(db, "test_table");
|
2022-10-10 12:50:21 +00:00
|
|
|
const system = new System("server");
|
|
|
|
const syscalls = storeSyscalls(db, "test_table");
|
2022-05-17 13:54:55 +00:00
|
|
|
system.registerSyscalls([], syscalls);
|
2022-10-10 12:50:21 +00:00
|
|
|
const plug = await system.load(
|
2022-03-25 11:03:06 +00:00
|
|
|
{
|
2022-04-26 17:04:36 +00:00
|
|
|
name: "test",
|
2022-03-25 11:03:06 +00:00
|
|
|
functions: {
|
|
|
|
test1: {
|
|
|
|
code: `(() => {
|
|
|
|
return {
|
|
|
|
default: async () => {
|
|
|
|
await self.syscall("store.set", "name", "Pete");
|
|
|
|
return await self.syscall("store.get", "name");
|
|
|
|
}
|
|
|
|
};
|
|
|
|
})()`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-10-10 12:50:21 +00:00
|
|
|
createSandbox,
|
2022-03-25 11:03:06 +00:00
|
|
|
);
|
2022-10-10 12:50:21 +00:00
|
|
|
assertEquals(await plug.invoke("test1", []), "Pete");
|
2022-03-25 11:03:06 +00:00
|
|
|
await system.unloadAll();
|
2022-05-17 13:54:55 +00:00
|
|
|
|
2022-10-10 12:50:21 +00:00
|
|
|
const dummyCtx: any = {};
|
2022-05-17 13:54:55 +00:00
|
|
|
|
|
|
|
await syscalls["store.deleteAll"](dummyCtx);
|
|
|
|
await syscalls["store.batchSet"](dummyCtx, [
|
|
|
|
{
|
|
|
|
key: "pete",
|
|
|
|
value: {
|
|
|
|
age: 20,
|
|
|
|
firstName: "Pete",
|
|
|
|
lastName: "Roberts",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: "petejr",
|
|
|
|
value: {
|
|
|
|
age: 8,
|
|
|
|
firstName: "Pete Jr",
|
|
|
|
lastName: "Roberts",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: "petesr",
|
|
|
|
value: {
|
|
|
|
age: 78,
|
|
|
|
firstName: "Pete Sr",
|
|
|
|
lastName: "Roberts",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
]);
|
|
|
|
|
|
|
|
let allRoberts = await syscalls["store.query"](dummyCtx, {
|
|
|
|
filter: [{ op: "=", prop: "lastName", value: "Roberts" }],
|
|
|
|
orderBy: "age",
|
|
|
|
orderDesc: true,
|
|
|
|
});
|
|
|
|
|
2022-10-10 12:50:21 +00:00
|
|
|
assertEquals(allRoberts.length, 3);
|
|
|
|
assertEquals(allRoberts[0].key, "petesr");
|
2022-05-17 13:54:55 +00:00
|
|
|
|
|
|
|
allRoberts = await syscalls["store.query"](dummyCtx, {
|
|
|
|
filter: [{ op: "=", prop: "lastName", value: "Roberts" }],
|
|
|
|
orderBy: "age",
|
|
|
|
limit: 1,
|
|
|
|
});
|
|
|
|
|
2022-10-10 12:50:21 +00:00
|
|
|
assertEquals(allRoberts.length, 1);
|
|
|
|
assertEquals(allRoberts[0].key, "petejr");
|
2022-05-17 13:54:55 +00:00
|
|
|
|
|
|
|
allRoberts = await syscalls["store.query"](dummyCtx, {
|
|
|
|
filter: [
|
|
|
|
{ op: ">", prop: "age", value: 10 },
|
|
|
|
{ op: "<", prop: "age", value: 30 },
|
|
|
|
],
|
|
|
|
orderBy: "age",
|
|
|
|
});
|
|
|
|
|
2022-10-10 12:50:21 +00:00
|
|
|
assertEquals(allRoberts.length, 1);
|
|
|
|
assertEquals(allRoberts[0].key, "pete");
|
2022-05-17 13:54:55 +00:00
|
|
|
|
|
|
|
// Delete the middle one
|
|
|
|
|
|
|
|
await syscalls["store.deleteQuery"](dummyCtx, {
|
|
|
|
filter: [
|
|
|
|
{ op: ">", prop: "age", value: 10 },
|
|
|
|
{ op: "<", prop: "age", value: 30 },
|
|
|
|
],
|
|
|
|
});
|
|
|
|
|
|
|
|
allRoberts = await syscalls["store.query"](dummyCtx, {});
|
2022-10-10 12:50:21 +00:00
|
|
|
assertEquals(allRoberts.length, 2);
|
2022-05-17 13:54:55 +00:00
|
|
|
|
2022-10-10 12:50:21 +00:00
|
|
|
db.close();
|
2022-03-25 11:03:06 +00:00
|
|
|
});
|