UNPKG

benchpress

Version:

Benchpress - a framework for e2e performance tests

116 lines 17.3 kB
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"]}