mirror of
https://github.com/zadam/trilium.git
synced 2025-10-20 15:19:01 +02:00
test(server/script): dayjs is available
This commit is contained in:
parent
537c282156
commit
f32f9d4326
76
apps/server/src/services/script.spec.ts
Normal file
76
apps/server/src/services/script.spec.ts
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
import becca from "../becca/becca.js";
|
||||||
|
import { note, NoteBuilder } from "../test/becca_mocking.js";
|
||||||
|
import cls from "./cls.js";
|
||||||
|
import { executeBundle, getScriptBundle } from "./script.js";
|
||||||
|
import BBranch from "../becca/entities/bbranch.js";
|
||||||
|
import BNote from "../becca/entities/bnote.js";
|
||||||
|
|
||||||
|
|
||||||
|
describe("Script", () => {
|
||||||
|
let rootNote!: NoteBuilder;
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
|
||||||
|
becca.reset();
|
||||||
|
|
||||||
|
rootNote = new NoteBuilder(
|
||||||
|
new BNote({
|
||||||
|
noteId: "root",
|
||||||
|
title: "root",
|
||||||
|
type: "text"
|
||||||
|
})
|
||||||
|
);
|
||||||
|
new BBranch({
|
||||||
|
branchId: "none_root",
|
||||||
|
noteId: "root",
|
||||||
|
parentNoteId: "none",
|
||||||
|
notePosition: 10
|
||||||
|
});
|
||||||
|
|
||||||
|
vi.mock("./sql.js", () => {
|
||||||
|
return {
|
||||||
|
default: {
|
||||||
|
transactional: (cb: Function) => {
|
||||||
|
cb();
|
||||||
|
},
|
||||||
|
execute: () => {},
|
||||||
|
replace: () => {},
|
||||||
|
getMap: () => {}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
vi.mock("./sql_init.js", () => {
|
||||||
|
return {
|
||||||
|
dbReady: () => {
|
||||||
|
console.log("Hello world");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("returns result from script", () => {
|
||||||
|
cls.init(() => {
|
||||||
|
const result = executeBundle({
|
||||||
|
script: `return "world";`,
|
||||||
|
html: "",
|
||||||
|
});
|
||||||
|
expect(result).toBe("world");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("dayjs", () => {
|
||||||
|
it("dayjs is available", () => {
|
||||||
|
cls.init(() => {
|
||||||
|
const scriptNote = note("dayjs", {
|
||||||
|
type: "code",
|
||||||
|
mime: "application/javascript;env=backend",
|
||||||
|
});
|
||||||
|
const bundle = getScriptBundle(scriptNote.note, true, "backend", [], `return api.dayjs().format("YYYY-MM-DD");`);
|
||||||
|
expect(bundle).toBeDefined();
|
||||||
|
const result = executeBundle(bundle!);
|
||||||
|
expect(result).toMatch(/^\d{4}-\d{2}-\d{2}$/);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
@ -39,7 +39,7 @@ function executeNoteNoException(note: BNote, apiParams: ApiParams) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function executeBundle(bundle: Bundle, apiParams: ApiParams = {}) {
|
export function executeBundle(bundle: Bundle, apiParams: ApiParams = {}) {
|
||||||
if (!apiParams.startNote) {
|
if (!apiParams.startNote) {
|
||||||
// this is the default case, the only exception is when we want to preserve frontend startNote
|
// this is the default case, the only exception is when we want to preserve frontend startNote
|
||||||
apiParams.startNote = bundle.note;
|
apiParams.startNote = bundle.note;
|
||||||
@ -140,7 +140,7 @@ function getScriptBundleForFrontend(note: BNote, script?: string, params?: Scrip
|
|||||||
return bundle;
|
return bundle;
|
||||||
}
|
}
|
||||||
|
|
||||||
function getScriptBundle(note: BNote, root: boolean = true, scriptEnv: string | null = null, includedNoteIds: string[] = [], overrideContent: string | null = null): Bundle | undefined {
|
export function getScriptBundle(note: BNote, root: boolean = true, scriptEnv: string | null = null, includedNoteIds: string[] = [], overrideContent: string | null = null): Bundle | undefined {
|
||||||
if (!note.isContentAvailable()) {
|
if (!note.isContentAvailable()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user