/* * Copyright (C) 2022 StApps * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation, version 3. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along with * this program. If not, see . */ import {expect} from 'chai'; import {Tree, treeGroupBy} from '../src/index.js'; interface TestItem { id: number; path?: string[]; } describe('tree-group', function () { it('should create a tree', function () { const items: Array = [ { id: 1, path: ['a', 'b', 'c'], }, { id: 2, path: ['a', 'b', 'd'], }, ]; const tree = treeGroupBy(items, item => item.path ?? []); const expectedTree: Tree = { a: { b: { c: {_: [items[0]]}, d: {_: [items[1]]}, } as Tree, } as Tree, } as Tree; expect(tree).to.deep.equal(expectedTree); }); it('should also sort empty paths', () => { const items: Array = [ { id: 1, path: ['a', 'b', 'c'], }, { id: 2, }, ]; const tree = treeGroupBy(items, item => item.path ?? []); const expectedTree: Tree = { a: { b: { c: {_: [items[0]]}, } as Tree, } as Tree, _: [items[1]], } as Tree; expect(tree).to.deep.equal(expectedTree); }); });