UNPKG

benchpress

Version:

Benchpress - a framework for e2e performance tests

88 lines 15 kB
import { print, NumberWrapper } from 'angular2/src/facade/lang'; import { StringMapWrapper } from 'angular2/src/facade/collection'; import { PromiseWrapper } from 'angular2/src/facade/async'; import { Math } from 'angular2/src/facade/math'; import { bind, provide, OpaqueToken } from 'angular2/src/core/di'; import { Statistic } from '../statistic'; import { Reporter } from '../reporter'; import { SampleDescription } from '../sample_description'; /** * A reporter for the console */ export class ConsoleReporter extends Reporter { constructor(_columnWidth, sampleDescription, _print) { super(); this._columnWidth = _columnWidth; this._print = _print; this._metricNames = ConsoleReporter._sortedProps(sampleDescription.metrics); this._printDescription(sampleDescription); } // TODO(tbosch): use static values when our transpiler supports them static get PRINT() { return _PRINT; } // TODO(tbosch): use static values when our transpiler supports them static get COLUMN_WIDTH() { return _COLUMN_WIDTH; } // TODO(tbosch): use static values when our transpiler supports them static get BINDINGS() { return _PROVIDERS; } static _lpad(value, columnWidth, fill = ' ') { var result = ''; for (var i = 0; i < columnWidth - value.length; i++) { result += fill; } return result + value; } static _formatNum(n) { return NumberWrapper.toFixed(n, 2); } static _sortedProps(obj) { var props = []; StringMapWrapper.forEach(obj, (value, prop) => props.push(prop)); props.sort(); return props; } _printDescription(sampleDescription) { this._print(`BENCHMARK ${sampleDescription.id}`); this._print('Description:'); var props = ConsoleReporter._sortedProps(sampleDescription.description); props.forEach((prop) => { this._print(`- ${prop}: ${sampleDescription.description[prop]}`); }); this._print('Metrics:'); this._metricNames.forEach((metricName) => { this._print(`- ${metricName}: ${sampleDescription.metrics[metricName]}`); }); this._print(''); this._printStringRow(this._metricNames); this._printStringRow(this._metricNames.map((_) => ''), '-'); } reportMeasureValues(measureValues) { var formattedValues = this._metricNames.map(metricName => { var value = measureValues.values[metricName]; return ConsoleReporter._formatNum(value); }); this._printStringRow(formattedValues); return PromiseWrapper.resolve(null); } reportSample(completeSample, validSamples) { this._printStringRow(this._metricNames.map((_) => ''), '='); this._printStringRow(this._metricNames.map(metricName => { var samples = validSamples.map(measureValues => measureValues.values[metricName]); var mean = Statistic.calculateMean(samples); var cv = Statistic.calculateCoefficientOfVariation(samples, mean); var formattedMean = ConsoleReporter._formatNum(mean); // Note: Don't use the unicode character for +- as it might cause // hickups for consoles... return NumberWrapper.isNaN(cv) ? formattedMean : `${formattedMean}+-${Math.floor(cv)}%`; })); return PromiseWrapper.resolve(null); } _printStringRow(parts, fill = ' ') { this._print(parts.map(part => ConsoleReporter._lpad(part, this._columnWidth, fill)).join(' | ')); } } var _PRINT = new OpaqueToken('ConsoleReporter.print'); var _COLUMN_WIDTH = new OpaqueToken('ConsoleReporter.columnWidth'); var _PROVIDERS = [ bind(ConsoleReporter) .toFactory((columnWidth, sampleDescription, print) => new ConsoleReporter(columnWidth, sampleDescription, print), [_COLUMN_WIDTH, SampleDescription, _PRINT]), provide(_COLUMN_WIDTH, { useValue: 18 }), provide(_PRINT, { useValue: print }) ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"console_reporter.js","sourceRoot":"","sources":["diffing_plugin_wrapper-output_path-xBLIBrVR.tmp/benchpress/src/reporter/console_reporter.ts"],"names":[],"mappings":"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","sourcesContent":["import {print, isPresent, isBlank, NumberWrapper} from 'angular2/src/facade/lang';\nimport {StringMapWrapper, ListWrapper} from 'angular2/src/facade/collection';\nimport {PromiseWrapper} from 'angular2/src/facade/async';\nimport {Math} from 'angular2/src/facade/math';\nimport {bind, provide, Provider, OpaqueToken} from 'angular2/src/core/di';\n\nimport {Statistic} from '../statistic';\nimport {Reporter} from '../reporter';\nimport {SampleDescription} from '../sample_description';\nimport {MeasureValues} from '../measure_values';\n\n/**\n * A reporter for the console\n */\nexport class ConsoleReporter extends Reporter {\n  // TODO(tbosch): use static values when our transpiler supports them\n  static get PRINT(): OpaqueToken { return _PRINT; }\n  // TODO(tbosch): use static values when our transpiler supports them\n  static get COLUMN_WIDTH(): OpaqueToken { return _COLUMN_WIDTH; }\n  // TODO(tbosch): use static values when our transpiler supports them\n  static get BINDINGS(): Provider[] { return _PROVIDERS; }\n\n\n  static _lpad(value, columnWidth, fill = ' ') {\n    var result = '';\n    for (var i = 0; i < columnWidth - value.length; i++) {\n      result += fill;\n    }\n    return result + value;\n  }\n\n  static _formatNum(n) { return NumberWrapper.toFixed(n, 2); }\n\n  static _sortedProps(obj) {\n    var props = [];\n    StringMapWrapper.forEach(obj, (value, prop) => props.push(prop));\n    props.sort();\n    return props;\n  }\n\n  private _metricNames: string[];\n\n  constructor(private _columnWidth: number, sampleDescription, private _print: Function) {\n    super();\n    this._metricNames = ConsoleReporter._sortedProps(sampleDescription.metrics);\n    this._printDescription(sampleDescription);\n  }\n\n  _printDescription(sampleDescription) {\n    this._print(`BENCHMARK ${sampleDescription.id}`);\n    this._print('Description:');\n    var props = ConsoleReporter._sortedProps(sampleDescription.description);\n    props.forEach((prop) => { this._print(`- ${prop}: ${sampleDescription.description[prop]}`); });\n    this._print('Metrics:');\n    this._metricNames.forEach((metricName) => {\n      this._print(`- ${metricName}: ${sampleDescription.metrics[metricName]}`);\n    });\n    this._print('');\n    this._printStringRow(this._metricNames);\n    this._printStringRow(this._metricNames.map((_) => ''), '-');\n  }\n\n  reportMeasureValues(measureValues: MeasureValues): Promise<any> {\n    var formattedValues = this._metricNames.map(metricName => {\n      var value = measureValues.values[metricName];\n      return ConsoleReporter._formatNum(value);\n    });\n    this._printStringRow(formattedValues);\n    return PromiseWrapper.resolve(null);\n  }\n\n  reportSample(completeSample: MeasureValues[], validSamples: MeasureValues[]): Promise<any> {\n    this._printStringRow(this._metricNames.map((_) => ''), '=');\n    this._printStringRow(this._metricNames.map(metricName => {\n      var samples = validSamples.map(measureValues => measureValues.values[metricName]);\n      var mean = Statistic.calculateMean(samples);\n      var cv = Statistic.calculateCoefficientOfVariation(samples, mean);\n      var formattedMean = ConsoleReporter._formatNum(mean)\n                              // Note: Don't use the unicode character for +- as it might cause\n                              // hickups for consoles...\n                              return NumberWrapper.isNaN(cv) ?\n                              formattedMean :\n                              `${formattedMean}+-${Math.floor(cv)}%`;\n    }));\n    return PromiseWrapper.resolve(null);\n  }\n\n  _printStringRow(parts: any[], fill = ' ') {\n    this._print(\n        parts.map(part => ConsoleReporter._lpad(part, this._columnWidth, fill)).join(' | '));\n  }\n}\n\nvar _PRINT = new OpaqueToken('ConsoleReporter.print');\nvar _COLUMN_WIDTH = new OpaqueToken('ConsoleReporter.columnWidth');\nvar _PROVIDERS = [\n  bind(ConsoleReporter)\n      .toFactory((columnWidth, sampleDescription, print) =>\n                     new ConsoleReporter(columnWidth, sampleDescription, print),\n                 [_COLUMN_WIDTH, SampleDescription, _PRINT]),\n  provide(_COLUMN_WIDTH, {useValue: 18}),\n  provide(_PRINT, {useValue: print})\n];\n"]}