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:
parent
7e6f536cf5
commit
3b40052dc7
|
@ -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; },
|
||||||
|
|
|
@ -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; },
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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$
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -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$
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
Loading…
Reference in New Issue