180 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			180 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| 'use strict'; // necessary for es6 output in node
 | |
| 
 | |
| import { browser, element, by } from 'protractor';
 | |
| import { setProtractorToNg1Mode, waitForNg1AsyncBootstrap, setProtractorToHybridMode } from '../protractor-helpers';
 | |
| 
 | |
| describe('Upgrade Tests', function () {
 | |
| 
 | |
|   describe('NG1 Auto-bootstrap', function() {
 | |
| 
 | |
|     beforeAll(function () {
 | |
|       browser.get('/index-ng-app.html');
 | |
|       setProtractorToNg1Mode();
 | |
|     });
 | |
| 
 | |
|     it('bootstraps as expected', function () {
 | |
|       expect(element(by.css('#message')).getText()).toEqual('Hello world');
 | |
|     });
 | |
| 
 | |
|   });
 | |
| 
 | |
|   describe('NG1 JavaScript Bootstrap', function() {
 | |
| 
 | |
|     beforeAll(function () {
 | |
|       browser.get('/index-bootstrap.html');
 | |
|       setProtractorToNg1Mode();
 | |
|       waitForNg1AsyncBootstrap();
 | |
|     });
 | |
| 
 | |
|     it('bootstraps as expected', function () {
 | |
|       expect(element(by.css('#message')).getText()).toEqual('Hello world');
 | |
|     });
 | |
| 
 | |
|   });
 | |
| 
 | |
|   describe('NG1-2 Hybrid Bootstrap', function() {
 | |
| 
 | |
|     beforeAll(function () {
 | |
|       setProtractorToHybridMode();
 | |
|       browser.get('/index-1-2-hybrid-bootstrap.html');
 | |
|     });
 | |
| 
 | |
|     it('bootstraps as expected', function () {
 | |
|       expect(element(by.css('#message')).getText()).toEqual('Hello world');
 | |
|     });
 | |
| 
 | |
|   });
 | |
| 
 | |
|   describe('Upgraded static component', function() {
 | |
| 
 | |
|     beforeAll(function () {
 | |
|       setProtractorToHybridMode();
 | |
|       browser.get('/index-upgrade-static.html');
 | |
|     });
 | |
| 
 | |
|     it('renders', function () {
 | |
|       expect(element(by.css('h2')).getText()).toEqual('Windstorm details!');
 | |
|     });
 | |
| 
 | |
|   });
 | |
| 
 | |
| 
 | |
|   describe('Upgraded component with IO', function() {
 | |
| 
 | |
|     beforeAll(function () {
 | |
|       browser.get('/index-upgrade-io.html');
 | |
|       setProtractorToNg1Mode();
 | |
|       waitForNg1AsyncBootstrap();
 | |
|     });
 | |
| 
 | |
|     it('has inputs', function () {
 | |
|       expect(element(by.css('h2')).getText()).toEqual('Windstorm details!');
 | |
|     });
 | |
| 
 | |
|     it('has outputs', function () {
 | |
|       element(by.buttonText('Delete')).click();
 | |
|       expect(element(by.css('h2')).getText()).toEqual('Ex-Windstorm details!');
 | |
|     });
 | |
| 
 | |
|   });
 | |
| 
 | |
| 
 | |
|   describe('Downgraded static component', function() {
 | |
| 
 | |
|     beforeAll(function () {
 | |
|       browser.get('/index-downgrade-static.html');
 | |
|       setProtractorToNg1Mode();
 | |
|       waitForNg1AsyncBootstrap();
 | |
|     });
 | |
| 
 | |
|     it('renders', function () {
 | |
|       expect(element(by.css('h2')).getText()).toEqual('Windstorm details!');
 | |
|     });
 | |
| 
 | |
|   });
 | |
| 
 | |
|   describe('Downgraded component with IO', function() {
 | |
| 
 | |
|     beforeAll(function () {
 | |
|       browser.get('/index-downgrade-io.html');
 | |
|       setProtractorToNg1Mode();
 | |
|       waitForNg1AsyncBootstrap();
 | |
|     });
 | |
| 
 | |
|     it('has inputs', function () {
 | |
|       expect(element.all(by.css('h2')).first().getText()).toEqual('Windstorm details!');
 | |
|     });
 | |
| 
 | |
|     it('has outputs', function () {
 | |
|       element.all(by.buttonText('Delete')).first().click();
 | |
|       expect(element.all(by.css('h2')).first().getText()).toEqual('Ex-Windstorm details!');
 | |
|     });
 | |
| 
 | |
|     it('supports ng-repeat', function () {
 | |
|       expect(element.all(by.css('hero-detail')).count()).toBe(3);
 | |
|     });
 | |
| 
 | |
|   });
 | |
| 
 | |
| 
 | |
|   describe('Downgraded component with content projection', function() {
 | |
| 
 | |
|     beforeAll(function () {
 | |
|       browser.get('/index-1-to-2-projection.html');
 | |
|       setProtractorToNg1Mode();
 | |
|       waitForNg1AsyncBootstrap();
 | |
|     });
 | |
| 
 | |
|     it('can be transcluded into', function () {
 | |
|       expect(element(by.css('hero-detail')).getText()).toContain('Specific powers of controlling winds');
 | |
|     });
 | |
| 
 | |
|   });
 | |
| 
 | |
| 
 | |
|   describe('Upgraded component with transclusion', function() {
 | |
| 
 | |
|     beforeAll(function () {
 | |
|       browser.get('/index-2-to-1-transclusion.html');
 | |
|       setProtractorToNg1Mode();
 | |
|       waitForNg1AsyncBootstrap();
 | |
|     });
 | |
| 
 | |
|     it('can be projected into', function () {
 | |
|       expect(element(by.css('hero-detail')).getText()).toContain('Specific powers of controlling winds');
 | |
|     });
 | |
| 
 | |
|   });
 | |
| 
 | |
| 
 | |
|   describe('Upgrading NG1 Providers', function() {
 | |
| 
 | |
|     beforeAll(function () {
 | |
|       browser.get('/index-1-to-2-providers.html');
 | |
|       setProtractorToNg1Mode();
 | |
|       waitForNg1AsyncBootstrap();
 | |
|     });
 | |
| 
 | |
|     it('works', function () {
 | |
|       expect(element(by.css('h2')).getText()).toBe('1: Windstorm');
 | |
|     });
 | |
| 
 | |
|   });
 | |
| 
 | |
| 
 | |
|   describe('Downgrading NG2 Providers', function() {
 | |
| 
 | |
|     beforeAll(function () {
 | |
|       browser.get('/index-2-to-1-providers.html');
 | |
|       setProtractorToNg1Mode();
 | |
|       waitForNg1AsyncBootstrap();
 | |
|     });
 | |
| 
 | |
|     it('works', function () {
 | |
|       expect(element(by.css('h2')).getText()).toBe('1: Windstorm');
 | |
|     });
 | |
| 
 | |
|   });
 | |
| 
 | |
| });
 |