| 
									
										
										
										
											2016-04-22 12:04:27 -07:00
										 |  |  | import { | 
					
						
							|  |  |  |   ComponentFixture, | 
					
						
							|  |  |  |   AsyncTestCompleter, | 
					
						
							|  |  |  |   TestComponentBuilder, | 
					
						
							|  |  |  |   beforeEach, | 
					
						
							|  |  |  |   ddescribe, | 
					
						
							|  |  |  |   xdescribe, | 
					
						
							|  |  |  |   describe, | 
					
						
							|  |  |  |   el, | 
					
						
							|  |  |  |   expect, | 
					
						
							|  |  |  |   iit, | 
					
						
							|  |  |  |   inject, | 
					
						
							|  |  |  |   beforeEachProviders, | 
					
						
							|  |  |  |   it, | 
					
						
							|  |  |  |   xit | 
					
						
							|  |  |  | } from 'angular2/testing_internal'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-25 16:54:51 -07:00
										 |  |  | import {Tree, TreeNode} from 'angular2/src/alt_router/segments'; | 
					
						
							| 
									
										
										
										
											2016-04-22 12:04:27 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | export function main() { | 
					
						
							|  |  |  |   describe('tree', () => { | 
					
						
							|  |  |  |     it("should return the root of the tree", () => { | 
					
						
							| 
									
										
										
										
											2016-04-25 16:54:51 -07:00
										 |  |  |       let t = new Tree<any>(new TreeNode<number>(1, [])); | 
					
						
							| 
									
										
										
										
											2016-04-22 12:04:27 -07:00
										 |  |  |       expect(t.root).toEqual(1); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it("should return the parent of a node", () => { | 
					
						
							| 
									
										
										
										
											2016-04-25 16:54:51 -07:00
										 |  |  |       let t = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])])); | 
					
						
							| 
									
										
										
										
											2016-04-22 12:04:27 -07:00
										 |  |  |       expect(t.parent(1)).toEqual(null); | 
					
						
							|  |  |  |       expect(t.parent(2)).toEqual(1); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it("should return the children of a node", () => { | 
					
						
							| 
									
										
										
										
											2016-04-25 16:54:51 -07:00
										 |  |  |       let t = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])])); | 
					
						
							| 
									
										
										
										
											2016-04-22 12:04:27 -07:00
										 |  |  |       expect(t.children(1)).toEqual([2]); | 
					
						
							| 
									
										
										
										
											2016-04-25 16:54:51 -07: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 12:04:27 -07:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it("should return the path to the root", () => { | 
					
						
							| 
									
										
										
										
											2016-04-25 16:54:51 -07:00
										 |  |  |       let t = new Tree<any>(new TreeNode<number>(1, [new TreeNode<number>(2, [])])); | 
					
						
							|  |  |  |       expect(t.pathFromRoot(2)).toEqual([1, 2]); | 
					
						
							| 
									
										
										
										
											2016-04-22 12:04:27 -07:00
										 |  |  |     }); | 
					
						
							| 
									
										
										
										
											2016-05-01 15:47:47 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     describe("contains", () => { | 
					
						
							|  |  |  |       it("should work", () => { | 
					
						
							| 
									
										
										
										
											2016-05-01 17:07:10 -07:00
										 |  |  |         let tree = new Tree<any>( | 
					
						
							|  |  |  |             new TreeNode<number>(1, [new TreeNode<number>(2, []), new TreeNode<number>(3, [])])); | 
					
						
							| 
									
										
										
										
											2016-05-01 15:47:47 -07: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 17:07:10 -07:00
										 |  |  |         let notSubtree2 = new Tree<any>( | 
					
						
							|  |  |  |             new TreeNode<number>(1, [new TreeNode<number>(2, [new TreeNode<number>(4, [])])])); | 
					
						
							| 
									
										
										
										
											2016-05-01 15:47:47 -07: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 12:04:27 -07:00
										 |  |  |   }); | 
					
						
							|  |  |  | } |