2018-01-24 09:35:09 +08:00
|
|
|
/*
|
|
|
|
* decaffeinate suggestions:
|
|
|
|
* DS001: Remove Babel/TypeScript constructor workaround
|
|
|
|
* DS101: Remove unnecessary use of Array.from
|
|
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
|
|
* DS207: Consider shorter variations of null checks
|
|
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
|
|
*/
|
2019-03-05 03:03:12 +08:00
|
|
|
import _ from 'underscore';
|
|
|
|
import { jasmine } from './jasmine';
|
2018-01-24 09:35:09 +08:00
|
|
|
|
2019-03-05 03:03:12 +08:00
|
|
|
export default class TimeReporter extends jasmine.Reporter {
|
2018-01-24 09:35:09 +08:00
|
|
|
constructor() {
|
|
|
|
super();
|
|
|
|
|
|
|
|
window.timedSpecs = [];
|
|
|
|
window.timedSuites = {};
|
|
|
|
|
|
|
|
window.logLongestSpec = () => this.logLongestSpecs(1);
|
|
|
|
window.logLongestSpecs = number => this.logLongestSpecs(number);
|
|
|
|
window.logLongestSuite = () => this.logLongestSuites(1);
|
|
|
|
window.logLongestSuites = number => this.logLongestSuites(number);
|
|
|
|
}
|
|
|
|
|
|
|
|
logLongestSuites(number, log) {
|
|
|
|
if (number == null) {
|
|
|
|
number = 10;
|
|
|
|
}
|
|
|
|
if (!(window.timedSuites.length > 0)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (log == null) {
|
|
|
|
log = line => console.log(line);
|
|
|
|
}
|
|
|
|
log('Longest running suites:');
|
|
|
|
const suites = _.map(window.timedSuites, (key, value) => [value, key]);
|
|
|
|
for (let suite of Array.from(_.sortBy(suites, suite => -suite[1]).slice(0, number))) {
|
|
|
|
const time = Math.round(suite[1] / 100) / 10;
|
|
|
|
log(` ${suite[0]} (${time}s)`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
logLongestSpecs(number, log) {
|
|
|
|
if (number == null) {
|
|
|
|
number = 10;
|
|
|
|
}
|
|
|
|
if (!(window.timedSpecs.length > 0)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (log == null) {
|
|
|
|
log = line => console.log(line);
|
|
|
|
}
|
|
|
|
log('Longest running specs:');
|
|
|
|
for (let spec of Array.from(_.sortBy(window.timedSpecs, spec => -spec.time).slice(0, number))) {
|
|
|
|
const time = Math.round(spec.time / 100) / 10;
|
|
|
|
log(`${spec.description} (${time}s)`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
reportSpecStarting(spec) {
|
|
|
|
const stack = [spec.description];
|
|
|
|
let { suite } = spec;
|
|
|
|
while (suite) {
|
|
|
|
stack.unshift(suite.description);
|
|
|
|
this.suite = suite.description;
|
|
|
|
suite = suite.parentSuite;
|
|
|
|
}
|
|
|
|
|
|
|
|
const reducer = function(memo, description, index) {
|
|
|
|
if (index === 0) {
|
|
|
|
return `${description}`;
|
|
|
|
} else {
|
2019-10-13 01:40:57 +08:00
|
|
|
return `${memo}\n${' '.repeat(index)}${description}`;
|
2018-01-24 09:35:09 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
this.description = _.reduce(stack, reducer, '');
|
|
|
|
this.time = Date.now();
|
|
|
|
}
|
|
|
|
|
|
|
|
reportSpecResults(spec) {
|
|
|
|
if (this.time == null || this.description == null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const duration = Date.now() - this.time;
|
|
|
|
|
|
|
|
if (duration > 0) {
|
|
|
|
window.timedSpecs.push({
|
|
|
|
description: this.description,
|
|
|
|
time: duration,
|
|
|
|
fullName: spec.getFullName(),
|
|
|
|
});
|
|
|
|
|
|
|
|
if (window.timedSuites[this.suite]) {
|
|
|
|
window.timedSuites[this.suite] += duration;
|
|
|
|
} else {
|
|
|
|
window.timedSuites[this.suite] = duration;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
this.time = null;
|
|
|
|
this.description = null;
|
|
|
|
}
|
2019-03-05 03:03:12 +08:00
|
|
|
}
|