mirror of
https://github.com/TriliumNext/Notes.git
synced 2025-07-27 18:12:29 +08:00
fix(server): sorting notes by custom attribute with missing value not idempotent
This commit is contained in:
parent
5e62f4999d
commit
a767ee3d2c
@ -4,7 +4,7 @@ import BAttribute from "../../src/becca/entities/battribute.js";
|
|||||||
import becca from "../../src/becca/becca.js";
|
import becca from "../../src/becca/becca.js";
|
||||||
import randtoken from "rand-token";
|
import randtoken from "rand-token";
|
||||||
import type SearchResult from "../../src/services/search/search_result.js";
|
import type SearchResult from "../../src/services/search/search_result.js";
|
||||||
import type { NoteType } from "../../src/becca/entities/rows.js";
|
import type { NoteRow, NoteType } from "../../src/becca/entities/rows.js";
|
||||||
randtoken.generator({ source: "crypto" });
|
randtoken.generator({ source: "crypto" });
|
||||||
|
|
||||||
function findNoteByTitle(searchResults: Array<SearchResult>, title: string): BNote | undefined {
|
function findNoteByTitle(searchResults: Array<SearchResult>, title: string): BNote | undefined {
|
||||||
@ -59,7 +59,7 @@ function id() {
|
|||||||
return randtoken.generate(10);
|
return randtoken.generate(10);
|
||||||
}
|
}
|
||||||
|
|
||||||
function note(title: string, extraParams = {}) {
|
function note(title: string, extraParams: Partial<NoteRow> = {}) {
|
||||||
const row = Object.assign(
|
const row = Object.assign(
|
||||||
{
|
{
|
||||||
noteId: id(),
|
noteId: id(),
|
||||||
|
72
src/services/tree.spec.ts
Normal file
72
src/services/tree.spec.ts
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
import { beforeEach, describe, expect, it, vi } from "vitest";
|
||||||
|
import becca_mocking 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!: any;
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
becca.reset();
|
||||||
|
|
||||||
|
rootNote = new becca_mocking.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) => {
|
||||||
|
cb();
|
||||||
|
},
|
||||||
|
execute: (...args) => { },
|
||||||
|
replace: (...args) => { },
|
||||||
|
getMap: (...args) => { }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
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(becca_mocking.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(becca_mocking.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);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
@ -145,8 +145,8 @@ function sortNotes(parentNoteId: string, customSortBy: string = "title", reverse
|
|||||||
return compare(bottomBEl, bottomAEl) * (reverse ? -1 : 1);
|
return compare(bottomBEl, bottomAEl) * (reverse ? -1 : 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
const customAEl = fetchValue(a, customSortBy);
|
const customAEl = fetchValue(a, customSortBy) ?? fetchValue(a, "title");
|
||||||
const customBEl = fetchValue(b, customSortBy);
|
const customBEl = fetchValue(b, customSortBy) ?? fetchValue(b, "title");
|
||||||
|
|
||||||
if (customAEl !== customBEl) {
|
if (customAEl !== customBEl) {
|
||||||
return compare(customAEl, customBEl);
|
return compare(customAEl, customBEl);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user