
Major changes: - make API more reusable - format output nicely - only force gc if needed Regarding forcing gc: Forcing gc can change script execution time. We now don't force gc at first and ignore results where gc happens during script execution. When we ignored too many results, we switch to forcing gc. Closes #339
61 lines
1.5 KiB
JavaScript
61 lines
1.5 KiB
JavaScript
"use strict";
|
|
var benchpress = require('../../../../tools/benchpress/benchpress.js');
|
|
|
|
describe('ng2 di benchmark', function () {
|
|
|
|
var URL = 'benchmarks/web/di/di_benchmark.html';
|
|
|
|
afterEach(benchpress.verifyNoBrowserErrors);
|
|
|
|
it('should log the stats for getByToken', function() {
|
|
browser.get(URL);
|
|
runClickTimeBenchmark({
|
|
buttons: ['#getByToken'],
|
|
logId: 'ng2.di.getByToken'
|
|
});
|
|
});
|
|
|
|
it('should log the stats for getByKey', function() {
|
|
browser.get(URL);
|
|
runClickTimeBenchmark({
|
|
buttons: ['#getByKey'],
|
|
logId: 'ng2.di.getByKey'
|
|
});
|
|
});
|
|
|
|
it('should log the stats for getChild', function() {
|
|
browser.get(URL);
|
|
runClickTimeBenchmark({
|
|
buttons: ['#getChild'],
|
|
logId: 'ng2.di.getChild'
|
|
});
|
|
});
|
|
|
|
it('should log the stats for instantiate', function() {
|
|
browser.get(URL);
|
|
runClickTimeBenchmark({
|
|
buttons: ['#instantiate'],
|
|
logId: 'ng2.di.instantiate'
|
|
});
|
|
});
|
|
|
|
});
|
|
|
|
function runClickTimeBenchmark(config) {
|
|
var buttons = config.buttons.map(function(selector) {
|
|
return $(selector);
|
|
});
|
|
var timeParams = browser.params.timeBenchmark;
|
|
benchpress.runTimeBenchmark({
|
|
sampleSize: timeParams.sampleSize,
|
|
targetCoefficientOfVariation: timeParams.targetCoefficientOfVariation,
|
|
timeout: timeParams.timeout,
|
|
metrics: timeParams.metrics,
|
|
logId: browser.params.lang+'.'+config.logId
|
|
}, function() {
|
|
buttons.forEach(function(button) {
|
|
button.click();
|
|
});
|
|
});
|
|
}
|