benchpress
Version:
Benchpress - a framework for e2e performance tests
116 lines • 17.3 kB
JavaScript
import { bind } from 'angular2/src/core/di';
import { Json, isPresent, isBlank, StringWrapper } from 'angular2/src/facade/lang';
import { BaseException } from 'angular2/src/facade/exceptions';
import { WebDriverExtension, PerfLogFeatures } from '../web_driver_extension';
import { WebDriverAdapter } from '../web_driver_adapter';
export class IOsDriverExtension extends WebDriverExtension {
constructor(_driver) {
super();
this._driver = _driver;
}
// TODO(tbosch): use static values when our transpiler supports them
static get BINDINGS() { return _PROVIDERS; }
gc() { throw new BaseException('Force GC is not supported on iOS'); }
timeBegin(name) {
return this._driver.executeScript(`console.time('${name}');`);
}
timeEnd(name, restartName = null) {
var script = `console.timeEnd('${name}');`;
if (isPresent(restartName)) {
script += `console.time('${restartName}');`;
}
return this._driver.executeScript(script);
}
// See https://github.com/WebKit/webkit/tree/master/Source/WebInspectorUI/Versions
readPerfLog() {
// TODO(tbosch): Bug in IOsDriver: Need to execute at least one command
// so that the browser logs can be read out!
return this._driver.executeScript('1+1')
.then((_) => this._driver.logs('performance'))
.then((entries) => {
var records = [];
entries.forEach(entry => {
var message = Json.parse(entry['message'])['message'];
if (StringWrapper.equals(message['method'], 'Timeline.eventRecorded')) {
records.push(message['params']['record']);
}
});
return this._convertPerfRecordsToEvents(records);
});
}
_convertPerfRecordsToEvents(records, events = null) {
if (isBlank(events)) {
events = [];
}
records.forEach((record) => {
var endEvent = null;
var type = record['type'];
var data = record['data'];
var startTime = record['startTime'];
var endTime = record['endTime'];
if (StringWrapper.equals(type, 'FunctionCall') &&
(isBlank(data) || !StringWrapper.equals(data['scriptName'], 'InjectedScript'))) {
events.push(createStartEvent('script', startTime));
endEvent = createEndEvent('script', endTime);
}
else if (StringWrapper.equals(type, 'Time')) {
events.push(createMarkStartEvent(data['message'], startTime));
}
else if (StringWrapper.equals(type, 'TimeEnd')) {
events.push(createMarkEndEvent(data['message'], startTime));
}
else if (StringWrapper.equals(type, 'RecalculateStyles') ||
StringWrapper.equals(type, 'Layout') ||
StringWrapper.equals(type, 'UpdateLayerTree') ||
StringWrapper.equals(type, 'Paint') || StringWrapper.equals(type, 'Rasterize') ||
StringWrapper.equals(type, 'CompositeLayers')) {
events.push(createStartEvent('render', startTime));
endEvent = createEndEvent('render', endTime);
}
// Note: ios used to support GCEvent up until iOS 6 :-(
if (isPresent(record['children'])) {
this._convertPerfRecordsToEvents(record['children'], events);
}
if (isPresent(endEvent)) {
events.push(endEvent);
}
});
return events;
}
perfLogFeatures() { return new PerfLogFeatures({ render: true }); }
supports(capabilities) {
return StringWrapper.equals(capabilities['browserName'].toLowerCase(), 'safari');
}
}
function createEvent(ph, name, time, args = null) {
var result = {
'cat': 'timeline',
'name': name,
'ts': time,
'ph': ph,
// The ios protocol does not support the notions of multiple processes in
// the perflog...
'pid': 'pid0'
};
if (isPresent(args)) {
result['args'] = args;
}
return result;
}
function createStartEvent(name, time, args = null) {
return createEvent('B', name, time, args);
}
function createEndEvent(name, time, args = null) {
return createEvent('E', name, time, args);
}
function createMarkStartEvent(name, time) {
return createEvent('b', name, time);
}
function createMarkEndEvent(name, time) {
return createEvent('e', name, time);
}
var _PROVIDERS = [
bind(IOsDriverExtension)
.toFactory((driver) => new IOsDriverExtension(driver), [WebDriverAdapter])
];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ios_driver_extension.js","sourceRoot":"","sources":["diffing_plugin_wrapper-output_path-xBLIBrVR.tmp/benchpress/src/webdriver/ios_driver_extension.ts"],"names":[],"mappings":"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","sourcesContent":["import {bind, provide, Provider} from 'angular2/src/core/di';\nimport {Json, isPresent, isBlank, RegExpWrapper, StringWrapper} from 'angular2/src/facade/lang';\nimport {BaseException, WrappedException} from 'angular2/src/facade/exceptions';\n\nimport {WebDriverExtension, PerfLogFeatures} from '../web_driver_extension';\nimport {WebDriverAdapter} from '../web_driver_adapter';\n\nexport class IOsDriverExtension extends WebDriverExtension {\n  // TODO(tbosch): use static values when our transpiler supports them\n  static get BINDINGS(): Provider[] { return _PROVIDERS; }\n\n  constructor(private _driver: WebDriverAdapter) { super(); }\n\n  gc(): Promise<any> { throw new BaseException('Force GC is not supported on iOS'); }\n\n  timeBegin(name: string): Promise<any> {\n    return this._driver.executeScript(`console.time('${name}');`);\n  }\n\n  timeEnd(name: string, restartName: string = null): Promise<any> {\n    var script = `console.timeEnd('${name}');`;\n    if (isPresent(restartName)) {\n      script += `console.time('${restartName}');`\n    }\n    return this._driver.executeScript(script);\n  }\n\n  // See https://github.com/WebKit/webkit/tree/master/Source/WebInspectorUI/Versions\n  readPerfLog() {\n    // TODO(tbosch): Bug in IOsDriver: Need to execute at least one command\n    // so that the browser logs can be read out!\n    return this._driver.executeScript('1+1')\n        .then((_) => this._driver.logs('performance'))\n        .then((entries) => {\n          var records = [];\n          entries.forEach(entry => {\n            var message = Json.parse(entry['message'])['message'];\n            if (StringWrapper.equals(message['method'], 'Timeline.eventRecorded')) {\n              records.push(message['params']['record']);\n            }\n          });\n          return this._convertPerfRecordsToEvents(records);\n        });\n  }\n\n  _convertPerfRecordsToEvents(records: any[], events: any[] = null) {\n    if (isBlank(events)) {\n      events = [];\n    }\n    records.forEach((record) => {\n      var endEvent = null;\n      var type = record['type'];\n      var data = record['data'];\n      var startTime = record['startTime'];\n      var endTime = record['endTime'];\n\n      if (StringWrapper.equals(type, 'FunctionCall') &&\n          (isBlank(data) || !StringWrapper.equals(data['scriptName'], 'InjectedScript'))) {\n        events.push(createStartEvent('script', startTime));\n        endEvent = createEndEvent('script', endTime);\n      } else if (StringWrapper.equals(type, 'Time')) {\n        events.push(createMarkStartEvent(data['message'], startTime));\n      } else if (StringWrapper.equals(type, 'TimeEnd')) {\n        events.push(createMarkEndEvent(data['message'], startTime));\n      } else if (StringWrapper.equals(type, 'RecalculateStyles') ||\n                 StringWrapper.equals(type, 'Layout') ||\n                 StringWrapper.equals(type, 'UpdateLayerTree') ||\n                 StringWrapper.equals(type, 'Paint') || StringWrapper.equals(type, 'Rasterize') ||\n                 StringWrapper.equals(type, 'CompositeLayers')) {\n        events.push(createStartEvent('render', startTime));\n        endEvent = createEndEvent('render', endTime);\n      }\n      // Note: ios used to support GCEvent up until iOS 6 :-(\n      if (isPresent(record['children'])) {\n        this._convertPerfRecordsToEvents(record['children'], events);\n      }\n      if (isPresent(endEvent)) {\n        events.push(endEvent);\n      }\n    });\n    return events;\n  }\n\n  perfLogFeatures(): PerfLogFeatures { return new PerfLogFeatures({render: true}); }\n\n  supports(capabilities: {[key: string]: any}): boolean {\n    return StringWrapper.equals(capabilities['browserName'].toLowerCase(), 'safari');\n  }\n}\n\nfunction createEvent(ph, name, time, args = null) {\n  var result = {\n    'cat': 'timeline',\n    'name': name,\n    'ts': time,\n    'ph': ph,\n    // The ios protocol does not support the notions of multiple processes in\n    // the perflog...\n    'pid': 'pid0'\n  };\n  if (isPresent(args)) {\n    result['args'] = args;\n  }\n  return result;\n}\n\nfunction createStartEvent(name, time, args = null) {\n  return createEvent('B', name, time, args);\n}\n\nfunction createEndEvent(name, time, args = null) {\n  return createEvent('E', name, time, args);\n}\n\nfunction createMarkStartEvent(name, time) {\n  return createEvent('b', name, time);\n}\n\nfunction createMarkEndEvent(name, time) {\n  return createEvent('e', name, time);\n}\n\nvar _PROVIDERS = [\n  bind(IOsDriverExtension)\n      .toFactory((driver) => new IOsDriverExtension(driver), [WebDriverAdapter])\n];\n"]}