feat(build): enforce mobile layout during e2e tests

This is important as we run our benchmarks on
mobile devices as web driver tests fails if buttons
are not visible / overlaid by other content.
This commit is contained in:
Tobias Bosch 2015-02-27 09:07:16 -08:00
parent 7e6f536cf5
commit 3b40052dc7
8 changed files with 53 additions and 41 deletions

View File

@ -13,8 +13,8 @@ describe('ng2 naive infinite scroll benchmark', function () {
url: URL, url: URL,
id: 'ng2.naive_infinite_scroll', id: 'ng2.naive_infinite_scroll',
work: function() { work: function() {
element(by.deepCss('#reset-btn')).click(); $('#reset-btn').click();
element(by.deepCss('#run-btn')).click(); $('#run-btn').click();
browser.wait(() => { browser.wait(() => {
return $('#done').getText().then( return $('#done').getText().then(
function() { return true; }, function() { return true; },

View File

@ -53,10 +53,8 @@ describe('ng2 naive infinite scroll benchmark', function () {
}); });
}) })
browser.executeScript( $("#reset-btn").click();
'document.querySelector("scroll-app /deep/ #reset-btn").click()'); $("#run-btn").click();
browser.executeScript(
'document.querySelector("scroll-app /deep/ #run-btn").click()');
browser.wait(() => { browser.wait(() => {
return $('#done').getText().then( return $('#done').getText().then(
function() { return true; }, function() { return true; },

View File

@ -23,11 +23,10 @@ export class App {
for (var i = 0; i < appSize; i++) { for (var i = 0; i < appSize; i++) {
ListWrapper.push(this.scrollAreas, i); ListWrapper.push(this.scrollAreas, i);
} }
// TODO(tbosch): change to bindAction when it works in pub serve bindAction('#run-btn', () => {
DOM.on(DOM.query('scroll-app /deep/ #run-btn'), 'click', (_) => {
this.runBenchmark(); this.runBenchmark();
}); });
DOM.on(DOM.query('scroll-app /deep/ #reset-btn'), 'click', (_) => { bindAction('#reset-btn', () => {
this._getScrollDiv().scrollTop = 0; this._getScrollDiv().scrollTop = 0;
var existingMarker = this._locateFinishedMarker(); var existingMarker = this._locateFinishedMarker();
if (isPresent(existingMarker)) { if (isPresent(existingMarker)) {
@ -90,10 +89,6 @@ export function setupReflectorForApp() {
<div> <div>
<div style="display: flex"> <div style="display: flex">
<scroll-area id="testArea"></scroll-area> <scroll-area id="testArea"></scroll-area>
<div style="padding-left: 20px">
<button id="run-btn">Run</button>
<button id="reset-btn">Reset</button>
</div>
</div> </div>
<div template="if scrollAreas.length > 0"> <div template="if scrollAreas.length > 0">
<p>Following tables are only here to add weight to the UI:</p> <p>Following tables are only here to add weight to the UI:</p>

View File

@ -9,6 +9,10 @@
Iteration count: <input type="text" name="iterationCount" value="1"></input><br> Iteration count: <input type="text" name="iterationCount" value="1"></input><br>
Scroll increment: <input type="text" name="scrollIncrement" value="1"></input><br> Scroll increment: <input type="text" name="scrollIncrement" value="1"></input><br>
</form> </form>
<div>
<button id="run-btn">Run</button>
<button id="reset-btn">Reset</button>
</div>
<scroll-app></scroll-app> <scroll-app></scroll-app>
$SCRIPTS$ $SCRIPTS$

View File

@ -13,8 +13,8 @@ describe('ng-dart1.x naive infinite scroll benchmark', function () {
url: URL, url: URL,
id: 'ng1-dart1.x.naive_infinite_scroll', id: 'ng1-dart1.x.naive_infinite_scroll',
work: function() { work: function() {
element(by.deepCss('#reset-btn')).click(); $('#reset-btn').click();
element(by.deepCss('#run-btn')).click(); $('#run-btn').click();
var s = 1000; var s = 1000;
if (appSize > 4) { if (appSize > 4) {
s = s + appSize * 100; s = s + appSize * 100;

View File

@ -11,10 +11,6 @@ import 'package:angular2/src/test_lib/benchmark_util.dart';
<div> <div>
<div style="display: flex"> <div style="display: flex">
<scroll-area scroll-top="scrollTop"></scroll-area> <scroll-area scroll-top="scrollTop"></scroll-area>
<div style="padding-left: 20px">
<button id='run-btn'>Run</button>
<button id='reset-btn'>Reset</button>
</div>
</div> </div>
<div ng-if="scrollAreas.length > 0"> <div ng-if="scrollAreas.length > 0">
<p>Following tables are only here to add weight to the UI:</p> <p>Following tables are only here to add weight to the UI:</p>
@ -39,10 +35,10 @@ class App implements ShadowRootAware {
@override @override
void onShadowRoot(ShadowRoot shadowRoot) { void onShadowRoot(ShadowRoot shadowRoot) {
bindAction('scroll-app /deep/ #run-btn', () { bindAction('#run-btn', () {
runBenchmark(); runBenchmark();
}); });
bindAction('scroll-app /deep/ #reset-btn', () { bindAction('#reset-btn', () {
scrollTop = 0; scrollTop = 0;
}); });
} }

View File

@ -9,6 +9,10 @@
Iteration count: <input type="text" name="iterationCount" value="1"></input><br> Iteration count: <input type="text" name="iterationCount" value="1"></input><br>
Scroll increment: <input type="text" name="scrollIncrement" value="1"></input><br> Scroll increment: <input type="text" name="scrollIncrement" value="1"></input><br>
</form> </form>
<div>
<button id="run-btn">Run</button>
<button id="reset-btn">Reset</button>
</div>
<scroll-app></scroll-app> <scroll-app></scroll-app>
$SCRIPTS$ $SCRIPTS$

View File

@ -33,17 +33,32 @@ var argv = require('yargs')
var browsers = argv['browsers'].split(','); var browsers = argv['browsers'].split(',');
var CHROME_OPTIONS = {
'args': ['--js-flags=--expose-gc'],
'perfLoggingPrefs': {
'traceCategories': 'blink.console,disabled-by-default-devtools.timeline'
}
};
var CHROME_MOBILE_EMULATION = {
// Can't use 'deviceName':'Google Nexus 7 2'
// as this would yield wrong orientation,
// so we specify facts explicitly
'deviceMetrics': {
'width': 600,
'height': 960,
'pixelRatio': 2
}
};
var BROWSER_CAPS = { var BROWSER_CAPS = {
Dartium: { Dartium: {
name: 'Dartium', name: 'Dartium',
browserName: 'chrome', browserName: 'chrome',
chromeOptions: { chromeOptions: mergeInto(CHROME_OPTIONS, {
'binary': process.env.DARTIUM, 'mobileEmulation': CHROME_MOBILE_EMULATION,
'args': ['--js-flags=--expose-gc'], 'binary': process.env.DARTIUM
'perfLoggingPrefs': { }),
'traceCategories': 'blink.console,disabled-by-default-devtools.timeline'
}
},
loggingPrefs: { loggingPrefs: {
performance: 'ALL', performance: 'ALL',
browser: 'ALL' browser: 'ALL'
@ -51,12 +66,9 @@ var BROWSER_CAPS = {
}, },
ChromeDesktop: { ChromeDesktop: {
browserName: 'chrome', browserName: 'chrome',
chromeOptions: { chromeOptions: mergeInto(CHROME_OPTIONS, {
'args': ['--js-flags=--expose-gc'], 'mobileEmulation': CHROME_MOBILE_EMULATION
'perfLoggingPrefs': { }),
'traceCategories': 'blink.console,disabled-by-default-devtools.timeline'
}
},
loggingPrefs: { loggingPrefs: {
performance: 'ALL', performance: 'ALL',
browser: 'ALL' browser: 'ALL'
@ -64,13 +76,9 @@ var BROWSER_CAPS = {
}, },
ChromeAndroid: { ChromeAndroid: {
browserName: 'chrome', browserName: 'chrome',
chromeOptions: { chromeOptions: mergeInto(CHROME_OPTIONS, {
androidPackage: 'com.android.chrome', 'androidPackage': 'com.android.chrome',
'args': ['--js-flags=--expose-gc'], }),
'perfLoggingPrefs': {
'traceCategories': 'blink.console,disabled-by-default-devtools.timeline'
}
},
loggingPrefs: { loggingPrefs: {
performance: 'ALL', performance: 'ALL',
browser: 'ALL' browser: 'ALL'
@ -201,3 +209,10 @@ exports.createBenchpressRunner = function(options) {
global.benchpressRunner = new benchpress.Runner(bindings); global.benchpressRunner = new benchpress.Runner(bindings);
} }
function mergeInto(src, target) {
for (var prop in src) {
target[prop] = src[prop];
}
return target;
}