2016-05-30 14:05:09 -04:00
|
|
|
/// <reference path="../_protractor/e2e.d.ts" />
|
2016-01-03 14:32:57 -05:00
|
|
|
describe('User Input Tests', function () {
|
|
|
|
|
|
|
|
beforeAll(function () {
|
|
|
|
browser.get('');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should support the click event', function () {
|
2016-05-30 14:05:09 -04:00
|
|
|
let mainEle = element(by.css('click-me'));
|
2016-06-01 12:11:58 -04:00
|
|
|
let buttonEle = element(by.css('click-me button'));
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(mainEle.getText()).not.toContain('You are my hero!');
|
|
|
|
buttonEle.click().then(function() {
|
|
|
|
expect(mainEle.getText()).toContain('You are my hero!');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should support the click event with an event payload', function () {
|
2016-05-30 14:05:09 -04:00
|
|
|
let mainEle = element(by.css('click-me2'));
|
2016-06-01 12:11:58 -04:00
|
|
|
let buttonEle = element(by.css('click-me2 button'));
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(mainEle.getText()).not.toContain('Event target is ');
|
|
|
|
buttonEle.click().then(function() {
|
|
|
|
expect(mainEle.getText()).toContain('Event target is BUTTON');
|
2016-06-07 19:06:25 -04:00
|
|
|
});
|
2016-01-03 14:32:57 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should support the keyup event ', function () {
|
2016-05-30 14:05:09 -04:00
|
|
|
let mainEle = element(by.css('key-up1'));
|
|
|
|
let inputEle = mainEle.element(by.css('input'));
|
|
|
|
let outputTextEle = mainEle.element(by.css('p'));
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(outputTextEle.getText()).toEqual('');
|
2016-06-07 19:06:25 -04:00
|
|
|
return sendKeys(inputEle, 'abc').then(function() {
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(outputTextEle.getText()).toEqual('a | ab | abc |');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2016-05-30 14:05:09 -04:00
|
|
|
it('should support user input from a local template let (loopback)', function () {
|
|
|
|
let mainEle = element(by.css('loop-back'));
|
|
|
|
let inputEle = mainEle.element(by.css('input'));
|
|
|
|
let outputTextEle = mainEle.element(by.css('p'));
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(outputTextEle.getText()).toEqual('');
|
2016-06-07 19:06:25 -04:00
|
|
|
return sendKeys(inputEle, 'abc').then(function() {
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(outputTextEle.getText()).toEqual('abc');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should be able to combine click event with a local template var', function () {
|
2016-05-30 14:05:09 -04:00
|
|
|
let mainEle = element(by.css('key-up2'));
|
|
|
|
let inputEle = mainEle.element(by.css('input'));
|
|
|
|
let outputTextEle = mainEle.element(by.css('p'));
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(outputTextEle.getText()).toEqual('');
|
2016-06-07 19:06:25 -04:00
|
|
|
return sendKeys(inputEle, 'abc').then(function() {
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(outputTextEle.getText()).toEqual('a | ab | abc |');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should be able to filter key events', function () {
|
2016-05-30 14:05:09 -04:00
|
|
|
let mainEle = element(by.css('key-up3'));
|
|
|
|
let inputEle = mainEle.element(by.css('input'));
|
|
|
|
let outputTextEle = mainEle.element(by.css('p'));
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(outputTextEle.getText()).toEqual('');
|
2016-06-07 19:06:25 -04:00
|
|
|
return sendKeys(inputEle, 'abc').then(function() {
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(outputTextEle.getText()).toEqual('', 'should be blank - have not sent enter yet');
|
|
|
|
return sendKeys(inputEle, protractor.Key.ENTER);
|
|
|
|
}).then(function() {
|
|
|
|
expect(outputTextEle.getText()).toEqual('abc');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should be able to filter blur events', function () {
|
2016-05-30 14:05:09 -04:00
|
|
|
let prevInputEle = element(by.css('key-up3 input'));
|
|
|
|
let mainEle = element(by.css('key-up4'));
|
|
|
|
let inputEle = mainEle.element(by.css('input'));
|
|
|
|
let outputTextEle = mainEle.element(by.css('p'));
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(outputTextEle.getText()).toEqual('');
|
2016-06-07 19:06:25 -04:00
|
|
|
return sendKeys(inputEle, 'abc').then(function() {
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(outputTextEle.getText()).toEqual('', 'should be blank - have not sent enter yet');
|
|
|
|
// change the focus
|
|
|
|
return prevInputEle.click();
|
|
|
|
}).then(function() {
|
|
|
|
expect(outputTextEle.getText()).toEqual('abc');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should be able to compose little tour of heroes', function () {
|
2016-05-30 14:05:09 -04:00
|
|
|
let mainEle = element(by.css('little-tour'));
|
|
|
|
let inputEle = mainEle.element(by.css('input'));
|
|
|
|
let addButtonEle = mainEle.element(by.css('button'));
|
|
|
|
let heroEles = mainEle.all(by.css('li'));
|
2016-06-01 12:11:58 -04:00
|
|
|
let numHeroes: number;
|
2016-01-03 14:32:57 -05:00
|
|
|
expect(heroEles.count()).toBeGreaterThan(0);
|
|
|
|
heroEles.count().then(function(count) {
|
|
|
|
numHeroes = count;
|
|
|
|
return sendKeys(inputEle, 'abc');
|
|
|
|
}).then(function() {
|
|
|
|
return addButtonEle.click();
|
|
|
|
}).then(function() {
|
|
|
|
expect(heroEles.count()).toEqual(numHeroes + 1, 'should be one more hero added');
|
|
|
|
expect(heroEles.get(numHeroes).getText()).toContain('abc');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|