appium-android-driver 4.52.0 → 4.52.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.helpers = exports.default = exports.commands = exports.SUPPORTED_PERFORMANCE_DATA_TYPES = exports.NETWORK_KEYS = exports.MEMORY_KEYS = exports.CPU_KEYS = exports.BATTERY_KEYS = void 0;
8
+ exports.default = exports.NETWORK_KEYS = exports.BATTERY_KEYS = exports.MEMORY_KEYS = exports.CPU_KEYS = exports.SUPPORTED_PERFORMANCE_DATA_TYPES = exports.helpers = exports.commands = void 0;
9
9
 
10
10
  require("source-map-support/register");
11
11
 
@@ -15,9 +15,9 @@ var _asyncbox = require("asyncbox");
15
15
 
16
16
  var _logger = _interopRequireDefault(require("../logger"));
17
17
 
18
- let commands = {},
19
- helpers = {},
20
- extensions = {};
18
+ const commands = {},
19
+ helpers = {},
20
+ extensions = {};
21
21
  exports.helpers = helpers;
22
22
  exports.commands = commands;
23
23
  const NETWORK_KEYS = [['bucketStart', 'activeTime', 'rxBytes', 'rxPackets', 'txBytes', 'txPackets', 'operations', 'bucketDuration'], ['st', 'activeTime', 'rb', 'rp', 'tb', 'tp', 'op', 'bucketDuration']];
@@ -26,50 +26,99 @@ const CPU_KEYS = ['user', 'kernel'];
26
26
  exports.CPU_KEYS = CPU_KEYS;
27
27
  const BATTERY_KEYS = ['power'];
28
28
  exports.BATTERY_KEYS = BATTERY_KEYS;
29
- const MEMORY_KEYS = ['totalPrivateDirty', 'nativePrivateDirty', 'dalvikPrivateDirty', 'eglPrivateDirty', 'glPrivateDirty', 'totalPss', 'nativePss', 'dalvikPss', 'eglPss', 'glPss', 'nativeHeapAllocatedSize', 'nativeHeapSize'];
29
+ const MEMORY_KEYS = ['totalPrivateDirty', 'nativePrivateDirty', 'dalvikPrivateDirty', 'eglPrivateDirty', 'glPrivateDirty', 'totalPss', 'nativePss', 'dalvikPss', 'eglPss', 'glPss', 'nativeHeapAllocatedSize', 'nativeHeapSize', 'nativeRss', 'dalvikRss', 'totalRss'];
30
30
  exports.MEMORY_KEYS = MEMORY_KEYS;
31
- const SUPPORTED_PERFORMANCE_DATA_TYPES = {
31
+ const SUPPORTED_PERFORMANCE_DATA_TYPES = Object.freeze({
32
32
  cpuinfo: 'the amount of cpu by user and kernel process - cpu information for applications on real devices and simulators',
33
33
  memoryinfo: 'the amount of memory used by the process - memory information for applications on real devices and simulators',
34
34
  batteryinfo: 'the remaining battery power - battery power information for applications on real devices and simulators',
35
35
  networkinfo: 'the network statistics - network rx/tx information for applications on real devices and simulators'
36
- };
36
+ });
37
37
  exports.SUPPORTED_PERFORMANCE_DATA_TYPES = SUPPORTED_PERFORMANCE_DATA_TYPES;
38
- const RETRY_PAUSE = 1000;
38
+ const MEMINFO_TITLES = Object.freeze({
39
+ NATIVE: 'Native',
40
+ DALVIK: 'Dalvik',
41
+ EGL: 'EGL',
42
+ GL: 'GL',
43
+ MTRACK: 'mtrack',
44
+ TOTAL: 'TOTAL',
45
+ HEAP: 'Heap'
46
+ });
47
+ const RETRY_PAUSE_MS = 1000;
48
+
49
+ function parseMeminfoForApi19To29(entries, valDict) {
50
+ const [type, subType] = entries;
51
+
52
+ if (type === MEMINFO_TITLES.NATIVE && subType === MEMINFO_TITLES.HEAP) {
53
+ [,, valDict.nativePss, valDict.nativePrivateDirty,,, valDict.nativeHeapSize, valDict.nativeHeapAllocatedSize] = entries;
54
+ } else if (type === MEMINFO_TITLES.DALVIK && subType === MEMINFO_TITLES.HEAP) {
55
+ [,, valDict.dalvikPss, valDict.dalvikPrivateDirty] = entries;
56
+ } else if (type === MEMINFO_TITLES.EGL && subType === MEMINFO_TITLES.MTRACK) {
57
+ [,, valDict.eglPss, valDict.eglPrivateDirty] = entries;
58
+ } else if (type === MEMINFO_TITLES.GL && subType === MEMINFO_TITLES.MTRACK) {
59
+ [,, valDict.glPss, valDict.glPrivateDirty] = entries;
60
+ } else if (type === MEMINFO_TITLES.TOTAL && entries.length === 8) {
61
+ [, valDict.totalPss, valDict.totalPrivateDirty] = entries;
62
+ }
63
+ }
64
+
65
+ function parseMeminfoForApiBelow19(entries, valDict) {
66
+ const type = entries[0];
67
+
68
+ if (type === MEMINFO_TITLES.NATIVE) {
69
+ [, valDict.nativePss,, valDict.nativePrivateDirty, valDict.nativeHeapSize, valDict.nativeHeapAllocatedSize] = entries;
70
+ } else if (type === MEMINFO_TITLES.DALVIK) {
71
+ [, valDict.dalvikPss,, valDict.dalvikPrivateDirty] = entries;
72
+ } else if (type === MEMINFO_TITLES.EGL) {
73
+ [, valDict.eglPss,, valDict.eglPrivateDirty] = entries;
74
+ } else if (type === MEMINFO_TITLES.GL) {
75
+ [, valDict.glPss,, valDict.glPrivateDirty] = entries;
76
+ } else if (type === MEMINFO_TITLES.TOTAL) {
77
+ [, valDict.totalPss,, valDict.totalPrivateDirty] = entries;
78
+ }
79
+ }
80
+
81
+ function parseMeminfoForApiAbove29(entries, valDict) {
82
+ const [type, subType] = entries;
83
+
84
+ if (type === MEMINFO_TITLES.NATIVE && subType === MEMINFO_TITLES.HEAP) {
85
+ [,, valDict.nativePss, valDict.nativePrivateDirty,,, valDict.nativeRss, valDict.nativeHeapSize, valDict.nativeHeapAllocatedSize] = entries;
86
+ } else if (type === MEMINFO_TITLES.DALVIK && subType === MEMINFO_TITLES.HEAP) {
87
+ [,, valDict.dalvikPss, valDict.dalvikPrivateDirty,,, valDict.dalvikRss] = entries;
88
+ } else if (type === MEMINFO_TITLES.EGL && subType === MEMINFO_TITLES.MTRACK) {
89
+ [,, valDict.eglPss, valDict.eglPrivateDirty] = entries;
90
+ } else if (type === MEMINFO_TITLES.GL && subType === MEMINFO_TITLES.MTRACK) {
91
+ [,, valDict.glPss, valDict.glPrivateDirty] = entries;
92
+ } else if (type === MEMINFO_TITLES.TOTAL && entries.length === 9) {
93
+ [, valDict.totalPss, valDict.totalPrivateDirty,,, valDict.totalRss] = entries;
94
+ }
95
+ }
39
96
 
