| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  | 'use strict'; // necessary for es6 output in node
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { browser, element, by, ElementFinder } from 'protractor'; | 
					
						
							|  |  |  | import { logging, promise } from 'selenium-webdriver'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * The tests here basically just checking that the end styles | 
					
						
							|  |  |  |  * of each animation are in effect. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Relies on the Angular testability only becoming stable once | 
					
						
							|  |  |  |  * animation(s) have finished. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Ideally we'd use https://developer.mozilla.org/en-US/docs/Web/API/Document/getAnimations
 | 
					
						
							|  |  |  |  * but they're not supported in Chrome at the moment. The upcoming nganimate polyfill | 
					
						
							|  |  |  |  * may also add some introspection support. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | describe('Animation Tests', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const INACTIVE_COLOR = 'rgba(238, 238, 238, 1)'; | 
					
						
							|  |  |  |   const ACTIVE_COLOR = 'rgba(207, 216, 220, 1)'; | 
					
						
							|  |  |  |   const NO_TRANSFORM_MATRIX_REGEX = /matrix\(1,\s*0,\s*0,\s*1,\s*0,\s*0\)/; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   beforeEach(() => { | 
					
						
							|  |  |  |     browser.get(''); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('basic states', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let host: ElementFinder; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     beforeEach(() => { | 
					
						
							| 
									
										
										
										
											2017-08-22 21:31:15 +02:00
										 |  |  |       host = element(by.css('app-hero-list-basic')); | 
					
						
							| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('animates between active and inactive', () => { | 
					
						
							|  |  |  |       addInactiveHero(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let li = host.element(by.css('li')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.0); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(INACTIVE_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       li.click(); | 
					
						
							|  |  |  |       browser.driver.sleep(300); | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.1); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(ACTIVE_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       li.click(); | 
					
						
							|  |  |  |       browser.driver.sleep(300); | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.0); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(INACTIVE_COLOR); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('styles inline in transitions', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let host: ElementFinder; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     beforeEach(function() { | 
					
						
							| 
									
										
										
										
											2017-08-22 21:31:15 +02:00
										 |  |  |       host = element(by.css('app-hero-list-inline-styles')); | 
					
						
							| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('are not kept after animation', () => { | 
					
						
							|  |  |  |       addInactiveHero(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let li = host.element(by.css('li')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       li.click(); | 
					
						
							|  |  |  |       browser.driver.sleep(300); | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.0); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(INACTIVE_COLOR); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('combined transition syntax', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let host: ElementFinder; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     beforeEach(() => { | 
					
						
							| 
									
										
										
										
											2017-08-22 21:31:15 +02:00
										 |  |  |       host = element(by.css('app-hero-list-combined-transitions')); | 
					
						
							| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('animates between active and inactive', () => { | 
					
						
							|  |  |  |       addInactiveHero(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let li = host.element(by.css('li')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.0); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(INACTIVE_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       li.click(); | 
					
						
							|  |  |  |       browser.driver.sleep(300); | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.1); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(ACTIVE_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       li.click(); | 
					
						
							|  |  |  |       browser.driver.sleep(300); | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.0); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(INACTIVE_COLOR); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('two-way transition syntax', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let host: ElementFinder; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     beforeEach(() => { | 
					
						
							| 
									
										
										
										
											2017-08-22 21:31:15 +02:00
										 |  |  |       host = element(by.css('app-hero-list-twoway')); | 
					
						
							| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('animates between active and inactive', () => { | 
					
						
							|  |  |  |       addInactiveHero(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let li = host.element(by.css('li')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.0); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(INACTIVE_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       li.click(); | 
					
						
							|  |  |  |       browser.driver.sleep(300); | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.1); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(ACTIVE_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       li.click(); | 
					
						
							|  |  |  |       browser.driver.sleep(300); | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.0); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(INACTIVE_COLOR); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('enter & leave', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let host: ElementFinder; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     beforeEach(() => { | 
					
						
							| 
									
										
										
										
											2017-08-22 21:31:15 +02:00
										 |  |  |       host = element(by.css('app-hero-list-enter-leave')); | 
					
						
							| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('adds and removes element', () => { | 
					
						
							|  |  |  |       addInactiveHero(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let li = host.element(by.css('li')); | 
					
						
							|  |  |  |       expect(li.getCssValue('transform')).toMatch(NO_TRANSFORM_MATRIX_REGEX); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       removeHero(); | 
					
						
							|  |  |  |       expect(li.isPresent()).toBe(false); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('enter & leave & states', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let host: ElementFinder; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     beforeEach(function() { | 
					
						
							| 
									
										
										
										
											2017-08-22 21:31:15 +02:00
										 |  |  |       host = element(by.css('app-hero-list-enter-leave-states')); | 
					
						
							| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('adds and removes and animates between active and inactive', () => { | 
					
						
							|  |  |  |       addInactiveHero(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let li = host.element(by.css('li')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(li.getCssValue('transform')).toMatch(NO_TRANSFORM_MATRIX_REGEX); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       li.click(); | 
					
						
							|  |  |  |       browser.driver.sleep(300); | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       li.click(); | 
					
						
							|  |  |  |       browser.driver.sleep(300); | 
					
						
							|  |  |  |       expect(li.getCssValue('transform')).toMatch(NO_TRANSFORM_MATRIX_REGEX); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       removeHero(); | 
					
						
							|  |  |  |       expect(li.isPresent()).toBe(false); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('auto style calc', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let host: ElementFinder; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     beforeEach(function() { | 
					
						
							| 
									
										
										
										
											2017-08-22 21:31:15 +02:00
										 |  |  |       host = element(by.css('app-hero-list-auto')); | 
					
						
							| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('adds and removes element', () => { | 
					
						
							|  |  |  |       addInactiveHero(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let li = host.element(by.css('li')); | 
					
						
							|  |  |  |       expect(li.getCssValue('height')).toBe('50px'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       removeHero(); | 
					
						
							|  |  |  |       expect(li.isPresent()).toBe(false); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('different timings', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let host: ElementFinder; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     beforeEach(() => { | 
					
						
							| 
									
										
										
										
											2017-08-22 21:31:15 +02:00
										 |  |  |       host = element(by.css('app-hero-list-timings')); | 
					
						
							| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('adds and removes element', () => { | 
					
						
							|  |  |  |       addInactiveHero(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let li = host.element(by.css('li')); | 
					
						
							|  |  |  |       expect(li.getCssValue('transform')).toMatch(NO_TRANSFORM_MATRIX_REGEX); | 
					
						
							|  |  |  |       expect(li.getCssValue('opacity')).toMatch('1'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       removeHero(); | 
					
						
							|  |  |  |       expect(li.isPresent()).toBe(false); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('multiple keyframes', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let host: ElementFinder; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     beforeEach(() => { | 
					
						
							| 
									
										
										
										
											2017-08-22 21:31:15 +02:00
										 |  |  |       host = element(by.css('app-hero-list-multistep')); | 
					
						
							| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('adds and removes element', () => { | 
					
						
							|  |  |  |       addInactiveHero(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let li = host.element(by.css('li')); | 
					
						
							|  |  |  |       expect(li.getCssValue('transform')).toMatch(NO_TRANSFORM_MATRIX_REGEX); | 
					
						
							|  |  |  |       expect(li.getCssValue('opacity')).toMatch('1'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       removeHero(); | 
					
						
							|  |  |  |       expect(li.isPresent()).toBe(false); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('parallel groups', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let host: ElementFinder; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     beforeEach(() => { | 
					
						
							| 
									
										
										
										
											2017-08-22 21:31:15 +02:00
										 |  |  |       host = element(by.css('app-hero-list-groups')); | 
					
						
							| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('adds and removes element', () => { | 
					
						
							|  |  |  |       addInactiveHero(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let li = host.element(by.css('li')); | 
					
						
							|  |  |  |       expect(li.getCssValue('transform')).toMatch(NO_TRANSFORM_MATRIX_REGEX); | 
					
						
							|  |  |  |       expect(li.getCssValue('opacity')).toMatch('1'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       removeHero(700); | 
					
						
							|  |  |  |       expect(li.isPresent()).toBe(false); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('adding active heroes', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let host: ElementFinder; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     beforeEach(() => { | 
					
						
							| 
									
										
										
										
											2017-08-22 21:31:15 +02:00
										 |  |  |       host = element(by.css('app-hero-list-basic')); | 
					
						
							| 
									
										
										
										
											2017-02-22 18:13:21 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('animates between active and inactive', () => { | 
					
						
							|  |  |  |       addActiveHero(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let li = host.element(by.css('li')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.1); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(ACTIVE_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       li.click(); | 
					
						
							|  |  |  |       browser.driver.sleep(300); | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.0); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(INACTIVE_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       li.click(); | 
					
						
							|  |  |  |       browser.driver.sleep(300); | 
					
						
							|  |  |  |       expect(getScaleX(li)).toBe(1.1); | 
					
						
							|  |  |  |       expect(li.getCssValue('backgroundColor')).toBe(ACTIVE_COLOR); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('callbacks', () => { | 
					
						
							|  |  |  |     it('fires a callback on start and done', () => { | 
					
						
							|  |  |  |       addActiveHero(); | 
					
						
							|  |  |  |       browser.manage().logs().get(logging.Type.BROWSER) | 
					
						
							|  |  |  |         .then((logs: logging.Entry[]) => { | 
					
						
							|  |  |  |           const animationMessages = logs.filter((log) => { | 
					
						
							|  |  |  |             return log.message.indexOf('Animation') !== -1 ? true : false; | 
					
						
							|  |  |  |           }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           expect(animationMessages.length).toBeGreaterThan(0); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function addActiveHero(sleep?: number) { | 
					
						
							|  |  |  |     sleep = sleep || 500; | 
					
						
							|  |  |  |     element(by.buttonText('Add active hero')).click(); | 
					
						
							|  |  |  |     browser.driver.sleep(sleep); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function addInactiveHero(sleep?: number) { | 
					
						
							|  |  |  |     sleep = sleep || 500; | 
					
						
							|  |  |  |     element(by.buttonText('Add inactive hero')).click(); | 
					
						
							|  |  |  |     browser.driver.sleep(sleep); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function removeHero(sleep?: number) { | 
					
						
							|  |  |  |     sleep = sleep || 500; | 
					
						
							|  |  |  |     element(by.buttonText('Remove hero')).click(); | 
					
						
							|  |  |  |     browser.driver.sleep(sleep); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function getScaleX(el: ElementFinder) { | 
					
						
							|  |  |  |     return Promise.all([ | 
					
						
							|  |  |  |       getBoundingClientWidth(el), | 
					
						
							|  |  |  |       getOffsetWidth(el) | 
					
						
							|  |  |  |     ]).then(function(promiseResolutions) { | 
					
						
							|  |  |  |       let clientWidth = promiseResolutions[0]; | 
					
						
							|  |  |  |       let offsetWidth = promiseResolutions[1]; | 
					
						
							|  |  |  |       return clientWidth / offsetWidth; | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function getBoundingClientWidth(el: ElementFinder): promise.Promise<number> { | 
					
						
							|  |  |  |     return browser.executeScript( | 
					
						
							|  |  |  |       'return arguments[0].getBoundingClientRect().width', | 
					
						
							|  |  |  |       el.getWebElement() | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function getOffsetWidth(el: ElementFinder): promise.Promise<number> { | 
					
						
							|  |  |  |     return browser.executeScript( | 
					
						
							|  |  |  |       'return arguments[0].offsetWidth', | 
					
						
							|  |  |  |       el.getWebElement() | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | }); |