'use strict'; // necessary for es6 output in node import { browser, element, by } from 'protractor'; import { setProtractorToNg1Mode, waitForNg1AsyncBootstrap } 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 () { browser.get('/index-1-2-hybrid-bootstrap.html'); setProtractorToNg1Mode(); waitForNg1AsyncBootstrap(); }); it('bootstraps as expected', function () { expect(element(by.css('#message')).getText()).toEqual('Hello world'); }); }); describe('NG1-2 Hybrid Bootstrap with Shared UpgradeAdapter', function() { beforeAll(function () { browser.get('/index-1-2-hybrid-shared-adapter-bootstrap.html'); setProtractorToNg1Mode(); waitForNg1AsyncBootstrap(); }); it('bootstraps as expected', function () { expect(element(by.css('#message')).getText()).toEqual('Hello world'); }); }); describe('Upgraded static component', function() { beforeAll(function () { browser.get('/index-upgrade-static.html'); setProtractorToNg1Mode(); waitForNg1AsyncBootstrap(); }); 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'); }); }); });