40
97
  commands.getPerformanceDataTypes = function getPerformanceDataTypes() {
41
98
  return _lodash.default.keys(SUPPORTED_PERFORMANCE_DATA_TYPES);
42
99
  };
43
100
 
44
- commands.getPerformanceData = async function getPerformanceData(packageName, dataType, dataReadTimeout = 2) {
45
- let data;
46
-
47
- switch (dataType) {
101
+ commands.getPerformanceData = async function getPerformanceData(packageName, dataType, retries = 2) {
102
+ switch (_lodash.default.toLower(dataType)) {
48
103
  case 'batteryinfo':
49
- data = await this.getBatteryInfo(dataReadTimeout);
50
- break;
104
+ return await this.getBatteryInfo(retries);
51
105
 
52
106
  case 'cpuinfo':
53
- data = await this.getCPUInfo(packageName, dataReadTimeout);
54
- break;
107
+ return await this.getCPUInfo(packageName, retries);
55
108
 
56
109
  case 'memoryinfo':
57
- data = await this.getMemoryInfo(packageName, dataReadTimeout);
58
- break;
110
+ return await this.getMemoryInfo(packageName, retries);
59
111
 
60
112
  case 'networkinfo':
61
- data = await this.getNetworkTrafficInfo(dataReadTimeout);
62
- break;
113
+ return await this.getNetworkTrafficInfo(retries);
63
114
 
64
115
  default:
65
- throw new Error(`No performance data of type '${dataType}' found.`);
116
+ throw new Error(`No performance data of type '${dataType}' found. ` + `Only the following values are supported: ${JSON.stringify(SUPPORTED_PERFORMANCE_DATA_TYPES, ' ', 2)}`);
66
117
  }
67
-
68
- return data;
69
118
  };
70
119
 
71
- helpers.getCPUInfo = async function getCPUInfo(packageName, dataReadTimeout = 2) {
72
- return await (0, _asyncbox.retryInterval)(dataReadTimeout, RETRY_PAUSE, async () => {
120
+ helpers.getCPUInfo = async function getCPUInfo(packageName, retries = 2) {
121
+ return await (0, _asyncbox.retryInterval)(retries, RETRY_PAUSE_MS, async () => {
73
122
  let output;
74
123
 
75
124
  try {
@@ -95,8 +144,8 @@ helpers.getCPUInfo = async function getCPUInfo(packageName, dataReadTimeout = 2)
95
144
  });
96
145
  };
97
146
 
98
- helpers.getBatteryInfo = async function getBatteryInfo(dataReadTimeout = 2) {
99
- return await (0, _asyncbox.retryInterval)(dataReadTimeout, RETRY_PAUSE, async () => {
147
+ helpers.getBatteryInfo = async function getBatteryInfo(retries = 2) {
148
+ return await (0, _asyncbox.retryInterval)(retries, RETRY_PAUSE_MS, async () => {
100
149
  let cmd = ['dumpsys', 'battery', '|', 'grep', 'level'];
101
150
  let data = await this.adb.shell(cmd);
102
151
  if (!data) throw new Error('No data from dumpsys');
@@ -110,76 +159,45 @@ helpers.getBatteryInfo = async function getBatteryInfo(dataReadTimeout = 2) {
110
159
  });
111
160
  };
112
161
 
113
- helpers.getMemoryInfo = async function getMemoryInfo(packageName, dataReadTimeout = 2) {
114
- return await (0, _asyncbox.retryInterval)(dataReadTimeout, RETRY_PAUSE, async () => {
115
- let cmd = ['dumpsys', 'meminfo', `'${packageName}'`, '|', 'grep', '-E', "'Native|Dalvik|EGL|GL|TOTAL'"];
116
- let data = await this.adb.shell(cmd);
117
- if (!data) throw new Error('No data from dumpsys');
118
- let totalPrivateDirty, totalPss, nativePrivateDirty, nativePss, nativeHeapSize, nativeHeapAllocatedSize, dalvikPrivateDirty, dalvikPss, eglPrivateDirty, eglPss, glPrivateDirty, glPss;
119
- let apilevel = await this.adb.getApiLevel();
120
-
121
- for (let line of data.split('\n')) {
122
- let entries = line.trim().split(' ').filter(Boolean);
123
-
124
- if (apilevel > 18) {
125
- let type = entries[0];
126
- let subType = entries[1];
127
-
128
- if (type === 'Native' && subType === 'Heap') {
129
- nativePss = entries[2];
130
- nativePrivateDirty = entries[3];
131
- nativeHeapSize = entries[6];
132
- nativeHeapAllocatedSize = entries[7];
133
- } else if (type === 'Dalvik' && subType === 'Heap') {
134
- dalvikPss = entries[2];
135
- dalvikPrivateDirty = entries[3];
136
- } else if (type === 'EGL' && subType === 'mtrack') {
137
- eglPss = entries[2];
138
- eglPrivateDirty = entries[3];
139
- } else if (type === 'GL' && subType === 'mtrack') {
140
- glPss = entries[2];
141
- glPrivateDirty = entries[3];
142
- } else if (type === 'TOTAL' && entries.length === 8) {
143
- totalPss = entries[1];
144
- totalPrivateDirty = entries[2];
145
- }
162
+ helpers.getMemoryInfo = async function getMemoryInfo(packageName, retries = 2) {
163
+ return await (0, _asyncbox.retryInterval)(retries, RETRY_PAUSE_MS, async () => {
164
+ const cmd = ['dumpsys', 'meminfo', `'${packageName}'`, '|', 'grep', '-E', `'${MEMINFO_TITLES.NATIVE}|${MEMINFO_TITLES.DALVIK}|${MEMINFO_TITLES.EGL}` + `|${MEMINFO_TITLES.GL}|${MEMINFO_TITLES.TOTAL}'`];
165
+ const data = await this.adb.shell(cmd);
166
+
167
+ if (!data) {
168
+ throw new Error('No data from dumpsys');
169
+ }
170
+
171
+ const valDict = {
172
+ totalPrivateDirty: ''
173
+ };
174
+ const apiLevel = await this.adb.getApiLevel();
175
+
176
+ for (const line of data.split('\n')) {
177
+ const entries = line.trim().split(/\s+/).filter(Boolean);
178
+
179
+ if (apiLevel >= 30) {
180
+ parseMeminfoForApiAbove29(entries, valDict);
181
+ } else if (apiLevel > 18 && apiLevel < 30) {
182
+ parseMeminfoForApi19To29(entries, valDict);
146
183
  } else {
147
- let type = entries[0];
148
-
149
- if (type === 'Native') {
150
- nativePss = entries[1];
151
- nativePrivateDirty = entries[3];
152
- nativeHeapSize = entries[4];
153
- nativeHeapAllocatedSize = entries[5];
154
- } else if (type === 'Dalvik') {
155
- dalvikPss = entries[1];
156
- dalvikPrivateDirty = entries[3];
157
- } else if (type === 'EGL') {
158
- eglPss = entries[1];
159
- eglPrivateDirty = entries[3];
160
- } else if (type === 'GL') {
161
- glPss = entries[1];
162
- glPrivateDirty = entries[3];
163
- } else if (type === 'TOTAL') {
164
- totalPss = entries[1];
165
- totalPrivateDirty = entries[3];
166
- }
184
+ parseMeminfoForApiBelow19(entries, valDict);
167
185
  }
168
186
  }
169
187
 
170
- if (totalPrivateDirty && totalPrivateDirty !== 'nodex') {
171
- let headers = _lodash.default.clone(MEMORY_KEYS);
188
+ if (valDict.totalPrivateDirty && valDict.totalPrivateDirty !== 'nodex') {
189
+ const headers = _lodash.default.clone(MEMORY_KEYS);
172
190
 
173
- let data = [totalPrivateDirty, nativePrivateDirty, dalvikPrivateDirty, eglPrivateDirty, glPrivateDirty, totalPss, nativePss, dalvikPss, eglPss, glPss, nativeHeapAllocatedSize, nativeHeapSize];
174
- return [headers, data];
175
- } else {
176
- throw new Error(`Unable to parse memory data: '${data}'`);
191
+ const values = headers.map(header => valDict[header]);
192
+ return [headers, values];
177
193
  }
194
+
195
+ throw new Error(`Unable to parse memory data: '${data}'`);
178
196
  });
179
197
  };
180
198
 
181
- helpers.getNetworkTrafficInfo = async function getNetworkTrafficInfo(dataReadTimeout = 2) {
182
- return await (0, _asyncbox.retryInterval)(dataReadTimeout, RETRY_PAUSE, async () => {
199
+ helpers.getNetworkTrafficInfo = async function getNetworkTrafficInfo(retries = 2) {
200
+ return await (0, _asyncbox.retryInterval)(retries, RETRY_PAUSE_MS, async () => {
183
201
  let returnValue = [];
184
202
  let bucketDuration, bucketStart, activeTime, rxBytes, rxPackets, txBytes, txPackets, operations;
185
203
  let cmd = ['dumpsys', 'netstats'];
@@ -311,4 +329,4 @@ var _default = extensions;
311
329
  exports.default = _default;require('source-map-support').install();
312
330
 
313
331
 
314
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/performance.js"],"names":["commands","helpers","extensions","NETWORK_KEYS","CPU_KEYS","BATTERY_KEYS","MEMORY_KEYS","SUPPORTED_PERFORMANCE_DATA_TYPES","cpuinfo","memoryinfo","batteryinfo","networkinfo","RETRY_PAUSE","getPerformanceDataTypes","_","keys","getPerformanceData","packageName","dataType","dataReadTimeout","data","getBatteryInfo","getCPUInfo","getMemoryInfo","getNetworkTrafficInfo","Error","output","adb","shell","e","stderr","log","info","usagesPattern","RegExp","escapeRegExp","match","exec","debug","cmd","power","parseInt","split","trim","Number","isNaN","clone","toString","totalPrivateDirty","totalPss","nativePrivateDirty","nativePss","nativeHeapSize","nativeHeapAllocatedSize","dalvikPrivateDirty","dalvikPss","eglPrivateDirty","eglPss","glPrivateDirty","glPss","apilevel","getApiLevel","line","entries","filter","Boolean","type","subType","length","headers","returnValue","bucketDuration","bucketStart","activeTime","rxBytes","rxPackets","txBytes","txPackets","operations","index","fromXtstats","indexOf","start","delimiter","end","pendingBytes","substring","arrayList","j","k","returnIndex","i","isEqual","isUndefined","Object","assign"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport { retryInterval } from 'asyncbox';\nimport log from '../logger';\n\n\nlet commands = {}, helpers = {}, extensions = {};\n\nconst NETWORK_KEYS = [['bucketStart', 'activeTime', 'rxBytes', 'rxPackets', 'txBytes', 'txPackets', 'operations', 'bucketDuration'], ['st', 'activeTime', 'rb', 'rp', 'tb', 'tp', 'op', 'bucketDuration']];\nconst CPU_KEYS = ['user', 'kernel'];\nconst BATTERY_KEYS = ['power'];\nconst MEMORY_KEYS = ['totalPrivateDirty', 'nativePrivateDirty', 'dalvikPrivateDirty', 'eglPrivateDirty', 'glPrivateDirty', 'totalPss', 'nativePss', 'dalvikPss', 'eglPss', 'glPss', 'nativeHeapAllocatedSize', 'nativeHeapSize'];\n\nconst SUPPORTED_PERFORMANCE_DATA_TYPES = {\n  cpuinfo: 'the amount of cpu by user and kernel process - cpu information for applications on real devices and simulators',\n  memoryinfo: 'the amount of memory used by the process - memory information for applications on real devices and simulators',\n  batteryinfo: 'the remaining battery power - battery power information for applications on real devices and simulators',\n  networkinfo: 'the network statistics - network rx/tx information for applications on real devices and simulators'\n};\n\nconst RETRY_PAUSE = 1000;\n\n//\n// returns the information type of the system state which is supported to read as like cpu, memory, network traffic, and battery.\n// output - array like below\n//[cpuinfo, batteryinfo, networkinfo, memoryinfo]\n//\ncommands.getPerformanceDataTypes = function getPerformanceDataTypes () {\n  return _.keys(SUPPORTED_PERFORMANCE_DATA_TYPES);\n};\n\n// returns the information type of the system state which is supported to read as like cpu, memory, network traffic, and battery.\n//input - (packageName) the package name of the application\n//        (dataType) the type of system state which wants to read. It should be one of the keys of the SUPPORTED_PERFORMANCE_DATA_TYPES\n//        (dataReadTimeout) the number of attempts to read\n// output - table of the performance data, The first line of the table represents the type of data. The remaining lines represent the values of the data.\n//\n// in case of battery info : [[power], [23]]\n// in case of memory info :  [[totalPrivateDirty, nativePrivateDirty, dalvikPrivateDirty, eglPrivateDirty, glPrivateDirty, totalPss, nativePss, dalvikPss, eglPss, glPss, nativeHeapAllocatedSize, nativeHeapSize], [18360, 8296, 6132, null, null, 42588, 8406, 7024, null, null, 26519, 10344]]\n// in case of network info : [[bucketStart, activeTime, rxBytes, rxPackets, txBytes, txPackets, operations, bucketDuration,], [1478091600000, null, 1099075, 610947, 928, 114362, 769, 0, 3600000], [1478095200000, null, 1306300, 405997, 509, 46359, 370, 0, 3600000]]\n// in case of network info : [[st, activeTime, rb, rp, tb, tp, op, bucketDuration], [1478088000, null, null, 32115296, 34291, 2956805, 25705, 0, 3600], [1478091600, null, null, 2714683, 11821, 1420564, 12650, 0, 3600], [1478095200, null, null, 10079213, 19962, 2487705, 20015, 0, 3600], [1478098800, null, null, 4444433, 10227, 1430356, 10493, 0, 3600]]\n// in case of cpu info : [[user, kernel], [0.9, 1.3]]\n//\ncommands.getPerformanceData = async function getPerformanceData (packageName, dataType, dataReadTimeout = 2) {\n  let data;\n  switch (dataType) {\n    case 'batteryinfo':\n      data = await this.getBatteryInfo(dataReadTimeout);\n      break;\n    case 'cpuinfo':\n      data = await this.getCPUInfo(packageName, dataReadTimeout);\n      break;\n    case 'memoryinfo':\n      data = await this.getMemoryInfo(packageName, dataReadTimeout);\n      break;\n    case 'networkinfo':\n      data = await this.getNetworkTrafficInfo(dataReadTimeout);\n      break;\n    default:\n      throw new Error(`No performance data of type '${dataType}' found.`);\n  }\n  return data;\n};\n\nhelpers.getCPUInfo = async function getCPUInfo (packageName, dataReadTimeout = 2) {\n  // TODO: figure out why this is\n  // sometimes, the function of 'adb.shell' fails. when I tested this function on the target of 'Galaxy Note5',\n  // adb.shell(dumpsys cpuinfo) returns cpu datas for other application packages, but I can't find the data for packageName.\n  // It usually fails 30 times and success for the next time,\n  // Since then, he has continued to succeed.\n  return await retryInterval(dataReadTimeout, RETRY_PAUSE, async () => {\n    let output;\n    try {\n      output = await this.adb.shell(['dumpsys', 'cpuinfo']);\n    } catch (e) {\n      if (e.stderr) {\n        log.info(e.stderr);\n      }\n      throw e;\n    }\n    // `output` will be something like\n    //    +0% 2209/io.appium.android.apis: 0.1% user + 0.2% kernel / faults: 70 minor\n    const usagesPattern =\n      new RegExp(`^.+\\\\/${_.escapeRegExp(packageName)}:\\\\D+([\\\\d.]+)%\\\\s+user\\\\s+\\\\+\\\\s+([\\\\d.]+)%\\\\s+kernel`, 'm');\n    const match = usagesPattern.exec(output);\n    if (!match) {\n      log.debug(output);\n      throw new Error(`Unable to parse cpu usage data for '${packageName}'. Check the server log for more details`);\n    }\n    return [CPU_KEYS, [match[1], match[2]]];\n  });\n};\n\nhelpers.getBatteryInfo = async function getBatteryInfo (dataReadTimeout = 2) {\n  return await retryInterval(dataReadTimeout, RETRY_PAUSE, async () => {\n    let cmd = ['dumpsys', 'battery', '|', 'grep', 'level'];\n    let data = await this.adb.shell(cmd);\n    if (!data) throw new Error('No data from dumpsys'); //eslint-disable-line curly\n\n    let power = parseInt((data.split(':')[1] || '').trim(), 10);\n\n    if (!Number.isNaN(power)) {\n      return [_.clone(BATTERY_KEYS), [power.toString()]];\n    } else {\n      throw new Error(`Unable to parse battery data: '${data}'`);\n    }\n  });\n\n};\n\nhelpers.getMemoryInfo = async function getMemoryInfo (packageName, dataReadTimeout = 2) {\n  return await retryInterval(dataReadTimeout, RETRY_PAUSE, async () => {\n    let cmd = ['dumpsys', 'meminfo', `'${packageName}'`, '|', 'grep', '-E', \"'Native|Dalvik|EGL|GL|TOTAL'\"];\n    let data = await this.adb.shell(cmd);\n    if (!data) throw new Error('No data from dumpsys'); //eslint-disable-line curly\n\n    let totalPrivateDirty, totalPss,\n        nativePrivateDirty, nativePss, nativeHeapSize, nativeHeapAllocatedSize,\n        dalvikPrivateDirty, dalvikPss,\n        eglPrivateDirty, eglPss,\n        glPrivateDirty, glPss;\n    let apilevel = await this.adb.getApiLevel();\n    for (let line of data.split('\\n')) {\n      let entries = line.trim().split(' ').filter(Boolean);\n      // entries will have the values\n      //   ['<System Type>', '<Memory Type>', <pss total>, <private dirty>, <private clean>, <swapPss dirty>, <heap size>, <heap alloc>, <heap free>]\n      // except 'TOTAL', which skips the second type name\n      //\n      // and on API level 18 and below\n      //   ['<System Type', '<pps>', '<shared dirty>', '<private dirty>', '<heap size>', '<heap alloc>', '<heap free>']\n\n      if (apilevel > 18) {\n        let type = entries[0];\n        let subType = entries[1];\n        if (type === 'Native' && subType === 'Heap') {\n          // native heap\n          nativePss = entries[2];\n          nativePrivateDirty = entries[3];\n          nativeHeapSize = entries[6];\n          nativeHeapAllocatedSize = entries[7];\n        } else if (type === 'Dalvik' && subType === 'Heap') {\n          // dalvik heap\n          dalvikPss = entries[2];\n          dalvikPrivateDirty = entries[3];\n        } else if (type === 'EGL' && subType === 'mtrack') {\n          // egl\n          eglPss = entries[2];\n          eglPrivateDirty = entries[3];\n        } else if (type === 'GL' && subType === 'mtrack') {\n          // gl\n          glPss = entries[2];\n          glPrivateDirty = entries[3];\n        } else if (type === 'TOTAL' && entries.length === 8) {\n          // there are two totals, and we only want the full listing, which has 8 entries\n          totalPss = entries[1];\n          totalPrivateDirty = entries[2];\n        }\n      } else {\n        let type = entries[0];\n        if (type === 'Native') {\n          nativePss = entries[1];\n          nativePrivateDirty = entries[3];\n          nativeHeapSize = entries[4];\n          nativeHeapAllocatedSize = entries[5];\n        } else if (type === 'Dalvik') {\n          dalvikPss = entries[1];\n          dalvikPrivateDirty = entries[3];\n        } else if (type === 'EGL') {\n          eglPss = entries[1];\n          eglPrivateDirty = entries[3];\n        } else if (type === 'GL') {\n          glPss = entries[1];\n          glPrivateDirty = entries[3];\n        } else if (type === 'TOTAL') {\n          totalPss = entries[1];\n          totalPrivateDirty = entries[3];\n        }\n      }\n    }\n\n    if (totalPrivateDirty && totalPrivateDirty !== 'nodex') {\n      let headers = _.clone(MEMORY_KEYS);\n      let data = [totalPrivateDirty, nativePrivateDirty, dalvikPrivateDirty, eglPrivateDirty, glPrivateDirty, totalPss, nativePss, dalvikPss, eglPss, glPss, nativeHeapAllocatedSize, nativeHeapSize];\n      return [headers, data];\n    } else {\n      throw new Error(`Unable to parse memory data: '${data}'`);\n    }\n  });\n};\n\nhelpers.getNetworkTrafficInfo = async function getNetworkTrafficInfo (dataReadTimeout = 2) {\n  return await retryInterval(dataReadTimeout, RETRY_PAUSE, async () => {\n    let returnValue = [];\n    let bucketDuration, bucketStart, activeTime, rxBytes, rxPackets, txBytes, txPackets, operations;\n\n    let cmd = ['dumpsys', 'netstats'];\n    let data = await this.adb.shell(cmd);\n    if (!data) throw new Error('No data from dumpsys'); //eslint-disable-line curly\n\n    // In case of network traffic information, it is different for the return data between emulator and real device.\n    // the return data of emulator\n    //   Xt stats:\n    //   Pending bytes: 39250\n    //   History since boot:\n    //   ident=[[type=WIFI, subType=COMBINED, networkId=\"WiredSSID\"]] uid=-1 set=ALL tag=0x0\n    //   NetworkStatsHistory: bucketDuration=3600000\n    //   bucketStart=1478098800000 activeTime=31824 rxBytes=21502 rxPackets=78 txBytes=17748 txPackets=90 operations=0\n    //\n    // 7.1\n    //   Xt stats:\n    //   Pending bytes: 481487\n    //   History since boot:\n    //   ident=[{type=MOBILE, subType=COMBINED, subscriberId=310260..., metered=true}] uid=-1 set=ALL tag=0x0\n    //     NetworkStatsHistory: bucketDuration=3600\n    //       st=1483984800 rb=0 rp=0 tb=12031 tp=184 op=0\n    //       st=1483988400 rb=0 rp=0 tb=38476 tp=587 op=0\n    //       st=1483999200 rb=315616 rp=400 tb=94800 tp=362 op=0\n    //       st=1484002800 rb=15826 rp=20 tb=4738 tp=16 op=0\n    //\n    // the return data of real device\n    //   Xt stats:\n    //   Pending bytes: 0\n    //   History since boot:\n    //   ident=[{type=MOBILE, subType=COMBINED, subscriberId=450050...}] uid=-1 set=ALL tag=0x0\n    //   NetworkStatsHistory: bucketDuration=3600\n    //   st=1478088000 rb=32115296 rp=34291 tb=2956805 tp=25705 op=0\n    //   st=1478091600 rb=2714683 rp=11821 tb=1420564 tp=12650 op=0\n    //   st=1478095200 rb=10079213 rp=19962 tb=2487705 tp=20015 op=0\n    //   st=1478098800 rb=4444433 rp=10227 tb=1430356 tp=10493 op=0\n    let index = 0;\n    let fromXtstats = data.indexOf('Xt stats:');\n\n    let start = data.indexOf('Pending bytes:', fromXtstats);\n    let delimiter = data.indexOf(':', start + 1);\n    let end = data.indexOf('\\n', delimiter + 1);\n    let pendingBytes = data.substring(delimiter + 1, end).trim();\n\n    if (end > delimiter) {\n      start = data.indexOf('bucketDuration', end + 1);\n      delimiter = data.indexOf('=', start + 1);\n      end = data.indexOf('\\n', delimiter + 1);\n      bucketDuration = data.substring(delimiter + 1, end).trim();\n    }\n\n    if (start >= 0) {\n      data = data.substring(end + 1, data.length);\n      let arrayList = data.split('\\n');\n\n      if (arrayList.length > 0) {\n        start = -1;\n\n        for (let j = 0; j < NETWORK_KEYS.length; ++j) {\n          start = arrayList[0].indexOf(NETWORK_KEYS[j][0]);\n\n          if (start >= 0) {\n            index = j;\n            returnValue[0] = [];\n\n            for (let k = 0; k < NETWORK_KEYS[j].length; ++k) {\n              returnValue[0][k] = NETWORK_KEYS[j][k];\n            }\n            break;\n          }\n        }\n\n        let returnIndex = 1;\n        for (let i = 0; i < arrayList.length; i++) {\n          data = arrayList[i];\n          start = data.indexOf(NETWORK_KEYS[index][0]);\n\n          if (start >= 0) {\n            delimiter = data.indexOf('=', start + 1);\n            end = data.indexOf(' ', delimiter + 1);\n            bucketStart = data.substring(delimiter + 1, end).trim();\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][1], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.indexOf(' ', delimiter + 1);\n                activeTime = data.substring(delimiter + 1, end).trim();\n              }\n            }\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][2], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.indexOf(' ', delimiter + 1);\n                rxBytes = data.substring(delimiter + 1, end).trim();\n              }\n            }\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][3], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.indexOf(' ', delimiter + 1);\n                rxPackets = data.substring(delimiter + 1, end).trim();\n              }\n            }\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][4], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.indexOf(' ', delimiter + 1);\n                txBytes = data.substring(delimiter + 1, end).trim();\n              }\n            }\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][5], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.indexOf(' ', delimiter + 1);\n                txPackets = data.substring(delimiter + 1, end).trim();\n              }\n            }\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][6], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.length;\n                operations = data.substring(delimiter + 1, end).trim();\n\n              }\n            }\n            returnValue[returnIndex++] = [bucketStart, activeTime, rxBytes, rxPackets, txBytes, txPackets, operations, bucketDuration];\n          }\n        }\n      }\n    }\n\n    if (!_.isEqual(pendingBytes, '') && !_.isUndefined(pendingBytes) && !_.isEqual(pendingBytes, 'nodex')) {\n      return returnValue;\n    } else {\n      throw new Error(`Unable to parse network traffic data: '${data}'`);\n    }\n  });\n};\n\nObject.assign(extensions, commands, helpers);\nexport {\n  commands, helpers, SUPPORTED_PERFORMANCE_DATA_TYPES, CPU_KEYS, MEMORY_KEYS,\n  BATTERY_KEYS, NETWORK_KEYS,\n};\nexport default extensions;\n"],"file":"lib/commands/performance.js","sourceRoot":"../../.."}
332
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/performance.js"],"names":["commands","helpers","extensions","NETWORK_KEYS","CPU_KEYS","BATTERY_KEYS","MEMORY_KEYS","SUPPORTED_PERFORMANCE_DATA_TYPES","Object","freeze","cpuinfo","memoryinfo","batteryinfo","networkinfo","MEMINFO_TITLES","NATIVE","DALVIK","EGL","GL","MTRACK","TOTAL","HEAP","RETRY_PAUSE_MS","parseMeminfoForApi19To29","entries","valDict","type","subType","nativePss","nativePrivateDirty","nativeHeapSize","nativeHeapAllocatedSize","dalvikPss","dalvikPrivateDirty","eglPss","eglPrivateDirty","glPss","glPrivateDirty","length","totalPss","totalPrivateDirty","parseMeminfoForApiBelow19","parseMeminfoForApiAbove29","nativeRss","dalvikRss","totalRss","getPerformanceDataTypes","_","keys","getPerformanceData","packageName","dataType","retries","toLower","getBatteryInfo","getCPUInfo","getMemoryInfo","getNetworkTrafficInfo","Error","JSON","stringify","output","adb","shell","e","stderr","log","info","usagesPattern","RegExp","escapeRegExp","match","exec","debug","cmd","data","power","parseInt","split","trim","Number","isNaN","clone","toString","apiLevel","getApiLevel","line","filter","Boolean","headers","values","map","header","returnValue","bucketDuration","bucketStart","activeTime","rxBytes","rxPackets","txBytes","txPackets","operations","index","fromXtstats","indexOf","start","delimiter","end","pendingBytes","substring","arrayList","j","k","returnIndex","i","isEqual","isUndefined","assign"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport { retryInterval } from 'asyncbox';\nimport log from '../logger';\n\nconst commands = {}, helpers = {}, extensions = {};\n\nconst NETWORK_KEYS = [\n  ['bucketStart', 'activeTime', 'rxBytes', 'rxPackets', 'txBytes', 'txPackets', 'operations', 'bucketDuration'],\n  ['st', 'activeTime', 'rb', 'rp', 'tb', 'tp', 'op', 'bucketDuration']\n];\nconst CPU_KEYS = ['user', 'kernel'];\nconst BATTERY_KEYS = ['power'];\nconst MEMORY_KEYS = [\n  'totalPrivateDirty', 'nativePrivateDirty', 'dalvikPrivateDirty',\n  'eglPrivateDirty', 'glPrivateDirty',\n  'totalPss', 'nativePss', 'dalvikPss', 'eglPss', 'glPss',\n  'nativeHeapAllocatedSize', 'nativeHeapSize',\n  'nativeRss', 'dalvikRss', 'totalRss'\n];\nconst SUPPORTED_PERFORMANCE_DATA_TYPES = Object.freeze({\n  cpuinfo: 'the amount of cpu by user and kernel process - cpu information for applications on real devices and simulators',\n  memoryinfo: 'the amount of memory used by the process - memory information for applications on real devices and simulators',\n  batteryinfo: 'the remaining battery power - battery power information for applications on real devices and simulators',\n  networkinfo: 'the network statistics - network rx/tx information for applications on real devices and simulators'\n});\nconst MEMINFO_TITLES = Object.freeze({\n  NATIVE: 'Native',\n  DALVIK: 'Dalvik',\n  EGL: 'EGL',\n  GL: 'GL',\n  MTRACK: 'mtrack',\n  TOTAL: 'TOTAL',\n  HEAP: 'Heap'\n});\nconst RETRY_PAUSE_MS = 1000;\n\n/**\n * API level between 18 and 30\n * ['<System Type>', '<Memory Type>', <pss total>, <private dirty>, <private clean>, <swapPss dirty>, <heap size>, <heap alloc>, <heap free>]\n * except 'TOTAL', which skips the second type name\n * !!! valDict gets mutated\n */\nfunction parseMeminfoForApi19To29 (entries, valDict) {\n  const [type, subType] = entries;\n  if (type === MEMINFO_TITLES.NATIVE && subType === MEMINFO_TITLES.HEAP) {\n    [,, valDict.nativePss, valDict.nativePrivateDirty,,, valDict.nativeHeapSize, valDict.nativeHeapAllocatedSize] = entries;\n  } else if (type === MEMINFO_TITLES.DALVIK && subType === MEMINFO_TITLES.HEAP) {\n    [,, valDict.dalvikPss, valDict.dalvikPrivateDirty] = entries;\n  } else if (type === MEMINFO_TITLES.EGL && subType === MEMINFO_TITLES.MTRACK) {\n    [,, valDict.eglPss, valDict.eglPrivateDirty] = entries;\n  } else if (type === MEMINFO_TITLES.GL && subType === MEMINFO_TITLES.MTRACK) {\n    [,, valDict.glPss, valDict.glPrivateDirty] = entries;\n  } else if (type === MEMINFO_TITLES.TOTAL && entries.length === 8) {\n    // there are two totals, and we only want the full listing, which has 8 entries\n    [, valDict.totalPss, valDict.totalPrivateDirty] = entries;\n  }\n}\n\n/**\n * ['<System Type', '<pps>', '<shared dirty>', '<private dirty>', '<heap size>', '<heap alloc>', '<heap free>']\n * !!! valDict gets mutated\n */\nfunction parseMeminfoForApiBelow19 (entries, valDict) {\n  const type = entries[0];\n  if (type === MEMINFO_TITLES.NATIVE) {\n    [, valDict.nativePss,, valDict.nativePrivateDirty, valDict.nativeHeapSize, valDict.nativeHeapAllocatedSize] = entries;\n  } else if (type === MEMINFO_TITLES.DALVIK) {\n    [, valDict.dalvikPss,, valDict.dalvikPrivateDirty] = entries;\n  } else if (type === MEMINFO_TITLES.EGL) {\n    [, valDict.eglPss,, valDict.eglPrivateDirty] = entries;\n  } else if (type === MEMINFO_TITLES.GL) {\n    [, valDict.glPss,, valDict.glPrivateDirty] = entries;\n  } else if (type === MEMINFO_TITLES.TOTAL) {\n    [, valDict.totalPss,, valDict.totalPrivateDirty] = entries;\n  }\n}\n\n/**\n * API level 30 and above\n * ['<System Type>', '<Memory Type>', <pss total>, <private dirty>, <private clean>, <swapPss dirty>, <rss total>, <heap size>, <heap alloc>, <heap free>]\n * !!! valDict gets mutated\n */\nfunction parseMeminfoForApiAbove29 (entries, valDict) {\n  const [type, subType] = entries;\n  if (type === MEMINFO_TITLES.NATIVE && subType === MEMINFO_TITLES.HEAP) {\n    [,, valDict.nativePss, valDict.nativePrivateDirty,,, valDict.nativeRss, valDict.nativeHeapSize, valDict.nativeHeapAllocatedSize] = entries;\n  } else if (type === MEMINFO_TITLES.DALVIK && subType === MEMINFO_TITLES.HEAP) {\n    [,, valDict.dalvikPss, valDict.dalvikPrivateDirty,,, valDict.dalvikRss] = entries;\n  } else if (type === MEMINFO_TITLES.EGL && subType === MEMINFO_TITLES.MTRACK) {\n    [,, valDict.eglPss, valDict.eglPrivateDirty] = entries;\n  } else if (type === MEMINFO_TITLES.GL && subType === MEMINFO_TITLES.MTRACK) {\n    [,, valDict.glPss, valDict.glPrivateDirty] = entries;\n  } else if (type === MEMINFO_TITLES.TOTAL && entries.length === 9) {\n    // has 9 entries\n    [, valDict.totalPss, valDict.totalPrivateDirty,,, valDict.totalRss] = entries;\n  }\n}\n\n//\n// returns the information type of the system state which is supported to read as like cpu, memory, network traffic, and battery.\n// output - array like below\n// [cpuinfo, batteryinfo, networkinfo, memoryinfo]\n//\ncommands.getPerformanceDataTypes = function getPerformanceDataTypes () {\n  return _.keys(SUPPORTED_PERFORMANCE_DATA_TYPES);\n};\n\n/**\n * @returns The information type of the system state which is supported to read as like cpu, memory, network traffic, and battery.\n * input - (packageName) the package name of the application\n *        (dataType) the type of system state which wants to read. It should be one of the keys of the SUPPORTED_PERFORMANCE_DATA_TYPES\n *        (dataReadTimeout) the number of attempts to read\n * output - table of the performance data, The first line of the table represents the type of data. The remaining lines represent the values of the data.\n *\n * in case of battery info : [[power], [23]]\n * in case of memory info :  [[totalPrivateDirty, nativePrivateDirty, dalvikPrivateDirty, eglPrivateDirty, glPrivateDirty, totalPss,\n *   nativePss, dalvikPss, eglPss, glPss, nativeHeapAllocatedSize, nativeHeapSize], [18360, 8296, 6132, null, null, 42588, 8406, 7024, null, null, 26519, 10344]]\n * in case of network info : [[bucketStart, activeTime, rxBytes, rxPackets, txBytes, txPackets, operations, bucketDuration,],\n *   [1478091600000, null, 1099075, 610947, 928, 114362, 769, 0, 3600000], [1478095200000, null, 1306300, 405997, 509, 46359, 370, 0, 3600000]]\n * in case of network info : [[st, activeTime, rb, rp, tb, tp, op, bucketDuration], [1478088000, null, null, 32115296, 34291, 2956805, 25705, 0, 3600],\n *   [1478091600, null, null, 2714683, 11821, 1420564, 12650, 0, 3600], [1478095200, null, null, 10079213, 19962, 2487705, 20015, 0, 3600],\n *   [1478098800, null, null, 4444433, 10227, 1430356, 10493, 0, 3600]]\n * in case of cpu info : [[user, kernel], [0.9, 1.3]]\n */\ncommands.getPerformanceData = async function getPerformanceData (packageName, dataType, retries = 2) {\n  switch (_.toLower(dataType)) {\n    case 'batteryinfo':\n      return await this.getBatteryInfo(retries);\n    case 'cpuinfo':\n      return await this.getCPUInfo(packageName, retries);\n    case 'memoryinfo':\n      return await this.getMemoryInfo(packageName, retries);\n    case 'networkinfo':\n      return await this.getNetworkTrafficInfo(retries);\n    default:\n      throw new Error(`No performance data of type '${dataType}' found. ` +\n        `Only the following values are supported: ${JSON.stringify(SUPPORTED_PERFORMANCE_DATA_TYPES, ' ', 2)}`);\n  }\n};\n\nhelpers.getCPUInfo = async function getCPUInfo (packageName, retries = 2) {\n  // TODO: figure out why this is\n  // sometimes, the function of 'adb.shell' fails. when I tested this function on the target of 'Galaxy Note5',\n  // adb.shell(dumpsys cpuinfo) returns cpu datas for other application packages, but I can't find the data for packageName.\n  // It usually fails 30 times and success for the next time,\n  // Since then, he has continued to succeed.\n  return await retryInterval(retries, RETRY_PAUSE_MS, async () => {\n    let output;\n    try {\n      output = await this.adb.shell(['dumpsys', 'cpuinfo']);\n    } catch (e) {\n      if (e.stderr) {\n        log.info(e.stderr);\n      }\n      throw e;\n    }\n    // `output` will be something like\n    //    +0% 2209/io.appium.android.apis: 0.1% user + 0.2% kernel / faults: 70 minor\n    const usagesPattern =\n      new RegExp(`^.+\\\\/${_.escapeRegExp(packageName)}:\\\\D+([\\\\d.]+)%\\\\s+user\\\\s+\\\\+\\\\s+([\\\\d.]+)%\\\\s+kernel`, 'm');\n    const match = usagesPattern.exec(output);\n    if (!match) {\n      log.debug(output);\n      throw new Error(`Unable to parse cpu usage data for '${packageName}'. Check the server log for more details`);\n    }\n    return [CPU_KEYS, [match[1], match[2]]];\n  });\n};\n\nhelpers.getBatteryInfo = async function getBatteryInfo (retries = 2) {\n  return await retryInterval(retries, RETRY_PAUSE_MS, async () => {\n    let cmd = ['dumpsys', 'battery', '|', 'grep', 'level'];\n    let data = await this.adb.shell(cmd);\n    if (!data) throw new Error('No data from dumpsys'); //eslint-disable-line curly\n\n    let power = parseInt((data.split(':')[1] || '').trim(), 10);\n\n    if (!Number.isNaN(power)) {\n      return [_.clone(BATTERY_KEYS), [power.toString()]];\n    } else {\n      throw new Error(`Unable to parse battery data: '${data}'`);\n    }\n  });\n};\n\nhelpers.getMemoryInfo = async function getMemoryInfo (packageName, retries = 2) {\n  return await retryInterval(retries, RETRY_PAUSE_MS, async () => {\n    const cmd = [\n      'dumpsys', 'meminfo', `'${packageName}'`,\n      '|', 'grep', '-E',\n      `'${MEMINFO_TITLES.NATIVE}|${MEMINFO_TITLES.DALVIK}|${MEMINFO_TITLES.EGL}` +\n      `|${MEMINFO_TITLES.GL}|${MEMINFO_TITLES.TOTAL}'`\n    ];\n    const data = await this.adb.shell(cmd);\n    if (!data) {\n      throw new Error('No data from dumpsys');\n    }\n    const valDict = {totalPrivateDirty: ''};\n    const apiLevel = await this.adb.getApiLevel();\n    for (const line of data.split('\\n')) {\n      const entries = line.trim().split(/\\s+/).filter(Boolean);\n      if (apiLevel >= 30) {\n        parseMeminfoForApiAbove29(entries, valDict);\n      } else if (apiLevel > 18 && apiLevel < 30) {\n        parseMeminfoForApi19To29(entries, valDict);\n      } else {\n        parseMeminfoForApiBelow19(entries, valDict);\n      }\n    }\n    if (valDict.totalPrivateDirty && valDict.totalPrivateDirty !== 'nodex') {\n      const headers = _.clone(MEMORY_KEYS);\n      const values = headers.map((header) => valDict[header]);\n      return [headers, values];\n    }\n\n    throw new Error(`Unable to parse memory data: '${data}'`);\n  });\n};\n\nhelpers.getNetworkTrafficInfo = async function getNetworkTrafficInfo (retries = 2) {\n  return await retryInterval(retries, RETRY_PAUSE_MS, async () => {\n    let returnValue = [];\n    let bucketDuration, bucketStart, activeTime, rxBytes, rxPackets, txBytes, txPackets, operations;\n\n    let cmd = ['dumpsys', 'netstats'];\n    let data = await this.adb.shell(cmd);\n    if (!data) throw new Error('No data from dumpsys'); //eslint-disable-line curly\n\n    // In case of network traffic information, it is different for the return data between emulator and real device.\n    // the return data of emulator\n    //   Xt stats:\n    //   Pending bytes: 39250\n    //   History since boot:\n    //   ident=[[type=WIFI, subType=COMBINED, networkId=\"WiredSSID\"]] uid=-1 set=ALL tag=0x0\n    //   NetworkStatsHistory: bucketDuration=3600000\n    //   bucketStart=1478098800000 activeTime=31824 rxBytes=21502 rxPackets=78 txBytes=17748 txPackets=90 operations=0\n    //\n    // 7.1\n    //   Xt stats:\n    //   Pending bytes: 481487\n    //   History since boot:\n    //   ident=[{type=MOBILE, subType=COMBINED, subscriberId=310260..., metered=true}] uid=-1 set=ALL tag=0x0\n    //     NetworkStatsHistory: bucketDuration=3600\n    //       st=1483984800 rb=0 rp=0 tb=12031 tp=184 op=0\n    //       st=1483988400 rb=0 rp=0 tb=38476 tp=587 op=0\n    //       st=1483999200 rb=315616 rp=400 tb=94800 tp=362 op=0\n    //       st=1484002800 rb=15826 rp=20 tb=4738 tp=16 op=0\n    //\n    // the return data of real device\n    //   Xt stats:\n    //   Pending bytes: 0\n    //   History since boot:\n    //   ident=[{type=MOBILE, subType=COMBINED, subscriberId=450050...}] uid=-1 set=ALL tag=0x0\n    //   NetworkStatsHistory: bucketDuration=3600\n    //   st=1478088000 rb=32115296 rp=34291 tb=2956805 tp=25705 op=0\n    //   st=1478091600 rb=2714683 rp=11821 tb=1420564 tp=12650 op=0\n    //   st=1478095200 rb=10079213 rp=19962 tb=2487705 tp=20015 op=0\n    //   st=1478098800 rb=4444433 rp=10227 tb=1430356 tp=10493 op=0\n    let index = 0;\n    let fromXtstats = data.indexOf('Xt stats:');\n\n    let start = data.indexOf('Pending bytes:', fromXtstats);\n    let delimiter = data.indexOf(':', start + 1);\n    let end = data.indexOf('\\n', delimiter + 1);\n    let pendingBytes = data.substring(delimiter + 1, end).trim();\n\n    if (end > delimiter) {\n      start = data.indexOf('bucketDuration', end + 1);\n      delimiter = data.indexOf('=', start + 1);\n      end = data.indexOf('\\n', delimiter + 1);\n      bucketDuration = data.substring(delimiter + 1, end).trim();\n    }\n\n    if (start >= 0) {\n      data = data.substring(end + 1, data.length);\n      let arrayList = data.split('\\n');\n\n      if (arrayList.length > 0) {\n        start = -1;\n\n        for (let j = 0; j < NETWORK_KEYS.length; ++j) {\n          start = arrayList[0].indexOf(NETWORK_KEYS[j][0]);\n\n          if (start >= 0) {\n            index = j;\n            returnValue[0] = [];\n\n            for (let k = 0; k < NETWORK_KEYS[j].length; ++k) {\n              returnValue[0][k] = NETWORK_KEYS[j][k];\n            }\n            break;\n          }\n        }\n\n        let returnIndex = 1;\n        for (let i = 0; i < arrayList.length; i++) {\n          data = arrayList[i];\n          start = data.indexOf(NETWORK_KEYS[index][0]);\n\n          if (start >= 0) {\n            delimiter = data.indexOf('=', start + 1);\n            end = data.indexOf(' ', delimiter + 1);\n            bucketStart = data.substring(delimiter + 1, end).trim();\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][1], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.indexOf(' ', delimiter + 1);\n                activeTime = data.substring(delimiter + 1, end).trim();\n              }\n            }\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][2], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.indexOf(' ', delimiter + 1);\n                rxBytes = data.substring(delimiter + 1, end).trim();\n              }\n            }\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][3], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.indexOf(' ', delimiter + 1);\n                rxPackets = data.substring(delimiter + 1, end).trim();\n              }\n            }\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][4], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.indexOf(' ', delimiter + 1);\n                txBytes = data.substring(delimiter + 1, end).trim();\n              }\n            }\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][5], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.indexOf(' ', delimiter + 1);\n                txPackets = data.substring(delimiter + 1, end).trim();\n              }\n            }\n\n            if (end > delimiter) {\n              start = data.indexOf(NETWORK_KEYS[index][6], end + 1);\n              if (start >= 0) {\n                delimiter = data.indexOf('=', start + 1);\n                end = data.length;\n                operations = data.substring(delimiter + 1, end).trim();\n\n              }\n            }\n            returnValue[returnIndex++] = [bucketStart, activeTime, rxBytes, rxPackets, txBytes, txPackets, operations, bucketDuration];\n          }\n        }\n      }\n    }\n\n    if (!_.isEqual(pendingBytes, '') && !_.isUndefined(pendingBytes) && !_.isEqual(pendingBytes, 'nodex')) {\n      return returnValue;\n    } else {\n      throw new Error(`Unable to parse network traffic data: '${data}'`);\n    }\n  });\n};\n\nObject.assign(extensions, commands, helpers);\nexport {\n  commands, helpers, SUPPORTED_PERFORMANCE_DATA_TYPES, CPU_KEYS, MEMORY_KEYS,\n  BATTERY_KEYS, NETWORK_KEYS,\n};\nexport default extensions;\n\n"],"file":"lib/commands/performance.js","sourceRoot":"../../.."}
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.helpers = exports.default = exports.commands = void 0;
8
+ exports.default = exports.helpers = exports.commands = void 0;
9
9
 
10
10
  require("source-map-support/register");
11
11
 
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.default = exports.commonCapConstraints = void 0;
6
+ exports.commonCapConstraints = exports.default = void 0;
7
7
 
8
8
  require("source-map-support/register");
9
9
 
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.helpers = exports.default = exports.PIN_UNLOCK_KEY_EVENT = exports.PIN_UNLOCK = exports.PATTERN_UNLOCK = exports.PASSWORD_UNLOCK = exports.FINGERPRINT_UNLOCK = void 0;
8
+ exports.default = exports.helpers = exports.FINGERPRINT_UNLOCK = exports.PATTERN_UNLOCK = exports.PASSWORD_UNLOCK = exports.PIN_UNLOCK_KEY_EVENT = exports.PIN_UNLOCK = void 0;
9
9
 
10
10
  require("source-map-support/register");
11
11
 
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.helpers = exports.default = exports.WEBVIEW_WIN = exports.WEBVIEW_BASE = exports.NATIVE_WIN = exports.KNOWN_CHROME_PACKAGE_NAMES = exports.CHROMIUM_WIN = void 0;
8
+ exports.KNOWN_CHROME_PACKAGE_NAMES = exports.CHROMIUM_WIN = exports.WEBVIEW_BASE = exports.WEBVIEW_WIN = exports.NATIVE_WIN = exports.helpers = exports.default = void 0;
9
9
 
10
10
  require("source-map-support/register");
11
11
 
package/lib/.DS_Store ADDED
Binary file