mirror of
https://github.com/TriliumNext/Notes.git
synced 2025-10-01 02:01:33 +08:00
77 lines
2.2 KiB
TypeScript
77 lines
2.2 KiB
TypeScript
import { beforeEach, describe, expect, it, vi } from "vitest";
|
|
import { note, NoteBuilder } from "../../spec/support/becca_mocking.js";
|
|
import becca from "../becca/becca.js";
|
|
import BBranch from "../becca/entities/bbranch.js";
|
|
import BNote from "../becca/entities/bnote.js";
|
|
import tree from "./tree.js";
|
|
import cls from "./cls.js";
|
|
|
|
describe("Tree", () => {
|
|
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("custom sort order is idempotent", () => {
|
|
rootNote.label("sorted", "order");
|
|
|
|
// Add values which have a defined order.
|
|
for (let i = 0; i <= 5; i++) {
|
|
rootNote.child(note(String(i)).label("order", String(i)));
|
|
}
|
|
|
|
// Add a few values which have no defined order.
|
|
for (let i = 6; i < 10; i++) {
|
|
rootNote.child(note(String(i)));
|
|
}
|
|
|
|
const expectedOrder = ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9"];
|
|
|
|
// Sort a few times to ensure that the resulting order is the same.
|
|
for (let i = 0; i < 5; i++) {
|
|
cls.init(() => {
|
|
tree.sortNotesIfNeeded(rootNote.note.noteId);
|
|
});
|
|
|
|
const order = rootNote.note.children.map((child) => child.title);
|
|
expect(order).toStrictEqual(expectedOrder);
|
|
}
|
|
});
|
|
});
|