2022-04-05 23:02:17 +08:00
|
|
|
import { createSandbox } from "../environments/node_sandbox";
|
|
|
|
import { expect, test } from "@jest/globals";
|
|
|
|
import { System } from "../system";
|
|
|
|
import { ensureTable, storeSyscalls } from "./store.knex_node";
|
2022-03-25 19:03:06 +08:00
|
|
|
import knex from "knex";
|
|
|
|
import fs from "fs/promises";
|
|
|
|
|
|
|
|
test("Test store", async () => {
|
|
|
|
const db = knex({
|
|
|
|
client: "better-sqlite3",
|
|
|
|
connection: {
|
|
|
|
filename: "test.db",
|
|
|
|
},
|
|
|
|
useNullAsDefault: true,
|
|
|
|
});
|
|
|
|
await ensureTable(db, "test_table");
|
|
|
|
let system = new System("server");
|
2022-05-17 21:54:55 +08:00
|
|
|
let syscalls = storeSyscalls(db, "test_table");
|
|
|
|
system.registerSyscalls([], syscalls);
|
2022-03-25 19:03:06 +08:00
|
|
|
let plug = await system.load(
|
|
|
|
{
|
2022-04-27 01:04:36 +08:00
|
|
|
name: "test",
|
2022-03-25 19:03:06 +08:00
|
|
|
functions: {
|
|
|
|
test1: {
|
|
|
|
code: `(() => {
|
|
|
|
return {
|
|
|
|
default: async () => {
|
|
|
|
await self.syscall("store.set", "name", "Pete");
|
|
|
|
return await self.syscall("store.get", "name");
|
|
|
|
}
|
|
|
|
};
|
|
|
|
})()`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
createSandbox
|
|
|
|
);
|
|
|
|
expect(await plug.invoke("test1", [])).toBe("Pete");
|
|
|
|
await system.unloadAll();
|
2022-05-17 21:54:55 +08:00
|
|
|
|
|
|
|
let dummyCtx: any = {};
|
|
|
|
|
|
|
|
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,
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(allRoberts.length).toBe(3);
|
|
|
|
expect(allRoberts[0].key).toBe("petesr");
|
|
|
|
|
|
|
|
allRoberts = await syscalls["store.query"](dummyCtx, {
|
|
|
|
filter: [{ op: "=", prop: "lastName", value: "Roberts" }],
|
|
|
|
orderBy: "age",
|
|
|
|
limit: 1,
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(allRoberts.length).toBe(1);
|
|
|
|
expect(allRoberts[0].key).toBe("petejr");
|
|
|
|
|
|
|
|
allRoberts = await syscalls["store.query"](dummyCtx, {
|
|
|
|
filter: [
|
|
|
|
{ op: ">", prop: "age", value: 10 },
|
|
|
|
{ op: "<", prop: "age", value: 30 },
|
|
|
|
],
|
|
|
|
orderBy: "age",
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(allRoberts.length).toBe(1);
|
|
|
|
expect(allRoberts[0].key).toBe("pete");
|
|
|
|
|
|
|
|
// 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, {});
|
|
|
|
expect(allRoberts.length).toBe(2);
|
|
|
|
|
|
|
|
await db.destroy();
|
|
|
|
|
2022-03-25 19:03:06 +08:00
|
|
|
await fs.unlink("test.db");
|
|
|
|
});
|