2016-07-21 20:12:00 -04:00
|
|
|
/**
|
|
|
|
* @license
|
2020-05-19 15:08:49 -04:00
|
|
|
* Copyright Google LLC All Rights Reserved.
|
2016-07-21 20:12:00 -04:00
|
|
|
*
|
|
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
|
|
* found in the LICENSE file at https://angular.io/license
|
|
|
|
*/
|
|
|
|
|
2016-05-24 16:57:51 -04:00
|
|
|
import {Tree, TreeNode} from '../../src/utils/tree';
|
2016-05-20 16:56:52 -04:00
|
|
|
|
|
|
|
describe('tree', () => {
|
2016-06-21 14:49:42 -04:00
|
|
|
it('should return the root of the tree', () => {
|
2017-12-17 18:10:54 -05:00
|
|
|
const t = new Tree<any>(new TreeNode<number>(1, [])) as any;
|
2016-05-20 16:56:52 -04:00
|
|
|
expect(t.root).toEqual(1);
|
|
|
|
});
|
|
|
|
|
2016-06-21 14:49:42 -04:00
|
|
|
it('should return the parent of a node', () => {
|
2017-12-17 18:10:54 -05:00
|
|
|
const t = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])])) as any;
|
2016-05-20 16:56:52 -04:00
|
|
|
expect(t.parent(1)).toEqual(null);
|
|
|
|
expect(t.parent(2)).toEqual(1);
|
|
|
|
});
|
|
|
|
|
2016-08-07 23:05:05 -04:00
|
|
|
it('should return the parent of a node (second child)', () => {
|
2020-04-13 19:40:21 -04:00
|
|
|
const t = new Tree<any>(new TreeNode<number>(
|
|
|
|
1, [new TreeNode<number>(2, []), new TreeNode<number>(3, [])])) as any;
|
2016-08-07 23:05:05 -04:00
|
|
|
expect(t.parent(1)).toEqual(null);
|
|
|
|
expect(t.parent(3)).toEqual(1);
|
|
|
|
});
|
|
|
|
|
2016-06-21 14:49:42 -04:00
|
|
|
it('should return the children of a node', () => {
|
2017-12-17 18:10:54 -05:00
|
|
|
const t = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])])) as any;
|
2016-05-20 16:56:52 -04:00
|
|
|
expect(t.children(1)).toEqual([2]);
|
|
|
|
expect(t.children(2)).toEqual([]);
|
|
|
|
});
|
|
|
|
|
2016-06-21 14:49:42 -04:00
|
|
|
it('should return the first child of a node', () => {
|
2017-12-17 18:10:54 -05:00
|
|
|
const t = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])])) as any;
|
2016-05-20 16:56:52 -04:00
|
|
|
expect(t.firstChild(1)).toEqual(2);
|
|
|
|
expect(t.firstChild(2)).toEqual(null);
|
|
|
|
});
|
|
|
|
|
2016-06-21 14:49:42 -04:00
|
|
|
it('should return the siblings of a node', () => {
|
2020-04-13 19:40:21 -04:00
|
|
|
const t = new Tree<any>(new TreeNode<number>(
|
|
|
|
1, [new TreeNode<number>(2, []), new TreeNode<number>(3, [])])) as any;
|
2016-05-24 16:46:50 -04:00
|
|
|
expect(t.siblings(2)).toEqual([3]);
|
|
|
|
expect(t.siblings(1)).toEqual([]);
|
|
|
|
});
|
|
|
|
|
2016-06-21 14:49:42 -04:00
|
|
|
it('should return the path to the root', () => {
|
2017-12-17 18:10:54 -05:00
|
|
|
const t = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])])) as any;
|
2016-05-20 16:56:52 -04:00
|
|
|
expect(t.pathFromRoot(2)).toEqual([1, 2]);
|
|
|
|
});
|
|
|
|
});
|