63 lines
2.1 KiB
TypeScript
63 lines
2.1 KiB
TypeScript
/// <reference path="../../angular2/typings/node/node.d.ts" />
|
|
/// <reference path="../../angular2/typings/angular-protractor/angular-protractor.d.ts" />
|
|
import {afterEach, describe, expect, it} from 'angular2/test_lib';
|
|
|
|
var testUtil = require('angular2/src/test_lib/e2e_util');
|
|
|
|
describe('ng2 naive infinite scroll benchmark', function() {
|
|
|
|
var URL = 'benchmarks/src/naive_infinite_scroll/index.html?appSize=3';
|
|
|
|
afterEach(testUtil.verifyNoBrowserErrors);
|
|
|
|
it('should not throw errors', function() {
|
|
browser.get(URL);
|
|
var expectedRowCount = 18;
|
|
var expectedCellsPerRow = 28;
|
|
var allScrollItems = 'scroll-app #testArea scroll-item';
|
|
var cells = `${ allScrollItems } .row *`;
|
|
var stageButtons = `${ allScrollItems } .row stage-buttons button`;
|
|
|
|
var count =
|
|
function(selector) {
|
|
return browser.executeScript(`return document.querySelectorAll("${ selector }").length;`);
|
|
}
|
|
|
|
var clickFirstOf =
|
|
function(selector) {
|
|
return browser.executeScript(`document.querySelector("${ selector }").click();`);
|
|
}
|
|
|
|
var firstTextOf =
|
|
function(selector) {
|
|
return browser.executeScript(`return document.querySelector("${ selector }").innerText;`);
|
|
}
|
|
|
|
// Make sure rows are rendered
|
|
count(allScrollItems)
|
|
.then(function(c) { expect(c).toBe(expectedRowCount); });
|
|
|
|
// Make sure cells are rendered
|
|
count(cells).then(function(c) { expect(c).toBe(expectedRowCount * expectedCellsPerRow); });
|
|
|
|
// Click on first enabled button and verify stage changes
|
|
firstTextOf(`${ stageButtons }:enabled`)
|
|
.then(function(text) {
|
|
expect(text).toBe('Pitched');
|
|
clickFirstOf(`${ stageButtons }:enabled`)
|
|
.then(function() {
|
|
firstTextOf(`${ stageButtons }:enabled`)
|
|
.then(function(text) { expect(text).toBe('Won'); })
|
|
});
|
|
})
|
|
|
|
$("#reset-btn")
|
|
.click();
|
|
$("#run-btn").click();
|
|
browser.wait(() => {
|
|
return $('#done').getText().then(function() { return true; }, function() { return false; });
|
|
}, 10000);
|
|
});
|
|
|
|
});
|