| 
									
										
										
										
											2016-10-06 23:25:52 +01:00
										 |  |  | 'use strict'; // necessary for es6 output in node 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { browser, element, by } from 'protractor'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | describe('Component Communication Cookbook Tests', function () { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-12 18:42:27 -07:00
										 |  |  |   // Note: '?e2e' which app can read to know it is running in protractor
 | 
					
						
							|  |  |  |   // e.g. `if (!/e2e/.test(location.search)) { ...`
 | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |   beforeAll(function () { | 
					
						
							| 
									
										
										
										
											2016-04-12 18:42:27 -07:00
										 |  |  |     browser.get('?e2e'); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('Parent-to-child communication', function() { | 
					
						
							|  |  |  |     // #docregion parent-to-child
 | 
					
						
							|  |  |  |     // ...
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |     let _heroNames = ['Mr. IQ', 'Magneta', 'Bombasto']; | 
					
						
							|  |  |  |     let _masterName = 'Master'; | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should pass properties to children properly', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let parent = element.all(by.tagName('hero-parent')).get(0); | 
					
						
							|  |  |  |       let heroes = parent.all(by.tagName('hero-child')); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       for (let i = 0; i < _heroNames.length; i++) { | 
					
						
							|  |  |  |         let childTitle = heroes.get(i).element(by.tagName('h3')).getText(); | 
					
						
							|  |  |  |         let childDetail = heroes.get(i).element(by.tagName('p')).getText(); | 
					
						
							| 
									
										
										
										
											2016-06-08 01:06:25 +02:00
										 |  |  |         expect(childTitle).toEqual(_heroNames[i] + ' says:'); | 
					
						
							|  |  |  |         expect(childDetail).toContain(_masterName); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |       } | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |     // ...
 | 
					
						
							|  |  |  |     // #enddocregion parent-to-child
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('Parent-to-child communication with setter', function() { | 
					
						
							|  |  |  |     // #docregion parent-to-child-setter
 | 
					
						
							|  |  |  |     // ...
 | 
					
						
							|  |  |  |     it('should display trimmed, non-empty names', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let _nonEmptyNameIndex = 0; | 
					
						
							|  |  |  |       let _nonEmptyName = '"Mr. IQ"'; | 
					
						
							|  |  |  |       let parent = element.all(by.tagName('name-parent')).get(0); | 
					
						
							|  |  |  |       let hero = parent.all(by.tagName('name-child')).get(_nonEmptyNameIndex); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let displayName = hero.element(by.tagName('h3')).getText(); | 
					
						
							| 
									
										
										
										
											2016-06-08 01:06:25 +02:00
										 |  |  |       expect(displayName).toEqual(_nonEmptyName); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should replace empty name with default name', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let _emptyNameIndex = 1; | 
					
						
							|  |  |  |       let _defaultName = '"<no name set>"'; | 
					
						
							|  |  |  |       let parent = element.all(by.tagName('name-parent')).get(0); | 
					
						
							|  |  |  |       let hero = parent.all(by.tagName('name-child')).get(_emptyNameIndex); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let displayName = hero.element(by.tagName('h3')).getText(); | 
					
						
							| 
									
										
										
										
											2016-06-08 01:06:25 +02:00
										 |  |  |       expect(displayName).toEqual(_defaultName); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |     }); | 
					
						
							|  |  |  |     // ...
 | 
					
						
							|  |  |  |     // #enddocregion parent-to-child-setter
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('Parent-to-child communication with ngOnChanges', function() { | 
					
						
							|  |  |  |     // #docregion parent-to-child-onchanges
 | 
					
						
							|  |  |  |     // ...
 | 
					
						
							|  |  |  |     // Test must all execute in this exact order
 | 
					
						
							|  |  |  |     it('should set expected initial values', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let actual = getActual(); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let initialLabel = 'Version 1.23'; | 
					
						
							|  |  |  |       let initialLog = 'major changed from {} to 1, minor changed from {} to 23'; | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |       expect(actual.label).toBe(initialLabel); | 
					
						
							|  |  |  |       expect(actual.count).toBe(1); | 
					
						
							|  |  |  |       expect(actual.logs.get(0).getText()).toBe(initialLog); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |     it('should set expected values after clicking \'Minor\' twice', function () { | 
					
						
							|  |  |  |       let repoTag = element(by.tagName('version-parent')); | 
					
						
							|  |  |  |       let newMinorButton = repoTag.all(by.tagName('button')).get(0); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |       newMinorButton.click().then(function() { | 
					
						
							|  |  |  |         newMinorButton.click().then(function() { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |           let actual = getActual(); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |           let labelAfter2Minor = 'Version 1.25'; | 
					
						
							|  |  |  |           let logAfter2Minor = 'minor changed from 24 to 25'; | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |           expect(actual.label).toBe(labelAfter2Minor); | 
					
						
							|  |  |  |           expect(actual.count).toBe(3); | 
					
						
							|  |  |  |           expect(actual.logs.get(2).getText()).toBe(logAfter2Minor); | 
					
						
							| 
									
										
										
										
											2016-06-08 01:06:25 +02:00
										 |  |  |         }); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |     it('should set expected values after clicking \'Major\' once', function () { | 
					
						
							|  |  |  |       let repoTag = element(by.tagName('version-parent')); | 
					
						
							|  |  |  |       let newMajorButton = repoTag.all(by.tagName('button')).get(1); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |       newMajorButton.click().then(function() { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |         let actual = getActual(); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |         let labelAfterMajor = 'Version 2.0'; | 
					
						
							|  |  |  |         let logAfterMajor = 'major changed from 1 to 2, minor changed from 25 to 0'; | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         expect(actual.label).toBe(labelAfterMajor); | 
					
						
							|  |  |  |         expect(actual.count).toBe(4); | 
					
						
							|  |  |  |         expect(actual.logs.get(3).getText()).toBe(logAfterMajor); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function getActual() { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let versionTag = element(by.tagName('version-child')); | 
					
						
							|  |  |  |       let label = versionTag.element(by.tagName('h3')).getText(); | 
					
						
							|  |  |  |       let ul = versionTag.element((by.tagName('ul'))); | 
					
						
							|  |  |  |       let logs = ul.all(by.tagName('li')); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |       return { | 
					
						
							|  |  |  |         label: label, | 
					
						
							|  |  |  |         logs: logs, | 
					
						
							|  |  |  |         count: logs.count() | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     // ...
 | 
					
						
							|  |  |  |     // #enddocregion parent-to-child-onchanges
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('Child-to-parent communication', function() { | 
					
						
							|  |  |  |     // #docregion child-to-parent
 | 
					
						
							|  |  |  |     // ...
 | 
					
						
							|  |  |  |     it('should not emit the event initially', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let voteLabel = element(by.tagName('vote-taker')) | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |         .element(by.tagName('h3')).getText(); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       expect(voteLabel).toBe('Agree: 0, Disagree: 0'); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should process Agree vote', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let agreeButton1 = element.all(by.tagName('my-voter')).get(0) | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |         .all(by.tagName('button')).get(0); | 
					
						
							|  |  |  |       agreeButton1.click().then(function() { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |         let voteLabel = element(by.tagName('vote-taker')) | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |           .element(by.tagName('h3')).getText(); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |         expect(voteLabel).toBe('Agree: 1, Disagree: 0'); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should process Disagree vote', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let agreeButton1 = element.all(by.tagName('my-voter')).get(1) | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |         .all(by.tagName('button')).get(1); | 
					
						
							|  |  |  |       agreeButton1.click().then(function() { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |         let voteLabel = element(by.tagName('vote-taker')) | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |           .element(by.tagName('h3')).getText(); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |         expect(voteLabel).toBe('Agree: 1, Disagree: 1'); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |     // ...
 | 
					
						
							|  |  |  |     // #enddocregion child-to-parent
 | 
					
						
							|  |  |  |   }); | 
					
						
							| 
									
										
										
										
											2016-04-12 18:42:27 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // Can't run timer tests in protractor because
 | 
					
						
							|  |  |  |   // interaction w/ zones causes all tests to freeze & timeout.
 | 
					
						
							|  |  |  |   xdescribe('Parent calls child via local var', function() { | 
					
						
							| 
									
										
										
										
											2016-06-08 01:06:25 +02:00
										 |  |  |     countDownTimerTests('countdown-parent-lv'); | 
					
						
							| 
									
										
										
										
											2016-04-12 18:42:27 -07:00
										 |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   xdescribe('Parent calls ViewChild', function() { | 
					
						
							| 
									
										
										
										
											2016-06-08 01:06:25 +02:00
										 |  |  |     countDownTimerTests('countdown-parent-vc'); | 
					
						
							| 
									
										
										
										
											2016-03-07 11:50:14 -08:00
										 |  |  |   }); | 
					
						
							| 
									
										
										
										
											2016-04-12 18:42:27 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |   function countDownTimerTests(parentTag: string) { | 
					
						
							| 
									
										
										
										
											2016-04-12 18:42:27 -07:00
										 |  |  |     // #docregion countdown-timer-tests
 | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |     // ...
 | 
					
						
							| 
									
										
										
										
											2016-03-07 11:50:14 -08:00
										 |  |  |     it('timer and parent seconds should match', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let parent = element(by.tagName(parentTag)); | 
					
						
							|  |  |  |       let message = parent.element(by.tagName('countdown-timer')).getText(); | 
					
						
							| 
									
										
										
										
											2016-03-07 11:50:14 -08:00
										 |  |  |       browser.sleep(10); // give `seconds` a chance to catchup with `message`
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let seconds = parent.element(by.className('seconds')).getText(); | 
					
						
							| 
									
										
										
										
											2016-03-07 11:50:14 -08:00
										 |  |  |       expect(message).toContain(seconds); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |     it('should stop the countdown', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let parent = element(by.tagName(parentTag)); | 
					
						
							|  |  |  |       let stopButton = parent.all(by.tagName('button')).get(1); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |       stopButton.click().then(function() { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |         let message = parent.element(by.tagName('countdown-timer')).getText(); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |         expect(message).toContain('Holding'); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |     // ...
 | 
					
						
							| 
									
										
										
										
											2016-04-12 18:42:27 -07:00
										 |  |  |     // #enddocregion countdown-timer-tests
 | 
					
						
							| 
									
										
										
										
											2016-03-07 11:50:14 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   describe('Parent and children communicate via a service', function() { | 
					
						
							|  |  |  |     // #docregion bidirectional-service
 | 
					
						
							|  |  |  |     // ...
 | 
					
						
							|  |  |  |     it('should announce a mission', function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |       let missionControl = element(by.tagName('mission-control')); | 
					
						
							|  |  |  |       let announceButton = missionControl.all(by.tagName('button')).get(0); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |       announceButton.click().then(function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |         let history = missionControl.all(by.tagName('li')); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |         expect(history.count()).toBe(1); | 
					
						
							|  |  |  |         expect(history.get(0).getText()).toMatch(/Mission.* announced/); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should confirm the mission by Lovell', function () { | 
					
						
							|  |  |  |       testConfirmMission(1, 2, 'Lovell'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should confirm the mission by Haise', function () { | 
					
						
							|  |  |  |       testConfirmMission(3, 3, 'Haise'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should confirm the mission by Swigert', function () { | 
					
						
							|  |  |  |       testConfirmMission(2, 4, 'Swigert'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |     function testConfirmMission(buttonIndex: number, expectedLogCount: number, astronaut: string) { | 
					
						
							|  |  |  |       let _confirmedLog = ' confirmed the mission'; | 
					
						
							|  |  |  |       let missionControl = element(by.tagName('mission-control')); | 
					
						
							|  |  |  |       let confirmButton = missionControl.all(by.tagName('button')).get(buttonIndex); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |       confirmButton.click().then(function () { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |         let history = missionControl.all(by.tagName('li')); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |         expect(history.count()).toBe(expectedLogCount); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:09 -07:00
										 |  |  |         expect(history.get(expectedLogCount - 1).getText()).toBe(astronaut + _confirmedLog); | 
					
						
							| 
									
										
										
										
											2016-02-02 14:39:34 +01:00
										 |  |  |       }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     // ...
 | 
					
						
							|  |  |  |     // #enddocregion bidirectional-service
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }); |