2016-04-22 15:04:27 -04:00
|
|
|
import {
|
|
|
|
AsyncTestCompleter,
|
|
|
|
beforeEach,
|
|
|
|
ddescribe,
|
|
|
|
xdescribe,
|
|
|
|
describe,
|
|
|
|
expect,
|
|
|
|
iit,
|
|
|
|
inject,
|
|
|
|
beforeEachProviders,
|
|
|
|
it,
|
|
|
|
xit
|
2016-05-02 13:36:58 -04:00
|
|
|
} from '@angular/core/testing/testing_internal';
|
2016-04-22 15:04:27 -04:00
|
|
|
|
2016-05-02 13:36:58 -04:00
|
|
|
import {Tree, TreeNode} from '../src/segments';
|
2016-04-22 15:04:27 -04:00
|
|
|
|
|
|
|
export function main() {
|
|
|
|
describe('tree', () => {
|
|
|
|
it("should return the root of the tree", () => {
|
2016-04-25 19:54:51 -04:00
|
|
|
let t = new Tree<any>(new TreeNode<number>(1, []));
|
2016-04-22 15:04:27 -04:00
|
|
|
expect(t.root).toEqual(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should return the parent of a node", () => {
|
2016-04-25 19:54:51 -04:00
|
|
|
let t = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])]));
|
2016-04-22 15:04:27 -04:00
|
|
|
expect(t.parent(1)).toEqual(null);
|
|
|
|
expect(t.parent(2)).toEqual(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should return the children of a node", () => {
|
2016-04-25 19:54:51 -04:00
|
|
|
let t = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])]));
|
2016-04-22 15:04:27 -04:00
|
|
|
expect(t.children(1)).toEqual([2]);
|
2016-04-25 19:54:51 -04:00
|
|
|
expect(t.children(2)).toEqual([]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should return the first child of a node", () => {
|
|
|
|
let t = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])]));
|
|
|
|
expect(t.firstChild(1)).toEqual(2);
|
|
|
|
expect(t.firstChild(2)).toEqual(null);
|
2016-04-22 15:04:27 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
it("should return the path to the root", () => {
|
2016-04-25 19:54:51 -04:00
|
|
|
let t = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])]));
|
|
|
|
expect(t.pathFromRoot(2)).toEqual([1, 2]);
|
2016-04-22 15:04:27 -04:00
|
|
|
});
|
2016-05-01 18:47:47 -04:00
|
|
|
|
|
|
|
describe("contains", () => {
|
|
|
|
it("should work", () => {
|
2016-05-01 20:07:10 -04:00
|
|
|
let tree = new Tree<any>(
|
|
|
|
new TreeNode<number>(1, [new TreeNode<number>(2, []), new TreeNode<number>(3, [])]));
|
2016-05-01 18:47:47 -04:00
|
|
|
let subtree1 = new Tree<any>(new TreeNode<number>(1, []));
|
|
|
|
let subtree2 = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])]));
|
|
|
|
let subtree3 = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(3, [])]));
|
|
|
|
let notSubtree1 = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(4, [])]));
|
2016-05-01 20:07:10 -04:00
|
|
|
let notSubtree2 = new Tree<any>(
|
|
|
|
new TreeNode<number>(1, [new TreeNode<number>(2, [new TreeNode<number>(4, [])])]));
|
2016-05-01 18:47:47 -04:00
|
|
|
|
|
|
|
expect(tree.contains(subtree1)).toEqual(true);
|
|
|
|
expect(tree.contains(subtree2)).toEqual(true);
|
|
|
|
expect(tree.contains(subtree3)).toEqual(true);
|
|
|
|
expect(tree.contains(notSubtree1)).toEqual(false);
|
|
|
|
expect(tree.contains(notSubtree2)).toEqual(false);
|
|
|
|
});
|
|
|
|
});
|
2016-04-22 15:04:27 -04:00
|
|
|
});
|
2016-05-02 13:36:58 -04:00
|
|
|
}
|