| 
									
										
										
										
											2016-10-06 23:25:52 +01:00
										 |  |  | 'use strict'; // necessary for es6 output in node 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { browser, element, by } from 'protractor'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  | describe('Server Communication', function () { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   beforeAll(function () { | 
					
						
							|  |  |  |     browser.get(''); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  |   describe('Tour of Heroes (Observable)', function () { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |     let initialHeroCount = 4; | 
					
						
							|  |  |  |     let newHeroName = 'Mr. IQ'; | 
					
						
							|  |  |  |     let heroCountAfterAdd = 5; | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |     let heroListComp = element(by.tagName('hero-list')); | 
					
						
							|  |  |  |     let addButton = heroListComp.element(by.tagName('button')); | 
					
						
							|  |  |  |     let heroTags = heroListComp.all(by.tagName('li')); | 
					
						
							|  |  |  |     let heroNameInput = heroListComp.element(by.tagName('input')); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should exist', function() { | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |       expect(heroListComp).toBeDefined('<hero-list> must exist'); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should display ' + initialHeroCount + ' heroes after init', function () { | 
					
						
							|  |  |  |       expect(heroTags.count()).toBe(initialHeroCount); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     it('should not add hero with empty name', function () { | 
					
						
							|  |  |  |       expect(addButton).toBeDefined('"Add Hero" button must be defined'); | 
					
						
							|  |  |  |       addButton.click().then(function() { | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  |         expect(heroTags.count()).toBe(initialHeroCount, 'No new hero should be added'); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |       }); | 
					
						
							| 
									
										
										
										
											2016-06-08 01:06:25 +02:00
										 |  |  |     }); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should add a new hero to the list', function () { | 
					
						
							|  |  |  |       expect(heroNameInput).toBeDefined('<input> for hero name must exist'); | 
					
						
							|  |  |  |       expect(addButton).toBeDefined('"Add Hero" button must be defined'); | 
					
						
							| 
									
										
										
										
											2016-10-06 23:25:52 +01:00
										 |  |  |       heroNameInput.sendKeys(newHeroName); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |       addButton.click().then(function() { | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  |         expect(heroTags.count()).toBe(heroCountAfterAdd, 'A new hero should be added'); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |         let newHeroInList = heroTags.get(heroCountAfterAdd - 1).getText(); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  |         expect(newHeroInList).toBe(newHeroName, 'The hero should be added to the end of the list'); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |       }); | 
					
						
							| 
									
										
										
										
											2016-06-08 01:06:25 +02:00
										 |  |  |     }); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |   }); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   describe('Wikipedia Demo', function () { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     it('should initialize the demo with empty result list', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let myWikiComp = element(by.tagName('my-wiki')); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |       expect(myWikiComp).toBeDefined('<my-wiki> must exist'); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let resultList = myWikiComp.all(by.tagName('li')); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |       expect(resultList.count()).toBe(0, 'result list must be empty'); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     describe('Fetches after each keystroke', function () { | 
					
						
							|  |  |  |       it('should fetch results after "B"', function(done) { | 
					
						
							|  |  |  |         testForRefreshedResult('B', done); | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |       it('should fetch results after "Ba"', function(done) { | 
					
						
							|  |  |  |         testForRefreshedResult('a', done); | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |       it('should fetch results after "Bas"', function(done) { | 
					
						
							|  |  |  |         testForRefreshedResult('s', done); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should fetch results after "Basic"', function(done) { | 
					
						
							|  |  |  |         testForRefreshedResult('ic', done); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-01 18:11:58 +02:00
										 |  |  |     function testForRefreshedResult(keyPressed: string, done: () => void) { | 
					
						
							| 
									
										
										
										
											2016-06-08 01:06:25 +02:00
										 |  |  |       testForResult('my-wiki', keyPressed, false, done); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   }); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   describe('Smarter Wikipedia Demo', function () { | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should initialize the demo with empty result list', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let myWikiSmartComp = element(by.tagName('my-wiki-smart')); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |       expect(myWikiSmartComp).toBeDefined('<my-wiki-smart> must exist'); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let resultList = myWikiSmartComp.all(by.tagName('li')); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |       expect(resultList.count()).toBe(0, 'result list must be empty'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should fetch results after "Java"', function(done) { | 
					
						
							|  |  |  |       testForNewResult('Java', done); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     it('should fetch results after "JavaS"', function(done) { | 
					
						
							|  |  |  |       testForStaleResult('S', done); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     it('should fetch results after "JavaSc"', function(done) { | 
					
						
							|  |  |  |       testForStaleResult('c', done); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     it('should fetch results after "JavaScript"', function(done) { | 
					
						
							|  |  |  |       testForStaleResult('ript', done); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-01 18:11:58 +02:00
										 |  |  |     function testForNewResult(keyPressed: string, done: () => void) { | 
					
						
							| 
									
										
										
										
											2016-06-08 01:06:25 +02:00
										 |  |  |       testForResult('my-wiki-smart', keyPressed, false, done); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-01 18:11:58 +02:00
										 |  |  |     function testForStaleResult(keyPressed: string, done: () => void) { | 
					
						
							| 
									
										
										
										
											2016-06-08 01:06:25 +02:00
										 |  |  |       testForResult('my-wiki-smart', keyPressed, true, done); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-01 18:11:58 +02:00
										 |  |  |   function testForResult(componentTagName: string, keyPressed: string, hasListBeforeSearch: boolean, done: () => void) { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |     let searchWait = 1000; // Wait for wikipedia but not so long that tests timeout
 | 
					
						
							|  |  |  |     let wikiComponent = element(by.tagName(componentTagName)); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     expect(wikiComponent).toBeDefined('<' + componentTagName + '> must exist'); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |     let searchBox = wikiComponent.element(by.tagName('input')); | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     expect(searchBox).toBeDefined('<input> for search must exist'); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |     searchBox.sendKeys(keyPressed).then(function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let resultList = wikiComponent.all(by.tagName('li')); | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  |       if (hasListBeforeSearch) { | 
					
						
							|  |  |  |         expect(resultList.count()).toBeGreaterThan(0, 'result list should not be empty before search'); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       setTimeout(function() { | 
					
						
							|  |  |  |         expect(resultList.count()).toBeGreaterThan(0, 'result list should not be empty after search'); | 
					
						
							|  |  |  |         done(); | 
					
						
							|  |  |  |       }, searchWait); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-05-17 21:25:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-08 17:47:08 +01:00
										 |  |  | }); |