@appium/base-driver 8.3.1 → 8.4.2
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.
- package/build/lib/basedriver/capabilities.d.ts +80 -0
- package/build/lib/basedriver/capabilities.d.ts.map +1 -0
- package/build/lib/basedriver/capabilities.js +11 -10
- package/build/lib/basedriver/commands/event.d.ts +9 -0
- package/build/lib/basedriver/commands/event.d.ts.map +1 -0
- package/build/lib/basedriver/commands/event.js +21 -21
- package/build/lib/basedriver/commands/find.d.ts +11 -0
- package/build/lib/basedriver/commands/find.d.ts.map +1 -0
- package/build/lib/basedriver/commands/find.js +44 -37
- package/build/lib/basedriver/commands/index.d.ts +8 -0
- package/build/lib/basedriver/commands/index.d.ts.map +1 -0
- package/build/lib/basedriver/commands/index.js +17 -14
- package/build/lib/basedriver/commands/log.d.ts +12 -0
- package/build/lib/basedriver/commands/log.d.ts.map +1 -0
- package/build/lib/basedriver/commands/log.js +24 -26
- package/build/lib/basedriver/commands/session.d.ts +11 -0
- package/build/lib/basedriver/commands/session.d.ts.map +1 -0
- package/build/lib/basedriver/commands/session.js +21 -147
- package/build/lib/basedriver/commands/settings.d.ts +10 -0
- package/build/lib/basedriver/commands/settings.d.ts.map +1 -0
- package/build/lib/basedriver/commands/settings.js +19 -17
- package/build/lib/basedriver/commands/timeout.d.ts +8 -0
- package/build/lib/basedriver/commands/timeout.d.ts.map +1 -0
- package/build/lib/basedriver/commands/timeout.js +118 -137
- package/build/lib/basedriver/core.d.ts +235 -0
- package/build/lib/basedriver/core.d.ts.map +1 -0
- package/build/lib/basedriver/core.js +283 -0
- package/build/lib/basedriver/desired-caps.d.ts +5 -0
- package/build/lib/basedriver/desired-caps.d.ts.map +1 -0
- package/build/lib/basedriver/desired-caps.js +1 -1
- package/build/lib/basedriver/device-settings.d.ts +32 -0
- package/build/lib/basedriver/device-settings.d.ts.map +1 -0
- package/build/lib/basedriver/device-settings.js +19 -11
- package/build/lib/basedriver/driver.d.ts +83 -0
- package/build/lib/basedriver/driver.d.ts.map +1 -0
- package/build/lib/basedriver/driver.js +100 -266
- package/build/lib/basedriver/helpers.d.ts +132 -0
- package/build/lib/basedriver/helpers.d.ts.map +1 -0
- package/build/lib/basedriver/helpers.js +17 -1
- package/build/lib/basedriver/logger.d.ts +3 -0
- package/build/lib/basedriver/logger.d.ts.map +1 -0
- package/build/lib/constants.d.ts +9 -0
- package/build/lib/constants.d.ts.map +1 -0
- package/build/lib/express/crash.d.ts +3 -0
- package/build/lib/express/crash.d.ts.map +1 -0
- package/build/lib/express/express-logging.d.ts +3 -0
- package/build/lib/express/express-logging.d.ts.map +1 -0
- package/build/lib/express/idempotency.d.ts +2 -0
- package/build/lib/express/idempotency.d.ts.map +1 -0
- package/build/lib/express/logger.d.ts +3 -0
- package/build/lib/express/logger.d.ts.map +1 -0
- package/build/lib/express/middleware.d.ts +9 -0
- package/build/lib/express/middleware.d.ts.map +1 -0
- package/build/lib/express/server.d.ts +10 -0
- package/build/lib/express/server.d.ts.map +1 -0
- package/build/lib/express/static.d.ts +6 -0
- package/build/lib/express/static.d.ts.map +1 -0
- package/build/lib/express/websocket.d.ts +64 -0
- package/build/lib/express/websocket.d.ts.map +1 -0
- package/build/lib/express/websocket.js +39 -38
- package/build/lib/helpers/capabilities.d.ts +13 -0
- package/build/lib/helpers/capabilities.d.ts.map +1 -0
- package/build/lib/helpers/capabilities.js +41 -1
- package/build/lib/index.d.ts +183 -0
- package/build/lib/index.d.ts.map +1 -0
- package/build/lib/index.js +40 -20
- package/build/lib/jsonwp-proxy/protocol-converter.d.ts +48 -0
- package/build/lib/jsonwp-proxy/protocol-converter.d.ts.map +1 -0
- package/build/lib/jsonwp-proxy/proxy.d.ts +41 -0
- package/build/lib/jsonwp-proxy/proxy.d.ts.map +1 -0
- package/build/lib/jsonwp-proxy/proxy.js +24 -6
- package/build/lib/jsonwp-status/status.d.ts +159 -0
- package/build/lib/jsonwp-status/status.d.ts.map +1 -0
- package/build/lib/protocol/errors.d.ts +310 -0
- package/build/lib/protocol/errors.d.ts.map +1 -0
- package/build/lib/protocol/errors.js +81 -2
- package/build/lib/protocol/helpers.d.ts +22 -0
- package/build/lib/protocol/helpers.d.ts.map +1 -0
- package/build/lib/protocol/index.d.ts +16 -0
- package/build/lib/protocol/index.d.ts.map +1 -0
- package/build/lib/protocol/index.js +7 -7
- package/build/lib/protocol/protocol.d.ts +11 -0
- package/build/lib/protocol/protocol.d.ts.map +1 -0
- package/build/lib/protocol/protocol.js +2 -6
- package/build/lib/protocol/routes.d.ts +6 -0
- package/build/lib/protocol/routes.d.ts.map +1 -0
- package/build/lib/protocol/routes.js +17 -1
- package/build/lib/protocol/validators.d.ts +8 -0
- package/build/lib/protocol/validators.d.ts.map +1 -0
- package/build/test/basedriver/driver-tests.js +30 -3
- package/build/test/e2e/basedriver/websockets.e2e.spec.js +12 -7
- package/build/test/unit/basedriver/commands/event.spec.js +7 -7
- package/build/test/unit/basedriver/commands/log.spec.js +31 -24
- package/build/test/unit/basedriver/timeout.spec.js +1 -1
- package/build/test/unit/protocol/routes.spec.js +2 -2
- package/build/tsconfig.tsbuildinfo +1 -0
- package/lib/basedriver/capabilities.js +49 -10
- package/lib/basedriver/commands/event.js +49 -31
- package/lib/basedriver/commands/find.js +108 -43
- package/lib/basedriver/commands/index.js +25 -19
- package/lib/basedriver/commands/log.js +60 -33
- package/lib/basedriver/commands/session.js +39 -141
- package/lib/basedriver/commands/settings.js +33 -13
- package/lib/basedriver/commands/timeout.js +153 -153
- package/lib/basedriver/core.js +497 -0
- package/lib/basedriver/desired-caps.js +1 -1
- package/lib/basedriver/device-settings.js +47 -12
- package/lib/basedriver/driver.js +273 -395
- package/lib/basedriver/helpers.js +18 -2
- package/lib/express/websocket.js +35 -32
- package/lib/helpers/capabilities.js +60 -1
- package/lib/index.js +16 -12
- package/lib/jsonwp-proxy/proxy.js +26 -6
- package/lib/protocol/errors.js +42 -42
- package/lib/protocol/index.js +4 -4
- package/lib/protocol/protocol.js +1 -3
- package/lib/protocol/routes.js +9 -0
- package/package.json +14 -11
- package/test/basedriver/driver-tests.js +31 -2
- package/index.d.ts +0 -386
|
@@ -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.
|
|
8
|
+
exports.TimeoutMixin = TimeoutMixin;
|
|
9
9
|
|
|
10
10
|
require("source-map-support/register");
|
|
11
11
|
|
|
@@ -17,173 +17,154 @@ var _support = require("@appium/support");
|
|
|
17
17
|
|
|
18
18
|
var _protocol = require("../../protocol");
|
|
19
19
|
|
|
20
|
-
let commands = {},
|
|
21
|
-
helpers = {},
|
|
22
|
-
extensions = {};
|
|
23
|
-
exports.helpers = helpers;
|
|
24
|
-
exports.commands = commands;
|
|
25
20
|
const MIN_TIMEOUT = 0;
|
|
26
21
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
type
|
|
31
|
-
|
|
32
|
-
|
|
22
|
+
function TimeoutMixin(Base) {
|
|
23
|
+
class TimeoutCommands extends Base {
|
|
24
|
+
async timeouts(type, ms, script, pageLoad, implicit) {
|
|
25
|
+
if (_support.util.hasValue(type) && _support.util.hasValue(ms)) {
|
|
26
|
+
this.log.debug(`MJSONWP timeout arguments: ${JSON.stringify({
|
|
27
|
+
type,
|
|
28
|
+
ms
|
|
29
|
+
})}}`);
|
|
30
|
+
|
|
31
|
+
switch (type) {
|
|
32
|
+
case 'command':
|
|
33
|
+
await this.newCommandTimeout(ms);
|
|
34
|
+
return;
|
|
35
|
+
|
|
36
|
+
case 'implicit':
|
|
37
|
+
await this.implicitWaitMJSONWP(ms);
|
|
38
|
+
return;
|
|
39
|
+
|
|
40
|
+
case 'page load':
|
|
41
|
+
await this.pageLoadTimeoutMJSONWP(ms);
|
|
42
|
+
return;
|
|
43
|
+
|
|
44
|
+
case 'script':
|
|
45
|
+
await this.scriptTimeoutMJSONWP(ms);
|
|
46
|
+
return;
|
|
47
|
+
|
|
48
|
+
default:
|
|
49
|
+
throw new Error(`'${type}' type is not supported for MJSONWP timeout`);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
33
52
|
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
53
|
+
this.log.debug(`W3C timeout argument: ${JSON.stringify({
|
|
54
|
+
script,
|
|
55
|
+
pageLoad,
|
|
56
|
+
implicit
|
|
57
|
+
})}}`);
|
|
38
58
|
|
|
39
|
-
|
|
40
|
-
await this.
|
|
41
|
-
|
|
59
|
+
if (_support.util.hasValue(script)) {
|
|
60
|
+
await this.scriptTimeoutW3C(script);
|
|
61
|
+
}
|
|
42
62
|
|
|
43
|
-
|
|
44
|
-
await this.
|
|
45
|
-
|
|
63
|
+
if (_support.util.hasValue(pageLoad)) {
|
|
64
|
+
await this.pageLoadTimeoutW3C(pageLoad);
|
|
65
|
+
}
|
|
46
66
|
|
|
47
|
-
|
|
48
|
-
await this.
|
|
49
|
-
|
|
67
|
+
if (_support.util.hasValue(implicit)) {
|
|
68
|
+
await this.implicitWaitW3C(implicit);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
50
71
|
|
|
51
|
-
|
|
52
|
-
|
|
72
|
+
async getTimeouts() {
|
|
73
|
+
return {
|
|
74
|
+
command: this.newCommandTimeoutMs,
|
|
75
|
+
implicit: this.implicitWaitMs
|
|
76
|
+
};
|
|
53
77
|
}
|
|
54
|
-
}
|
|
55
78
|
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
implicit
|
|
60
|
-
})}}`);
|
|
79
|
+
async implicitWaitW3C(ms) {
|
|
80
|
+
await this.implicitWait(ms);
|
|
81
|
+
}
|
|
61
82
|
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
83
|
+
async implicitWaitMJSONWP(ms) {
|
|
84
|
+
await this.implicitWait(ms);
|
|
85
|
+
}
|
|
65
86
|
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
87
|
+
async implicitWait(ms) {
|
|
88
|
+
await this.setImplicitWait(this.parseTimeoutArgument(ms));
|
|
89
|
+
}
|
|
69
90
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
};
|
|
91
|
+
async pageLoadTimeoutW3C(ms) {
|
|
92
|
+
throw new _protocol.errors.NotImplementedError('Not implemented yet for pageLoad.');
|
|
93
|
+
}
|
|
74
94
|
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
implicit: this.implicitWaitMs
|
|
79
|
-
};
|
|
80
|
-
};
|
|
95
|
+
async pageLoadTimeoutMJSONWP(ms) {
|
|
96
|
+
throw new _protocol.errors.NotImplementedError('Not implemented yet for pageLoad.');
|
|
97
|
+
}
|
|
81
98
|
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
}
|
|
99
|
+
async scriptTimeoutW3C(ms) {
|
|
100
|
+
throw new _protocol.errors.NotImplementedError('Not implemented yet for script.');
|
|
101
|
+
}
|
|
85
102
|
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
}
|
|
103
|
+
async scriptTimeoutMJSONWP(ms) {
|
|
104
|
+
throw new _protocol.errors.NotImplementedError('Not implemented yet for script.');
|
|
105
|
+
}
|
|
89
106
|
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
}
|
|
107
|
+
async newCommandTimeout(ms) {
|
|
108
|
+
this.setNewCommandTimeout(this.parseTimeoutArgument(ms));
|
|
109
|
+
}
|
|
93
110
|
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
111
|
+
setImplicitWait(ms) {
|
|
112
|
+
this.implicitWaitMs = ms;
|
|
113
|
+
this.log.debug(`Set implicit wait to ${ms}ms`);
|
|
97
114
|
|
|
98
|
-
|
|
99
|
-
|
|
115
|
+
if (this.managedDrivers && this.managedDrivers.length) {
|
|
116
|
+
this.log.debug('Setting implicit wait on managed drivers');
|
|
100
117
|
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
118
|
+
for (let driver of this.managedDrivers) {
|
|
119
|
+
if (_lodash.default.isFunction(driver.setImplicitWait)) {
|
|
120
|
+
driver.setImplicitWait(ms);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
104
123
|
}
|
|
105
124
|
}
|
|
106
|
-
}
|
|
107
|
-
};
|
|
108
125
|
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
};
|
|
126
|
+
setNewCommandTimeout(ms) {
|
|
127
|
+
this.newCommandTimeoutMs = ms;
|
|
128
|
+
this.log.debug(`Set new command timeout to ${ms}ms`);
|
|
112
129
|
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
};
|
|
130
|
+
if (this.managedDrivers && this.managedDrivers.length) {
|
|
131
|
+
this.log.debug('Setting new command timeout on managed drivers');
|
|
116
132
|
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
133
|
+
for (let driver of this.managedDrivers) {
|
|
134
|
+
if (_lodash.default.isFunction(driver.setNewCommandTimeout)) {
|
|
135
|
+
driver.setNewCommandTimeout(ms);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
120
140
|
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
};
|
|
141
|
+
async implicitWaitForCondition(condFn) {
|
|
142
|
+
this.log.debug(`Waiting up to ${this.implicitWaitMs} ms for condition`);
|
|
124
143
|
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
144
|
+
let wrappedCondFn = async (...args) => {
|
|
145
|
+
await this.clearNewCommandTimeout();
|
|
146
|
+
return await condFn(...args);
|
|
147
|
+
};
|
|
128
148
|
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
149
|
+
return await (0, _asyncbox.waitForCondition)(wrappedCondFn, {
|
|
150
|
+
waitMs: this.implicitWaitMs,
|
|
151
|
+
intervalMs: 500,
|
|
152
|
+
logger: this.log
|
|
153
|
+
});
|
|
154
|
+
}
|
|
132
155
|
|
|
133
|
-
|
|
134
|
-
|
|
156
|
+
parseTimeoutArgument(ms) {
|
|
157
|
+
let duration = parseInt(ms, 10);
|
|
135
158
|
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
driver.setNewCommandTimeout(ms);
|
|
159
|
+
if (_lodash.default.isNaN(duration) || duration < MIN_TIMEOUT) {
|
|
160
|
+
throw new _protocol.errors.UnknownError(`Invalid timeout value '${ms}'`);
|
|
139
161
|
}
|
|
162
|
+
|
|
163
|
+
return duration;
|
|
140
164
|
}
|
|
141
|
-
}
|
|
142
|
-
};
|
|
143
165
|
|
|
144
|
-
helpers.clearNewCommandTimeout = function clearNewCommandTimeout() {
|
|
145
|
-
if (this.noCommandTimer) {
|
|
146
|
-
clearTimeout(this.noCommandTimer);
|
|
147
|
-
this.noCommandTimer = null;
|
|
148
|
-
}
|
|
149
|
-
};
|
|
150
|
-
|
|
151
|
-
helpers.startNewCommandTimeout = function startNewCommandTimeout() {
|
|
152
|
-
this.clearNewCommandTimeout();
|
|
153
|
-
if (!this.newCommandTimeoutMs) return;
|
|
154
|
-
this.noCommandTimer = setTimeout(async () => {
|
|
155
|
-
this.log.warn(`Shutting down because we waited ` + `${this.newCommandTimeoutMs / 1000.0} seconds for a command`);
|
|
156
|
-
const errorMessage = `New Command Timeout of ` + `${this.newCommandTimeoutMs / 1000.0} seconds ` + `expired. Try customizing the timeout using the ` + `'newCommandTimeout' desired capability`;
|
|
157
|
-
await this.startUnexpectedShutdown(new Error(errorMessage));
|
|
158
|
-
}, this.newCommandTimeoutMs);
|
|
159
|
-
};
|
|
160
|
-
|
|
161
|
-
helpers.implicitWaitForCondition = async function implicitWaitForCondition(condFn) {
|
|
162
|
-
this.log.debug(`Waiting up to ${this.implicitWaitMs} ms for condition`);
|
|
163
|
-
|
|
164
|
-
let wrappedCondFn = async (...args) => {
|
|
165
|
-
this.clearNewCommandTimeout();
|
|
166
|
-
return await condFn(...args);
|
|
167
|
-
};
|
|
168
|
-
|
|
169
|
-
return await (0, _asyncbox.waitForCondition)(wrappedCondFn, {
|
|
170
|
-
waitMs: this.implicitWaitMs,
|
|
171
|
-
intervalMs: 500,
|
|
172
|
-
logger: this.log
|
|
173
|
-
});
|
|
174
|
-
};
|
|
175
|
-
|
|
176
|
-
helpers.parseTimeoutArgument = function parseTimeoutArgument(ms) {
|
|
177
|
-
let duration = parseInt(ms, 10);
|
|
178
|
-
|
|
179
|
-
if (_lodash.default.isNaN(duration) || duration < MIN_TIMEOUT) {
|
|
180
|
-
throw new _protocol.errors.UnknownError(`Invalid timeout value '${ms}'`);
|
|
181
166
|
}
|
|
182
167
|
|
|
183
|
-
return
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
Object.assign(extensions, commands, helpers);
|
|
187
|
-
var _default = extensions;
|
|
188
|
-
exports.default = _default;
|
|
189
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../lib/basedriver/commands/timeout.js"],"names":["commands","helpers","extensions","MIN_TIMEOUT","timeouts","type","ms","script","pageLoad","implicit","util","hasValue","log","debug","JSON","stringify","newCommandTimeout","implicitWaitMJSONWP","pageLoadTimeoutMJSONWP","scriptTimeoutMJSONWP","Error","scriptTimeoutW3C","pageLoadTimeoutW3C","implicitWaitW3C","getTimeouts","command","newCommandTimeoutMs","implicitWaitMs","implicitWait","setImplicitWait","parseTimeoutArgument","managedDrivers","length","driver","_","isFunction","errors","NotImplementedError","setNewCommandTimeout","clearNewCommandTimeout","noCommandTimer","clearTimeout","startNewCommandTimeout","setTimeout","warn","errorMessage","startUnexpectedShutdown","implicitWaitForCondition","condFn","wrappedCondFn","args","waitMs","intervalMs","logger","duration","parseInt","isNaN","UnknownError","Object","assign"],"mappings":"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","sourcesContent":["import { waitForCondition } from 'asyncbox';\nimport _ from 'lodash';\nimport { util } from '@appium/support';\nimport { errors } from '../../protocol';\n\n\nlet commands = {}, helpers = {}, extensions = {};\n\nconst MIN_TIMEOUT = 0;\n\ncommands.timeouts = async function timeouts (type, ms, script, pageLoad, implicit) {\n  if (util.hasValue(type) && util.hasValue(ms)) {\n    this.log.debug(`MJSONWP timeout arguments: ${JSON.stringify({type, ms})}}`);\n\n    switch (type) {\n      case 'command':\n        await this.newCommandTimeout(ms);\n        return;\n      case 'implicit':\n        await this.implicitWaitMJSONWP(ms);\n        return;\n      case 'page load':\n        await this.pageLoadTimeoutMJSONWP(ms);\n        return;\n      case 'script':\n        await this.scriptTimeoutMJSONWP(ms);\n        return;\n      default:\n        throw new Error(`'${type}' type is not supported for MJSONWP timeout`);\n    }\n  }\n\n  // Otherwise assume it is W3C protocol\n  this.log.debug(`W3C timeout argument: ${JSON.stringify({script, pageLoad, implicit})}}`);\n  if (util.hasValue(script)) {\n    await this.scriptTimeoutW3C(script);\n  }\n  if (util.hasValue(pageLoad)) {\n    await this.pageLoadTimeoutW3C(pageLoad);\n  }\n  if (util.hasValue(implicit)) {\n    await this.implicitWaitW3C(implicit);\n  }\n};\n\ncommands.getTimeouts = async function getTimeouts () { // eslint-disable-line require-await\n  return {\n    command: this.newCommandTimeoutMs,\n    implicit: this.implicitWaitMs,\n  };\n};\n\n// implicit\ncommands.implicitWaitW3C = async function implicitWaitW3C (ms) {\n  await this.implicitWait(ms);\n};\n\ncommands.implicitWaitMJSONWP = async function implicitWaitMJSONWP (ms) {\n  await this.implicitWait(ms);\n};\n\ncommands.implicitWait = async function implicitWait (ms) {\n  await this.setImplicitWait(this.parseTimeoutArgument(ms));\n};\n\nhelpers.setImplicitWait = function setImplicitWait (ms) { // eslint-disable-line require-await\n  this.implicitWaitMs = ms;\n  this.log.debug(`Set implicit wait to ${ms}ms`);\n  if (this.managedDrivers && this.managedDrivers.length) {\n    this.log.debug('Setting implicit wait on managed drivers');\n    for (let driver of this.managedDrivers) {\n      if (_.isFunction(driver.setImplicitWait)) {\n        driver.setImplicitWait(ms);\n      }\n    }\n  }\n};\n\n// pageLoad\n// eslint-disable-next-line no-unused-vars\ncommands.pageLoadTimeoutW3C = async function pageLoadTimeoutW3C (ms) { // eslint-disable-line require-await\n  throw new errors.NotImplementedError('Not implemented yet for pageLoad.');\n};\n\n// eslint-disable-next-line no-unused-vars\ncommands.pageLoadTimeoutMJSONWP = async function pageLoadTimeoutMJSONWP (ms) { // eslint-disable-line require-await\n  throw new errors.NotImplementedError('Not implemented yet for pageLoad.');\n};\n\n// script\n// eslint-disable-next-line no-unused-vars\ncommands.scriptTimeoutW3C = async function scriptTimeoutW3C (ms) { // eslint-disable-line require-await\n  throw new errors.NotImplementedError('Not implemented yet for script.');\n};\n\n// eslint-disable-next-line no-unused-vars\ncommands.scriptTimeoutMJSONWP = async function scriptTimeoutMJSONWP (ms) { // eslint-disable-line require-await\n  throw new errors.NotImplementedError('Not implemented yet for script.');\n};\n\n// command\ncommands.newCommandTimeout = async function newCommandTimeout (ms) { // eslint-disable-line require-await\n  this.setNewCommandTimeout(this.parseTimeoutArgument(ms));\n};\n\nhelpers.setNewCommandTimeout = function setNewCommandTimeout (ms) {\n  this.newCommandTimeoutMs = ms;\n  this.log.debug(`Set new command timeout to ${ms}ms`);\n  if (this.managedDrivers && this.managedDrivers.length) {\n    this.log.debug('Setting new command timeout on managed drivers');\n    for (let driver of this.managedDrivers) {\n      if (_.isFunction(driver.setNewCommandTimeout)) {\n        driver.setNewCommandTimeout(ms);\n      }\n    }\n  }\n};\n\nhelpers.clearNewCommandTimeout = function clearNewCommandTimeout () {\n  if (this.noCommandTimer) {\n    clearTimeout(this.noCommandTimer);\n    this.noCommandTimer = null;\n  }\n};\n\nhelpers.startNewCommandTimeout = function startNewCommandTimeout () {\n  // make sure there are no rogue timeouts\n  this.clearNewCommandTimeout();\n\n  // if command timeout is 0, it is disabled\n  if (!this.newCommandTimeoutMs) return; // eslint-disable-line curly\n\n  this.noCommandTimer = setTimeout(async () => {\n    this.log.warn(`Shutting down because we waited ` +\n              `${this.newCommandTimeoutMs / 1000.0} seconds for a command`);\n    const errorMessage = `New Command Timeout of ` +\n              `${this.newCommandTimeoutMs / 1000.0} seconds ` +\n              `expired. Try customizing the timeout using the ` +\n              `'newCommandTimeout' desired capability`;\n    await this.startUnexpectedShutdown(new Error(errorMessage));\n  }, this.newCommandTimeoutMs);\n};\n\nhelpers.implicitWaitForCondition = async function implicitWaitForCondition (condFn) {\n  this.log.debug(`Waiting up to ${this.implicitWaitMs} ms for condition`);\n  let wrappedCondFn = async (...args) => {\n    // reset command timeout\n    this.clearNewCommandTimeout();\n\n    return await condFn(...args);\n  };\n  return await waitForCondition(wrappedCondFn, {\n    waitMs: this.implicitWaitMs, intervalMs: 500, logger: this.log\n  });\n};\n\nhelpers.parseTimeoutArgument = function parseTimeoutArgument (ms) {\n  let duration = parseInt(ms, 10);\n  if (_.isNaN(duration) || duration < MIN_TIMEOUT) {\n    throw new errors.UnknownError(`Invalid timeout value '${ms}'`);\n  }\n  return duration;\n};\n\nObject.assign(extensions, commands, helpers);\nexport { commands, helpers };\nexport default extensions;\n"]}
|
|
168
|
+
return TimeoutCommands;
|
|
169
|
+
}
|
|
170
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../lib/basedriver/commands/timeout.js"],"names":["MIN_TIMEOUT","TimeoutMixin","Base","TimeoutCommands","timeouts","type","ms","script","pageLoad","implicit","util","hasValue","log","debug","JSON","stringify","newCommandTimeout","implicitWaitMJSONWP","pageLoadTimeoutMJSONWP","scriptTimeoutMJSONWP","Error","scriptTimeoutW3C","pageLoadTimeoutW3C","implicitWaitW3C","getTimeouts","command","newCommandTimeoutMs","implicitWaitMs","implicitWait","setImplicitWait","parseTimeoutArgument","errors","NotImplementedError","setNewCommandTimeout","managedDrivers","length","driver","_","isFunction","implicitWaitForCondition","condFn","wrappedCondFn","args","clearNewCommandTimeout","waitMs","intervalMs","logger","duration","parseInt","isNaN","UnknownError"],"mappings":"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","sourcesContent":["// @ts-check\n\n/* eslint-disable no-unused-vars */\n/* eslint-disable require-await */\nimport {waitForCondition} from 'asyncbox';\nimport _ from 'lodash';\nimport {util} from '@appium/support';\nimport {errors} from '../../protocol';\n\nconst MIN_TIMEOUT = 0;\n\n/**\n * @param {import('../driver').BaseDriverBase} Base\n * @returns {TimeoutBase}\n */\nexport function TimeoutMixin (Base) {\n\n  /**\n   * @implements {ITimeoutCommands}\n   */\n  class TimeoutCommands extends Base {\n    async timeouts (type, ms, script, pageLoad, implicit) {\n      if (util.hasValue(type) && util.hasValue(ms)) {\n        this.log.debug(\n          `MJSONWP timeout arguments: ${JSON.stringify({type, ms})}}`,\n        );\n\n        switch (type) {\n          case 'command':\n            await this.newCommandTimeout(ms);\n            return;\n          case 'implicit':\n            await this.implicitWaitMJSONWP(ms);\n            return;\n          case 'page load':\n            await this.pageLoadTimeoutMJSONWP(ms);\n            return;\n          case 'script':\n            await this.scriptTimeoutMJSONWP(ms);\n            return;\n          default:\n            throw new Error(\n              `'${type}' type is not supported for MJSONWP timeout`,\n            );\n        }\n      }\n\n      // Otherwise assume it is W3C protocol\n      this.log.debug(\n        `W3C timeout argument: ${JSON.stringify({\n          script,\n          pageLoad,\n          implicit,\n        })}}`,\n      );\n      if (util.hasValue(script)) {\n        await this.scriptTimeoutW3C(script);\n      }\n      if (util.hasValue(pageLoad)) {\n        await this.pageLoadTimeoutW3C(pageLoad);\n      }\n      if (util.hasValue(implicit)) {\n        await this.implicitWaitW3C(implicit);\n      }\n    }\n\n    async getTimeouts () {\n      return {\n        command: this.newCommandTimeoutMs,\n        implicit: this.implicitWaitMs,\n      };\n    }\n\n    // implicit\n    async implicitWaitW3C (ms) {\n      await this.implicitWait(ms);\n    }\n\n    async implicitWaitMJSONWP (ms) {\n      await this.implicitWait(ms);\n    }\n\n    async implicitWait (ms) {\n      await this.setImplicitWait(this.parseTimeoutArgument(ms));\n    }\n\n    // pageLoad\n    async pageLoadTimeoutW3C (ms) {\n      throw new errors.NotImplementedError('Not implemented yet for pageLoad.');\n    }\n\n    async pageLoadTimeoutMJSONWP (ms) {\n      throw new errors.NotImplementedError('Not implemented yet for pageLoad.');\n    }\n\n    // script\n    async scriptTimeoutW3C (ms) {\n      throw new errors.NotImplementedError('Not implemented yet for script.');\n    }\n\n    async scriptTimeoutMJSONWP (ms) {\n      throw new errors.NotImplementedError('Not implemented yet for script.');\n    }\n\n    // command\n    async newCommandTimeout (ms) {\n      this.setNewCommandTimeout(this.parseTimeoutArgument(ms));\n    }\n\n    setImplicitWait (ms) {\n      // eslint-disable-line require-await\n      this.implicitWaitMs = ms;\n      this.log.debug(`Set implicit wait to ${ms}ms`);\n      if (this.managedDrivers && this.managedDrivers.length) {\n        this.log.debug('Setting implicit wait on managed drivers');\n        for (let driver of this.managedDrivers) {\n          if (_.isFunction(driver.setImplicitWait)) {\n            driver.setImplicitWait(ms);\n          }\n        }\n      }\n    }\n\n    setNewCommandTimeout (ms) {\n      this.newCommandTimeoutMs = ms;\n      this.log.debug(`Set new command timeout to ${ms}ms`);\n      if (this.managedDrivers && this.managedDrivers.length) {\n        this.log.debug('Setting new command timeout on managed drivers');\n        for (let driver of this.managedDrivers) {\n          if (_.isFunction(driver.setNewCommandTimeout)) {\n            driver.setNewCommandTimeout(ms);\n          }\n        }\n      }\n    }\n\n    async implicitWaitForCondition (condFn) {\n      this.log.debug(`Waiting up to ${this.implicitWaitMs} ms for condition`);\n      let wrappedCondFn = async (...args) => {\n        // reset command timeout\n        await this.clearNewCommandTimeout();\n\n        return await condFn(...args);\n      };\n      return await waitForCondition(wrappedCondFn, {\n        waitMs: this.implicitWaitMs,\n        intervalMs: 500,\n        logger: this.log,\n      });\n    }\n\n    parseTimeoutArgument (ms) {\n      let duration = parseInt(ms, 10);\n      if (_.isNaN(duration) || duration < MIN_TIMEOUT) {\n        throw new errors.UnknownError(`Invalid timeout value '${ms}'`);\n      }\n      return duration;\n    }\n  }\n\n  return TimeoutCommands;\n}\n\n/**\n * @typedef {import('@appium/types').TimeoutCommands} ITimeoutCommands\n * @typedef {import('../driver').BaseDriverBase<ITimeoutCommands>} TimeoutBase\n */\n"]}
|
|
@@ -0,0 +1,235 @@
|
|
|
1
|
+
export type Capabilities = import('@appium/types').Capabilities;
|
|
2
|
+
export type W3CCapabilities = import('@appium/types').W3CCapabilities;
|
|
3
|
+
export type Driver = import('@appium/types').Driver;
|
|
4
|
+
export type Core = import('@appium/types').Core;
|
|
5
|
+
export type DriverOpts = import('@appium/types').DriverOpts;
|
|
6
|
+
export type EventHistory = import('@appium/types').EventHistory;
|
|
7
|
+
export type AppiumLogger = import('@appium/types').AppiumLogger;
|
|
8
|
+
/**
|
|
9
|
+
* @implements {Core}
|
|
10
|
+
*/
|
|
11
|
+
export class DriverCore implements Core {
|
|
12
|
+
/**
|
|
13
|
+
* Make the basedriver version available so for any driver which inherits from this package, we
|
|
14
|
+
* know which version of basedriver it inherited from
|
|
15
|
+
*/
|
|
16
|
+
static baseVersion: any;
|
|
17
|
+
constructor(opts?: import("@appium/types").DriverOpts, shouldValidateCaps?: boolean);
|
|
18
|
+
/**
|
|
19
|
+
* @type {string?}
|
|
20
|
+
*/
|
|
21
|
+
sessionId: string | null;
|
|
22
|
+
/**
|
|
23
|
+
* @type {DriverOpts & Capabilities}
|
|
24
|
+
*/
|
|
25
|
+
opts: import("@appium/types").DriverOpts & Partial<import("@wdio/types/build/Capabilities").Capabilities & import("@wdio/types/build/Capabilities").AppiumCapabilities & {
|
|
26
|
+
[x: string]: any;
|
|
27
|
+
}>;
|
|
28
|
+
/**
|
|
29
|
+
* @type {DriverOpts}
|
|
30
|
+
*/
|
|
31
|
+
initialOpts: DriverOpts;
|
|
32
|
+
/**
|
|
33
|
+
* @type {Capabilities}
|
|
34
|
+
*/
|
|
35
|
+
caps: Capabilities;
|
|
36
|
+
/**
|
|
37
|
+
* @type {W3CCapabilities}
|
|
38
|
+
*/
|
|
39
|
+
originalCaps: W3CCapabilities;
|
|
40
|
+
helpers: import("@appium/types").DriverHelpers;
|
|
41
|
+
/**
|
|
42
|
+
* basePath is used for several purposes, for example in setting up
|
|
43
|
+
* proxying to other drivers, since we need to know what the base path
|
|
44
|
+
* of any incoming request might look like. We set it to the default
|
|
45
|
+
* initially but it is automatically updated during any actual program
|
|
46
|
+
* execution by the routeConfiguringFunction, which is necessarily run as
|
|
47
|
+
* the entrypoint for any Appium server
|
|
48
|
+
*/
|
|
49
|
+
basePath: string;
|
|
50
|
+
relaxedSecurityEnabled: boolean;
|
|
51
|
+
/** @type {string[]} */
|
|
52
|
+
allowInsecure: string[];
|
|
53
|
+
/** @type {string[]} */
|
|
54
|
+
denyInsecure: string[];
|
|
55
|
+
newCommandTimeoutMs: number;
|
|
56
|
+
implicitWaitMs: number;
|
|
57
|
+
/** @type {string[]} */
|
|
58
|
+
locatorStrategies: string[];
|
|
59
|
+
/** @type {string[]} */
|
|
60
|
+
webLocatorStrategies: string[];
|
|
61
|
+
/** @type {Driver[]} */
|
|
62
|
+
managedDrivers: Driver[];
|
|
63
|
+
/** @type {NodeJS.Timeout?} */
|
|
64
|
+
noCommandTimer: NodeJS.Timeout | null;
|
|
65
|
+
/** @type {EventHistory} */
|
|
66
|
+
_eventHistory: EventHistory;
|
|
67
|
+
_constraints: import("@appium/types").Constraints;
|
|
68
|
+
/** @type {NodeJS.EventEmitter} */
|
|
69
|
+
eventEmitter: NodeJS.EventEmitter;
|
|
70
|
+
/**
|
|
71
|
+
* @type {AppiumLogger}
|
|
72
|
+
*/
|
|
73
|
+
_log: AppiumLogger;
|
|
74
|
+
/**
|
|
75
|
+
* @protected
|
|
76
|
+
*/
|
|
77
|
+
protected shutdownUnexpectedly: boolean;
|
|
78
|
+
/**
|
|
79
|
+
* @type {boolean}
|
|
80
|
+
* @protected
|
|
81
|
+
*/
|
|
82
|
+
protected shouldValidateCaps: boolean;
|
|
83
|
+
/**
|
|
84
|
+
* @protected
|
|
85
|
+
*/
|
|
86
|
+
protected commandsQueueGuard: AsyncLock;
|
|
87
|
+
/**
|
|
88
|
+
* settings should be instantiated by drivers which extend BaseDriver, but
|
|
89
|
+
* we set it to an empty DeviceSettings instance here to make sure that the
|
|
90
|
+
* default settings are applied even if an extending driver doesn't utilize
|
|
91
|
+
* the settings functionality itself
|
|
92
|
+
*/
|
|
93
|
+
settings: DeviceSettings<Record<string, unknown>>;
|
|
94
|
+
get log(): import("@appium/types").AppiumLogger;
|
|
95
|
+
/**
|
|
96
|
+
* Set a callback handler if needed to execute a custom piece of code
|
|
97
|
+
* when the driver is shut down unexpectedly. Multiple calls to this method
|
|
98
|
+
* will cause the handler to be executed mutiple times
|
|
99
|
+
*
|
|
100
|
+
* @param {(...args: any[]) => void} handler The code to be executed on unexpected shutdown.
|
|
101
|
+
* The function may accept one argument, which is the actual error instance, which
|
|
102
|
+
* caused the driver to shut down.
|
|
103
|
+
*/
|
|
104
|
+
onUnexpectedShutdown(handler: (...args: any[]) => void): void;
|
|
105
|
+
/**
|
|
106
|
+
* This property is used by AppiumDriver to store the data of the
|
|
107
|
+
* specific driver sessions. This data can be later used to adjust
|
|
108
|
+
* properties for driver instances running in parallel.
|
|
109
|
+
* Override it in inherited driver classes if necessary.
|
|
110
|
+
*
|
|
111
|
+
* @return {Record<string,unknown>} Driver properties mapping
|
|
112
|
+
*/
|
|
113
|
+
get driverData(): Record<string, unknown>;
|
|
114
|
+
/**
|
|
115
|
+
* This property controls the way {#executeCommand} method
|
|
116
|
+
* handles new driver commands received from the client.
|
|
117
|
+
* Override it for inherited classes only in special cases.
|
|
118
|
+
*
|
|
119
|
+
* @return {boolean} If the returned value is true (default) then all the commands
|
|
120
|
+
* received by the particular driver instance are going to be put into the queue,
|
|
121
|
+
* so each following command will not be executed until the previous command
|
|
122
|
+
* execution is completed. False value disables that queue, so each driver command
|
|
123
|
+
* is executed independently and does not wait for anything.
|
|
124
|
+
*/
|
|
125
|
+
get isCommandsQueueEnabled(): boolean;
|
|
126
|
+
get eventHistory(): import("@appium/types").EventHistory;
|
|
127
|
+
/**
|
|
128
|
+
* API method for driver developers to log timings for important events
|
|
129
|
+
* @param {string} eventName
|
|
130
|
+
*/
|
|
131
|
+
logEvent(eventName: string): void;
|
|
132
|
+
/**
|
|
133
|
+
* Overridden in appium driver, but here so that individual drivers can be
|
|
134
|
+
* tested with clients that poll
|
|
135
|
+
*/
|
|
136
|
+
getStatus(): Promise<{}>;
|
|
137
|
+
set desiredCapConstraints(arg: import("@appium/types").Constraints);
|
|
138
|
+
get desiredCapConstraints(): import("@appium/types").Constraints;
|
|
139
|
+
/**
|
|
140
|
+
* method required by MJSONWP in order to determine whether it should
|
|
141
|
+
* respond with an invalid session response
|
|
142
|
+
* @param {string} [sessionId]
|
|
143
|
+
* @returns {boolean}
|
|
144
|
+
*/
|
|
145
|
+
sessionExists(sessionId?: string | undefined): boolean;
|
|
146
|
+
/**
|
|
147
|
+
* method required by MJSONWP in order to determine if the command should
|
|
148
|
+
* be proxied directly to the driver
|
|
149
|
+
* @param {string} sessionId
|
|
150
|
+
* @returns {this | import('@appium/types').Driver}
|
|
151
|
+
*/
|
|
152
|
+
driverForSession(sessionId: string): import("@appium/types").Driver | DriverCore;
|
|
153
|
+
/**
|
|
154
|
+
*
|
|
155
|
+
* @param {Capabilities} caps
|
|
156
|
+
*/
|
|
157
|
+
logExtraCaps(caps: Partial<import("@wdio/types/build/Capabilities").Capabilities & import("@wdio/types/build/Capabilities").AppiumCapabilities & {
|
|
158
|
+
[x: string]: any;
|
|
159
|
+
}>): void;
|
|
160
|
+
/**
|
|
161
|
+
*
|
|
162
|
+
* @param {Capabilities} caps
|
|
163
|
+
* @returns {boolean}
|
|
164
|
+
*/
|
|
165
|
+
validateDesiredCaps(caps: Capabilities): boolean;
|
|
166
|
+
isMjsonwpProtocol(): boolean;
|
|
167
|
+
isW3CProtocol(): boolean;
|
|
168
|
+
setProtocolMJSONWP(): void;
|
|
169
|
+
protocol: string | undefined;
|
|
170
|
+
setProtocolW3C(): void;
|
|
171
|
+
/**
|
|
172
|
+
* Check whether a given feature is enabled via its name
|
|
173
|
+
*
|
|
174
|
+
* @param {string} name - name of feature/command
|
|
175
|
+
*
|
|
176
|
+
* @returns {Boolean}
|
|
177
|
+
*/
|
|
178
|
+
isFeatureEnabled(name: string): boolean;
|
|
179
|
+
/**
|
|
180
|
+
* Assert that a given feature is enabled and throw a helpful error if it's
|
|
181
|
+
* not
|
|
182
|
+
*
|
|
183
|
+
* @param {string} name - name of feature/command
|
|
184
|
+
*/
|
|
185
|
+
ensureFeatureEnabled(name: string): void;
|
|
186
|
+
/**
|
|
187
|
+
*
|
|
188
|
+
* @param {string} strategy
|
|
189
|
+
* @param {boolean} [webContext]
|
|
190
|
+
*/
|
|
191
|
+
validateLocatorStrategy(strategy: string, webContext?: boolean | undefined): void;
|
|
192
|
+
/**
|
|
193
|
+
*
|
|
194
|
+
* @param {string} [sessionId]
|
|
195
|
+
* @returns {boolean}
|
|
196
|
+
*/
|
|
197
|
+
proxyActive(sessionId?: string | undefined): boolean;
|
|
198
|
+
/**
|
|
199
|
+
*
|
|
200
|
+
* @param {string} sessionId
|
|
201
|
+
* @returns {[string, RegExp][]}
|
|
202
|
+
*/
|
|
203
|
+
getProxyAvoidList(sessionId: string): [string, RegExp][];
|
|
204
|
+
/**
|
|
205
|
+
*
|
|
206
|
+
* @param {string} [sessionId]
|
|
207
|
+
* @returns {boolean}
|
|
208
|
+
*/
|
|
209
|
+
canProxy(sessionId?: string | undefined): boolean;
|
|
210
|
+
/**
|
|
211
|
+
* Whether a given command route (expressed as method and url) should not be
|
|
212
|
+
* proxied according to this driver
|
|
213
|
+
*
|
|
214
|
+
* @param {string} sessionId - the current sessionId (in case the driver runs
|
|
215
|
+
* multiple session ids and requires it). This is not used in this method but
|
|
216
|
+
* should be made available to overridden methods.
|
|
217
|
+
* @param {import('@appium/types').HTTPMethod} method - HTTP method of the route
|
|
218
|
+
* @param {string} url - url of the route
|
|
219
|
+
* @param {any} [body] - webdriver request body
|
|
220
|
+
*
|
|
221
|
+
* @returns {boolean} - whether the route should be avoided
|
|
222
|
+
*/
|
|
223
|
+
proxyRouteIsAvoided(sessionId: string, method: import('@appium/types').HTTPMethod, url: string, body?: any): boolean;
|
|
224
|
+
/**
|
|
225
|
+
*
|
|
226
|
+
* @param {Driver} driver
|
|
227
|
+
*/
|
|
228
|
+
addManagedDriver(driver: Driver): void;
|
|
229
|
+
getManagedDrivers(): import("@appium/types").Driver[];
|
|
230
|
+
clearNewCommandTimeout(): Promise<void>;
|
|
231
|
+
}
|
|
232
|
+
import { EventEmitter } from "events";
|
|
233
|
+
import AsyncLock from "async-lock";
|
|
234
|
+
import DeviceSettings from "./device-settings";
|
|
235
|
+
//# sourceMappingURL=core.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core.d.ts","sourceRoot":"","sources":["../../../lib/basedriver/core.js"],"names":[],"mappings":"2BAyea,OAAO,eAAe,EAAE,YAAY;8BACpC,OAAO,eAAe,EAAE,eAAe;qBACvC,OAAO,eAAe,EAAE,MAAM;mBAC9B,OAAO,eAAe,EAAE,IAAI;yBAC5B,OAAO,eAAe,EAAE,UAAU;2BAClC,OAAO,eAAe,EAAE,YAAY;2BACpC,OAAO,eAAe,EAAE,YAAY;AAzdjD;;GAEG;AACH;IAEE;;;OAGG;IACH,wBAAoC;IAqGpC,qFAqBC;IAxHD;;MAEE;IACF,WAFS,MAAM,QAEE;IAEjB;;MAEE;IACF;;OAAK;IAEL;;MAEE;IACF,aAFS,UAAU,CAEP;IAEZ;;MAEE;IACF,MAFS,YAAY,CAEhB;IAEL;;MAEE;IACF,cAFS,eAAe,CAEX;IAEb,+CAAkB;IAElB;;;;;;;MAOE;IACF,iBAA6B;IAE7B,gCAA+B;IAE/B,uBAAuB;IACvB,eADW,MAAM,EAAE,CACA;IAEnB,uBAAuB;IACvB,cADW,MAAM,EAAE,CACD;IAElB,4BAA6C;IAE7C,uBAAmB;IAEnB,uBAAuB;IACvB,mBADW,MAAM,EAAE,CACI;IAEvB,uBAAuB;IACvB,sBADW,MAAM,EAAE,CACO;IAE1B,uBAAuB;IACvB,gBADW,MAAM,EAAE,CACC;IAEpB,8BAA8B;IAC9B,gBADW,OAAO,OAAO,QACH;IAEtB,2BAA2B;IAC3B,eADW,YAAY,CACQ;IAE/B,kDAAyD;IAGzD,kCAAkC;IAClC,cADW,mBAAmB,CACI;IAElC;;MAEE;IACF,MAFS,YAAY,CAEhB;IAEL;;MAEE;IACF,wCAA6B;IAE7B;;;MAGE;IACF,8BAHS,OAAO,CAGG;IAEnB;;MAEE;IACF,wCAAqC;IAErC;;;;;MAKE;IACF,kDAAgC;IAyBhC,gDAEC;IAED;;;;;;;;MAQE;IACF,wCAJoB,GAAG,EAAE,KAAK,IAAI,QAMjC;IAED;;;;;;;MAOE;IACF,0CAEC;IAED;;;;;;;;;;MAUE;IACF,sCAEC;IAMD,yDAEC;IAED;;;MAGE;IACF,oBAFU,MAAM,QAgBf;IAED;;;MAGE;IACF,yBAEC;IAGD,oEAWC;IAED,iEAEC;IAED;;;;;MAKE;IACF,+CAFY,OAAO,CAKlB;IAED;;;;;MAKE;IACF,4BAHU,MAAM,+CAKf;IAED;;;MAGE;IACF;;cAWC;IAED;;;;MAIE;IACF,0BAHU,YAAY,GACV,OAAO,CAqBlB;IAED,6BAEC;IAED,yBAEC;IAED,2BAEC;IADC,6BAAiC;IAGnC,uBAEC;IAED;;;;;;MAME;IACF,uBAJU,MAAM,WAuBf;IAED;;;;;MAKE;IACF,2BAFU,MAAM,QAYf;IAED;;;;MAIE;IACF,kCAHU,MAAM,0CAoBf;IAED;;;;MAIE;IACF,6CAFY,OAAO,CAIlB;IAED;;;;MAIE;IACF,6BAHU,MAAM,GACJ,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAI7B;IAED;;;;MAIE;IACF,0CAFY,OAAO,CAIlB;IAED;;;;;;;;;;;;MAYE;IACF,+BATU,MAAM,UAGN,OAAO,eAAe,EAAE,UAAU,OAClC,MAAM,SACN,GAAG,GAED,OAAO,CAuBlB;IAED;;;MAGE;IACF,yBAFU,MAAM,QAIf;IAED,sDAEC;IAED,wCAKC;CACF"}
|