@appium/base-driver 8.2.3 → 8.3.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.
Files changed (128) hide show
  1. package/build/lib/basedriver/capabilities.js +2 -4
  2. package/build/lib/basedriver/commands/event.js +2 -4
  3. package/build/lib/basedriver/commands/find.js +5 -14
  4. package/build/lib/basedriver/commands/index.js +2 -4
  5. package/build/lib/basedriver/commands/log.js +4 -9
  6. package/build/lib/basedriver/commands/session.js +19 -30
  7. package/build/lib/basedriver/commands/settings.js +5 -11
  8. package/build/lib/basedriver/commands/timeout.js +11 -18
  9. package/build/lib/basedriver/desired-caps.js +2 -4
  10. package/build/lib/basedriver/device-settings.js +15 -5
  11. package/build/lib/basedriver/driver.js +36 -23
  12. package/build/lib/basedriver/helpers.js +10 -12
  13. package/build/lib/basedriver/logger.js +2 -4
  14. package/build/lib/constants.js +2 -4
  15. package/build/lib/express/crash.js +2 -4
  16. package/build/lib/express/express-logging.js +3 -5
  17. package/build/lib/express/idempotency.js +3 -5
  18. package/build/lib/express/logger.js +2 -4
  19. package/build/lib/express/middleware.js +2 -4
  20. package/build/lib/express/server.js +2 -4
  21. package/build/lib/express/static.js +2 -4
  22. package/build/lib/express/websocket.js +2 -4
  23. package/build/lib/helpers/capabilities.js +37 -0
  24. package/build/lib/index.js +4 -8
  25. package/build/lib/jsonwp-proxy/protocol-converter.js +19 -15
  26. package/build/lib/jsonwp-proxy/proxy.js +20 -15
  27. package/build/lib/jsonwp-status/status.js +2 -4
  28. package/build/lib/protocol/errors.js +2 -4
  29. package/build/lib/protocol/helpers.js +2 -4
  30. package/build/lib/protocol/index.js +2 -4
  31. package/build/lib/protocol/protocol.js +37 -30
  32. package/build/lib/protocol/routes.js +68 -4
  33. package/build/lib/protocol/validators.js +2 -4
  34. package/build/test/basedriver/README.md +5 -0
  35. package/build/test/basedriver/driver-e2e-tests.js +2 -4
  36. package/build/test/basedriver/driver-tests.js +12 -17
  37. package/build/test/basedriver/index.js +2 -4
  38. package/build/test/e2e/basedriver/driver.e2e.spec.js +15 -0
  39. package/build/test/e2e/basedriver/helpers.e2e.spec.js +192 -0
  40. package/build/test/e2e/basedriver/websockets.e2e.spec.js +82 -0
  41. package/build/test/e2e/express/server.e2e.spec.js +159 -0
  42. package/build/test/e2e/jsonwp-proxy/proxy.e2e.spec.js +59 -0
  43. package/build/test/e2e/protocol/fake-driver.js +163 -0
  44. package/build/test/e2e/protocol/helpers.js +25 -0
  45. package/build/test/e2e/protocol/protocol.e2e.spec.js +1186 -0
  46. package/build/test/helpers.js +2 -4
  47. package/build/test/unit/basedriver/capabilities.spec.js +672 -0
  48. package/build/test/unit/basedriver/capability.spec.js +353 -0
  49. package/build/test/unit/basedriver/commands/event.spec.js +110 -0
  50. package/build/test/unit/basedriver/commands/log.spec.js +85 -0
  51. package/build/test/unit/basedriver/driver.spec.js +15 -0
  52. package/build/test/unit/basedriver/helpers.spec.js +151 -0
  53. package/build/test/unit/basedriver/timeout.spec.js +135 -0
  54. package/build/test/unit/express/server.spec.js +155 -0
  55. package/build/test/unit/express/static.spec.js +26 -0
  56. package/build/test/unit/jsonwp-proxy/mock-request.js +91 -0
  57. package/build/test/unit/jsonwp-proxy/protocol-converter.spec.js +171 -0
  58. package/build/test/unit/jsonwp-proxy/proxy.spec.js +292 -0
  59. package/build/test/unit/jsonwp-proxy/url.spec.js +165 -0
  60. package/build/test/unit/jsonwp-status/status.spec.js +34 -0
  61. package/build/test/unit/protocol/errors.spec.js +390 -0
  62. package/build/test/unit/protocol/routes.spec.js +80 -0
  63. package/build/test/unit/protocol/validator.spec.js +149 -0
  64. package/lib/basedriver/commands/find.js +3 -6
  65. package/lib/basedriver/commands/log.js +2 -4
  66. package/lib/basedriver/commands/session.js +21 -22
  67. package/lib/basedriver/commands/settings.js +3 -5
  68. package/lib/basedriver/commands/timeout.js +9 -10
  69. package/lib/basedriver/device-settings.js +10 -1
  70. package/lib/basedriver/driver.js +36 -12
  71. package/lib/basedriver/helpers.js +13 -11
  72. package/lib/express/express-logging.js +1 -1
  73. package/lib/express/idempotency.js +1 -1
  74. package/lib/helpers/capabilities.js +25 -0
  75. package/lib/index.js +2 -2
  76. package/lib/jsonwp-proxy/protocol-converter.js +14 -13
  77. package/lib/jsonwp-proxy/proxy.js +16 -12
  78. package/lib/protocol/protocol.js +34 -29
  79. package/lib/protocol/routes.js +60 -1
  80. package/package.json +36 -24
  81. package/test/basedriver/README.md +5 -0
  82. package/test/basedriver/driver-e2e-tests.js +1 -1
  83. package/test/basedriver/driver-tests.js +12 -7
  84. package/build/lib/protocol/sessions-cache.js +0 -88
  85. package/build/test/basedriver/capabilities-specs.js +0 -632
  86. package/build/test/basedriver/capability-specs.js +0 -396
  87. package/build/test/basedriver/commands/event-specs.js +0 -112
  88. package/build/test/basedriver/commands/log-specs.js +0 -80
  89. package/build/test/basedriver/driver-e2e-specs.js +0 -17
  90. package/build/test/basedriver/driver-specs.js +0 -17
  91. package/build/test/basedriver/helpers-e2e-specs.js +0 -194
  92. package/build/test/basedriver/helpers-specs.js +0 -153
  93. package/build/test/basedriver/timeout-specs.js +0 -139
  94. package/build/test/basedriver/websockets-e2e-specs.js +0 -84
  95. package/build/test/express/server-e2e-specs.js +0 -156
  96. package/build/test/express/server-specs.js +0 -151
  97. package/build/test/express/static-specs.js +0 -23
  98. package/build/test/jsonwp-proxy/mock-request.js +0 -93
  99. package/build/test/jsonwp-proxy/protocol-converter-specs.js +0 -173
  100. package/build/test/jsonwp-proxy/proxy-e2e-specs.js +0 -61
  101. package/build/test/jsonwp-proxy/proxy-specs.js +0 -294
  102. package/build/test/jsonwp-proxy/url-specs.js +0 -167
  103. package/build/test/jsonwp-status/status-specs.js +0 -36
  104. package/build/test/protocol/errors-specs.js +0 -388
  105. package/build/test/protocol/fake-driver.js +0 -168
  106. package/build/test/protocol/helpers.js +0 -27
  107. package/build/test/protocol/protocol-e2e-specs.js +0 -1182
  108. package/build/test/protocol/routes-specs.js +0 -82
  109. package/build/test/protocol/validator-specs.js +0 -151
  110. package/lib/protocol/sessions-cache.js +0 -74
  111. package/test/basedriver/capabilities-specs.js +0 -505
  112. package/test/basedriver/capability-specs.js +0 -409
  113. package/test/basedriver/commands/event-specs.js +0 -74
  114. package/test/basedriver/commands/log-specs.js +0 -70
  115. package/test/basedriver/driver-e2e-specs.js +0 -8
  116. package/test/basedriver/driver-specs.js +0 -8
  117. package/test/basedriver/fixtures/BadZippedApp.zip +0 -1
  118. package/test/basedriver/fixtures/FakeAndroidApp.apk +0 -1
  119. package/test/basedriver/fixtures/FakeAndroidApp.asd +0 -0
  120. package/test/basedriver/fixtures/FakeIOSApp.app +0 -1
  121. package/test/basedriver/fixtures/FakeIOSApp.app.zip +0 -0
  122. package/test/basedriver/fixtures/FakeIOSApp.ipa +0 -0
  123. package/test/basedriver/fixtures/custom-element-finder-bad.js +0 -5
  124. package/test/basedriver/fixtures/custom-element-finder.js +0 -29
  125. package/test/basedriver/helpers-e2e-specs.js +0 -187
  126. package/test/basedriver/helpers-specs.js +0 -137
  127. package/test/basedriver/timeout-specs.js +0 -133
  128. package/test/basedriver/websockets-e2e-specs.js +0 -75
@@ -0,0 +1,353 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ require("source-map-support/register");
6
+
7
+ var _bluebird = _interopRequireDefault(require("bluebird"));
8
+
9
+ var _lib = _interopRequireWildcard(require("../../../lib"));
10
+
11
+ var _logger = _interopRequireDefault(require("../../../lib/basedriver/logger"));
12
+
13
+ var _sinon = require("sinon");
14
+
15
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
16
+
17
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
18
+
19
+ describe('Desired Capabilities', function () {
20
+ let d;
21
+ let sandbox;
22
+ beforeEach(function () {
23
+ d = new _lib.default();
24
+ sandbox = (0, _sinon.createSandbox)();
25
+ sandbox.spy(d.log, 'warn');
26
+ sandbox.spy(_logger.default, 'warn');
27
+ });
28
+ afterEach(function () {
29
+ sandbox.restore();
30
+ });
31
+ it('should require platformName and deviceName', async function () {
32
+ await d.createSession({
33
+ firstMatch: [{}]
34
+ }).should.eventually.be.rejectedWith(_lib.errors.SessionNotCreatedError, /platformName/);
35
+ });
36
+ it('should require platformName', async function () {
37
+ await d.createSession({
38
+ alwaysMatch: {
39
+ 'appium:deviceName': 'Delorean'
40
+ }
41
+ }).should.eventually.be.rejectedWith(_lib.errors.SessionNotCreatedError, /platformName/);
42
+ });
43
+ it('should not care about cap order', async function () {
44
+ await d.createSession(null, null, {
45
+ alwaysMatch: {
46
+ 'appium:deviceName': 'Delorean',
47
+ platformName: 'iOS'
48
+ }
49
+ }).should.eventually.be.fulfilled;
50
+ });
51
+ it('should check required caps which are added to driver', async function () {
52
+ d.desiredCapConstraints = {
53
+ necessary: {
54
+ presence: true
55
+ },
56
+ proper: {
57
+ presence: true,
58
+ isString: true,
59
+ inclusion: ['Delorean', 'Reventon']
60
+ }
61
+ };
62
+ await d.createSession(null, null, {
63
+ alwaysMatch: {
64
+ 'platformName': 'iOS',
65
+ 'appium:deviceName': 'Delorean'
66
+ }
67
+ }).should.eventually.be.rejectedWith(_lib.errors.SessionNotCreatedError, /necessary.*proper/);
68
+ });
69
+ it('should check added required caps in addition to base', async function () {
70
+ d.desiredCapConstraints = {
71
+ necessary: {
72
+ presence: true
73
+ },
74
+ proper: {
75
+ presence: true,
76
+ isString: true,
77
+ inclusion: ['Delorean', 'Reventon']
78
+ }
79
+ };
80
+ await d.createSession(null, null, {
81
+ alwaysMatch: {
82
+ 'appium:necessary': 'yup'
83
+ }
84
+ }).should.eventually.be.rejectedWith(_lib.errors.SessionNotCreatedError, /platformName/);
85
+ });
86
+ it('should accept extra capabilities', async function () {
87
+ await d.createSession(null, null, {
88
+ alwaysMatch: {
89
+ 'platformName': 'iOS',
90
+ 'appium:deviceName': 'Delorean',
91
+ 'appium:extra': 'cheese',
92
+ 'appium:hold the': 'sauce'
93
+ }
94
+ }).should.eventually.be.fulfilled;
95
+ });
96
+ it('should log the use of extra caps', async function () {
97
+ this.timeout(500);
98
+ await d.createSession(null, null, {
99
+ alwaysMatch: {
100
+ 'platformName': 'iOS',
101
+ 'appium:deviceName': 'Delorean',
102
+ 'appium:extra': 'cheese',
103
+ 'appium:hold the': 'sauce'
104
+ }
105
+ });
106
+ d.log.warn.should.have.been.called;
107
+ });
108
+ it('should be sensitive to the case of caps', async function () {
109
+ await d.createSession(null, null, {
110
+ alwaysMatch: {
111
+ 'platformname': 'iOS',
112
+ 'appium:deviceName': 'Delorean'
113
+ }
114
+ }).should.eventually.be.rejectedWith(_lib.errors.SessionNotCreatedError, /platformName/);
115
+ });
116
+ describe('boolean capabilities', function () {
117
+ it('should allow a string "false"', async function () {
118
+ await d.createSession(null, null, {
119
+ alwaysMatch: {
120
+ 'platformName': 'iOS',
121
+ 'appium:deviceName': 'Delorean',
122
+ 'appium:noReset': 'false'
123
+ }
124
+ });
125
+ d.log.warn.should.have.been.called;
126
+ let sessions = await d.getSessions();
127
+ sessions[0].capabilities.noReset.should.eql(false);
128
+ });
129
+ it('should allow a string "true"', async function () {
130
+ await d.createSession(null, null, {
131
+ alwaysMatch: {
132
+ 'platformName': 'iOS',
133
+ 'appium:deviceName': 'Delorean',
134
+ 'appium:noReset': 'true'
135
+ }
136
+ });
137
+ d.log.warn.should.have.been.called;
138
+ let sessions = await d.getSessions();
139
+ sessions[0].capabilities.noReset.should.eql(true);
140
+ });
141
+ it('should allow a string "true" in string capabilities', async function () {
142
+ await d.createSession(null, null, {
143
+ alwaysMatch: {
144
+ 'platformName': 'iOS',
145
+ 'appium:deviceName': 'Delorean',
146
+ 'appium:language': 'true'
147
+ }
148
+ });
149
+ d.log.warn.should.not.have.been.called;
150
+ let sessions = await d.getSessions();
151
+ sessions[0].capabilities.language.should.eql('true');
152
+ });
153
+ });
154
+ describe('number capabilities', function () {
155
+ it('should allow a string "1"', async function () {
156
+ await d.createSession(null, null, {
157
+ alwaysMatch: {
158
+ 'platformName': 'iOS',
159
+ 'appium:deviceName': 'Delorean',
160
+ 'appium:newCommandTimeout': '1'
161
+ }
162
+ });
163
+ d.log.warn.should.have.been.called;
164
+ let sessions = await d.getSessions();
165
+ sessions[0].capabilities.newCommandTimeout.should.eql(1);
166
+ });
167
+ it('should allow a string "1.1"', async function () {
168
+ await d.createSession(null, null, {
169
+ alwaysMatch: {
170
+ 'platformName': 'iOS',
171
+ 'appium:deviceName': 'Delorean',
172
+ 'appium:newCommandTimeout': '1.1'
173
+ }
174
+ });
175
+ d.log.warn.should.have.been.called;
176
+ let sessions = await d.getSessions();
177
+ sessions[0].capabilities.newCommandTimeout.should.eql(1.1);
178
+ });
179
+ it('should allow a string "1" in string capabilities', async function () {
180
+ await d.createSession(null, null, {
181
+ alwaysMatch: {
182
+ 'platformName': 'iOS',
183
+ 'appium:deviceName': 'Delorean',
184
+ 'appium:language': '1'
185
+ }
186
+ });
187
+ d.log.warn.should.not.have.been.called;
188
+ let sessions = await d.getSessions();
189
+ sessions[0].capabilities.language.should.eql('1');
190
+ });
191
+ });
192
+ it('should error if objects in caps', async function () {
193
+ await d.createSession(null, null, {
194
+ alwaysMatch: {
195
+ 'platformName': {
196
+ a: 'iOS'
197
+ },
198
+ 'appium:deviceName': 'Delorean'
199
+ }
200
+ }).should.eventually.be.rejectedWith(_lib.errors.SessionNotCreatedError, /platformName/i);
201
+ });
202
+ it('should check for deprecated caps', async function () {
203
+ this.timeout(500);
204
+ d.desiredCapConstraints = {
205
+ 'lynx-version': {
206
+ deprecated: true
207
+ }
208
+ };
209
+ await d.createSession(null, null, {
210
+ alwaysMatch: {
211
+ 'platformName': 'iOS',
212
+ 'appium:deviceName': 'Delorean',
213
+ 'appium:lynx-version': 5
214
+ }
215
+ });
216
+ _logger.default.warn.should.have.been.called;
217
+ });
218
+ it('should not warn if deprecated=false', async function () {
219
+ this.timeout(500);
220
+ d.desiredCapConstraints = {
221
+ 'lynx-version': {
222
+ deprecated: false
223
+ }
224
+ };
225
+ await d.createSession(null, null, {
226
+ alwaysMatch: {
227
+ 'platformName': 'iOS',
228
+ 'appium:deviceName': 'Delorean',
229
+ 'appium:lynx-version': 5
230
+ }
231
+ });
232
+ d.log.warn.should.not.have.been.called;
233
+ });
234
+ it('should not validate against null/undefined caps', async function () {
235
+ d.desiredCapConstraints = {
236
+ 'foo': {
237
+ isString: true
238
+ }
239
+ };
240
+
241
+ try {
242
+ await d.createSession(null, null, {
243
+ alwaysMatch: {
244
+ platformName: 'iOS',
245
+ 'appium:deviceName': 'Dumb',
246
+ 'appium:foo': null
247
+ }
248
+ });
249
+ } finally {
250
+ await d.deleteSession();
251
+ }
252
+
253
+ await d.createSession(null, null, {
254
+ alwaysMatch: {
255
+ platformName: 'iOS',
256
+ 'appium:deviceName': 'Dumb',
257
+ 'appium:foo': 1
258
+ }
259
+ }).should.eventually.be.rejectedWith(/'foo' must be of type string/);
260
+
261
+ try {
262
+ await d.createSession(null, null, {
263
+ alwaysMatch: {
264
+ platformName: 'iOS',
265
+ 'appium:deviceName': 'Dumb',
266
+ 'appium:foo': undefined
267
+ }
268
+ });
269
+ } finally {
270
+ await d.deleteSession();
271
+ }
272
+
273
+ try {
274
+ await d.createSession(null, null, {
275
+ alwaysMatch: {
276
+ platformName: 'iOS',
277
+ 'appium:deviceName': 'Dumb',
278
+ 'appium:foo': ''
279
+ }
280
+ });
281
+ } finally {
282
+ await d.deleteSession();
283
+ }
284
+ });
285
+ it('should still validate null/undefined/empty caps whose presence is required', async function () {
286
+ d.desiredCapConstraints = {
287
+ foo: {
288
+ presence: true
289
+ }
290
+ };
291
+ await d.createSession(null, null, {
292
+ alwaysMatch: {
293
+ platformName: 'iOS',
294
+ 'appium:deviceName': 'Dumb',
295
+ 'appium:foo': null
296
+ }
297
+ }).should.eventually.be.rejectedWith(/blank/);
298
+ await d.createSession(null, {
299
+ alwaysMatch: {
300
+ platformName: 'iOS',
301
+ 'appium:deviceName': 'Dumb',
302
+ 'appium:foo': ''
303
+ }
304
+ }).should.eventually.be.rejectedWith(/blank/);
305
+ await d.createSession({
306
+ firstMatch: [{
307
+ platformName: 'iOS',
308
+ 'appium:deviceName': 'Dumb',
309
+ 'appium:foo': {}
310
+ }]
311
+ }).should.eventually.be.rejectedWith(/blank/);
312
+ await d.createSession({
313
+ alwaysMatch: {
314
+ platformName: 'iOS',
315
+ 'appium:deviceName': 'Dumb',
316
+ 'appium:foo': []
317
+ }
318
+ }).should.eventually.be.rejectedWith(/blank/);
319
+ await d.createSession({
320
+ alwaysMatch: {
321
+ platformName: 'iOS',
322
+ 'appium:deviceName': 'Dumb',
323
+ 'appium:foo': ' '
324
+ }
325
+ }).should.eventually.be.rejectedWith(/blank/);
326
+ });
327
+ describe('w3c', function () {
328
+ it('should accept w3c capabilities', async function () {
329
+ const [sessionId, caps] = await d.createSession(null, null, {
330
+ alwaysMatch: {
331
+ platformName: 'iOS',
332
+ 'appium:deviceName': 'Delorean'
333
+ },
334
+ firstMatch: [{}]
335
+ });
336
+
337
+ try {
338
+ sessionId.should.exist;
339
+ caps.should.eql({
340
+ platformName: 'iOS',
341
+ deviceName: 'Delorean'
342
+ });
343
+ } finally {
344
+ await d.deleteSession();
345
+ }
346
+ });
347
+ it('should raise an error if w3c capabilities is not a plain JSON object', async function () {
348
+ const testValues = [true, 'string', [], 100];
349
+ await _bluebird.default.map(testValues, val => d.createSession(null, null, val).should.eventually.be.rejectedWith(_lib.errors.SessionNotCreatedError));
350
+ });
351
+ });
352
+ });
353
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../test/unit/basedriver/capability.spec.js"],"names":["describe","d","sandbox","beforeEach","BaseDriver","spy","log","logger","afterEach","restore","it","createSession","firstMatch","should","eventually","be","rejectedWith","errors","SessionNotCreatedError","alwaysMatch","platformName","fulfilled","desiredCapConstraints","necessary","presence","proper","isString","inclusion","timeout","warn","have","been","called","sessions","getSessions","capabilities","noReset","eql","not","language","newCommandTimeout","a","deprecated","deleteSession","undefined","foo","sessionId","caps","exist","deviceName","testValues","B","map","val"],"mappings":";;;;;;AAEA;;AACA;;AACA;;AACA;;;;;;AAEAA,QAAQ,CAAC,sBAAD,EAAyB,YAAY;AAC3C,MAAIC,CAAJ;AACA,MAAIC,OAAJ;AAEAC,EAAAA,UAAU,CAAC,YAAY;AACrBF,IAAAA,CAAC,GAAG,IAAIG,YAAJ,EAAJ;AACAF,IAAAA,OAAO,GAAG,2BAAV;AACAA,IAAAA,OAAO,CAACG,GAAR,CAAYJ,CAAC,CAACK,GAAd,EAAmB,MAAnB;AACAJ,IAAAA,OAAO,CAACG,GAAR,CAAYE,eAAZ,EAAoB,MAApB;AACD,GALS,CAAV;AAOAC,EAAAA,SAAS,CAAC,YAAY;AACpBN,IAAAA,OAAO,CAACO,OAAR;AACD,GAFQ,CAAT;AAIAC,EAAAA,EAAE,CAAC,4CAAD,EAA+C,kBAAkB;AACjE,UAAMT,CAAC,CAACU,aAAF,CAAgB;AACpBC,MAAAA,UAAU,EAAE,CAAC,EAAD;AADQ,KAAhB,EAEHC,MAFG,CAEIC,UAFJ,CAEeC,EAFf,CAEkBC,YAFlB,CAE+BC,YAAOC,sBAFtC,EAE8D,cAF9D,CAAN;AAGD,GAJC,CAAF;AAOAR,EAAAA,EAAE,CAAC,6BAAD,EAAgC,kBAAkB;AAClD,UAAMT,CAAC,CAACU,aAAF,CAAgB;AACpBQ,MAAAA,WAAW,EAAE;AACX,6BAAqB;AADV;AADO,KAAhB,EAIHN,MAJG,CAIIC,UAJJ,CAIeC,EAJf,CAIkBC,YAJlB,CAI+BC,YAAOC,sBAJtC,EAI8D,cAJ9D,CAAN;AAKD,GANC,CAAF;AAQAR,EAAAA,EAAE,CAAC,iCAAD,EAAoC,kBAAkB;AACtD,UAAMT,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,MAAAA,WAAW,EAAE;AACX,6BAAqB,UADV;AAEXC,QAAAA,YAAY,EAAE;AAFH;AADmB,KAA5B,EAKHP,MALG,CAKIC,UALJ,CAKeC,EALf,CAKkBM,SALxB;AAMD,GAPC,CAAF;AASAX,EAAAA,EAAE,CAAC,sDAAD,EAAyD,kBAAkB;AAC3ET,IAAAA,CAAC,CAACqB,qBAAF,GAA0B;AACxBC,MAAAA,SAAS,EAAE;AACTC,QAAAA,QAAQ,EAAE;AADD,OADa;AAIxBC,MAAAA,MAAM,EAAE;AACND,QAAAA,QAAQ,EAAE,IADJ;AAENE,QAAAA,QAAQ,EAAE,IAFJ;AAGNC,QAAAA,SAAS,EAAE,CAAC,UAAD,EAAa,UAAb;AAHL;AAJgB,KAA1B;AAWA,UAAM1B,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,MAAAA,WAAW,EAAE;AACX,wBAAgB,KADL;AAEX,6BAAqB;AAFV;AADmB,KAA5B,EAKHN,MALG,CAKIC,UALJ,CAKeC,EALf,CAKkBC,YALlB,CAK+BC,YAAOC,sBALtC,EAK8D,mBAL9D,CAAN;AAMD,GAlBC,CAAF;AAoBAR,EAAAA,EAAE,CAAC,sDAAD,EAAyD,kBAAkB;AAC3ET,IAAAA,CAAC,CAACqB,qBAAF,GAA0B;AACxBC,MAAAA,SAAS,EAAE;AACTC,QAAAA,QAAQ,EAAE;AADD,OADa;AAIxBC,MAAAA,MAAM,EAAE;AACND,QAAAA,QAAQ,EAAE,IADJ;AAENE,QAAAA,QAAQ,EAAE,IAFJ;AAGNC,QAAAA,SAAS,EAAE,CAAC,UAAD,EAAa,UAAb;AAHL;AAJgB,KAA1B;AAWA,UAAM1B,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,MAAAA,WAAW,EAAE;AACX,4BAAoB;AADT;AADmB,KAA5B,EAIHN,MAJG,CAIIC,UAJJ,CAIeC,EAJf,CAIkBC,YAJlB,CAI+BC,YAAOC,sBAJtC,EAI8D,cAJ9D,CAAN;AAKD,GAjBC,CAAF;AAmBAR,EAAAA,EAAE,CAAC,kCAAD,EAAqC,kBAAkB;AACvD,UAAMT,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,MAAAA,WAAW,EAAE;AACX,wBAAgB,KADL;AAEX,6BAAqB,UAFV;AAGX,wBAAgB,QAHL;AAIX,2BAAmB;AAJR;AADmB,KAA5B,EAOHN,MAPG,CAOIC,UAPJ,CAOeC,EAPf,CAOkBM,SAPxB;AAQD,GATC,CAAF;AAWAX,EAAAA,EAAE,CAAC,kCAAD,EAAqC,kBAAkB;AACvD,SAAKkB,OAAL,CAAa,GAAb;AAEA,UAAM3B,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,MAAAA,WAAW,EAAE;AACX,wBAAgB,KADL;AAEX,6BAAqB,UAFV;AAGX,wBAAgB,QAHL;AAIX,2BAAmB;AAJR;AADmB,KAA5B,CAAN;AASAlB,IAAAA,CAAC,CAACK,GAAF,CAAMuB,IAAN,CAAWhB,MAAX,CAAkBiB,IAAlB,CAAuBC,IAAvB,CAA4BC,MAA5B;AACD,GAbC,CAAF;AAeAtB,EAAAA,EAAE,CAAC,yCAAD,EAA4C,kBAAkB;AAC9D,UAAMT,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,MAAAA,WAAW,EAAE;AACX,wBAAgB,KADL;AAEX,6BAAqB;AAFV;AADmB,KAA5B,EAKHN,MALG,CAKIC,UALJ,CAKeC,EALf,CAKkBC,YALlB,CAK+BC,YAAOC,sBALtC,EAK8D,cAL9D,CAAN;AAMD,GAPC,CAAF;AASAlB,EAAAA,QAAQ,CAAC,sBAAD,EAAyB,YAAY;AAC3CU,IAAAA,EAAE,CAAC,+BAAD,EAAkC,kBAAkB;AACpD,YAAMT,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,QAAAA,WAAW,EAAE;AACX,0BAAgB,KADL;AAEX,+BAAqB,UAFV;AAGX,4BAAkB;AAHP;AADmB,OAA5B,CAAN;AAOAlB,MAAAA,CAAC,CAACK,GAAF,CAAMuB,IAAN,CAAWhB,MAAX,CAAkBiB,IAAlB,CAAuBC,IAAvB,CAA4BC,MAA5B;AAEA,UAAIC,QAAQ,GAAG,MAAMhC,CAAC,CAACiC,WAAF,EAArB;AACAD,MAAAA,QAAQ,CAAC,CAAD,CAAR,CAAYE,YAAZ,CAAyBC,OAAzB,CAAiCvB,MAAjC,CAAwCwB,GAAxC,CAA4C,KAA5C;AACD,KAZC,CAAF;AAcA3B,IAAAA,EAAE,CAAC,8BAAD,EAAiC,kBAAkB;AACnD,YAAMT,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,QAAAA,WAAW,EAAE;AACX,0BAAgB,KADL;AAEX,+BAAqB,UAFV;AAGX,4BAAkB;AAHP;AADmB,OAA5B,CAAN;AAOAlB,MAAAA,CAAC,CAACK,GAAF,CAAMuB,IAAN,CAAWhB,MAAX,CAAkBiB,IAAlB,CAAuBC,IAAvB,CAA4BC,MAA5B;AAEA,UAAIC,QAAQ,GAAG,MAAMhC,CAAC,CAACiC,WAAF,EAArB;AACAD,MAAAA,QAAQ,CAAC,CAAD,CAAR,CAAYE,YAAZ,CAAyBC,OAAzB,CAAiCvB,MAAjC,CAAwCwB,GAAxC,CAA4C,IAA5C;AACD,KAZC,CAAF;AAcA3B,IAAAA,EAAE,CAAC,qDAAD,EAAwD,kBAAkB;AAC1E,YAAMT,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,QAAAA,WAAW,EAAE;AACX,0BAAgB,KADL;AAEX,+BAAqB,UAFV;AAGX,6BAAmB;AAHR;AADmB,OAA5B,CAAN;AAOAlB,MAAAA,CAAC,CAACK,GAAF,CAAMuB,IAAN,CAAWhB,MAAX,CAAkByB,GAAlB,CAAsBR,IAAtB,CAA2BC,IAA3B,CAAgCC,MAAhC;AAEA,UAAIC,QAAQ,GAAG,MAAMhC,CAAC,CAACiC,WAAF,EAArB;AACAD,MAAAA,QAAQ,CAAC,CAAD,CAAR,CAAYE,YAAZ,CAAyBI,QAAzB,CAAkC1B,MAAlC,CAAyCwB,GAAzC,CAA6C,MAA7C;AACD,KAZC,CAAF;AAaD,GA1CO,CAAR;AA4CArC,EAAAA,QAAQ,CAAC,qBAAD,EAAwB,YAAY;AAC1CU,IAAAA,EAAE,CAAC,2BAAD,EAA8B,kBAAkB;AAChD,YAAMT,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,QAAAA,WAAW,EAAE;AACX,0BAAgB,KADL;AAEX,+BAAqB,UAFV;AAGX,sCAA4B;AAHjB;AADmB,OAA5B,CAAN;AAOAlB,MAAAA,CAAC,CAACK,GAAF,CAAMuB,IAAN,CAAWhB,MAAX,CAAkBiB,IAAlB,CAAuBC,IAAvB,CAA4BC,MAA5B;AAEA,UAAIC,QAAQ,GAAG,MAAMhC,CAAC,CAACiC,WAAF,EAArB;AACAD,MAAAA,QAAQ,CAAC,CAAD,CAAR,CAAYE,YAAZ,CAAyBK,iBAAzB,CAA2C3B,MAA3C,CAAkDwB,GAAlD,CAAsD,CAAtD;AACD,KAZC,CAAF;AAcA3B,IAAAA,EAAE,CAAC,6BAAD,EAAgC,kBAAkB;AAClD,YAAMT,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,QAAAA,WAAW,EAAE;AACX,0BAAgB,KADL;AAEX,+BAAqB,UAFV;AAGX,sCAA4B;AAHjB;AADmB,OAA5B,CAAN;AAOAlB,MAAAA,CAAC,CAACK,GAAF,CAAMuB,IAAN,CAAWhB,MAAX,CAAkBiB,IAAlB,CAAuBC,IAAvB,CAA4BC,MAA5B;AAEA,UAAIC,QAAQ,GAAG,MAAMhC,CAAC,CAACiC,WAAF,EAArB;AACAD,MAAAA,QAAQ,CAAC,CAAD,CAAR,CAAYE,YAAZ,CAAyBK,iBAAzB,CAA2C3B,MAA3C,CAAkDwB,GAAlD,CAAsD,GAAtD;AACD,KAZC,CAAF;AAcA3B,IAAAA,EAAE,CAAC,kDAAD,EAAqD,kBAAkB;AACvE,YAAMT,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,QAAAA,WAAW,EAAE;AACX,0BAAgB,KADL;AAEX,+BAAqB,UAFV;AAGX,6BAAmB;AAHR;AADmB,OAA5B,CAAN;AAOAlB,MAAAA,CAAC,CAACK,GAAF,CAAMuB,IAAN,CAAWhB,MAAX,CAAkByB,GAAlB,CAAsBR,IAAtB,CAA2BC,IAA3B,CAAgCC,MAAhC;AAEA,UAAIC,QAAQ,GAAG,MAAMhC,CAAC,CAACiC,WAAF,EAArB;AACAD,MAAAA,QAAQ,CAAC,CAAD,CAAR,CAAYE,YAAZ,CAAyBI,QAAzB,CAAkC1B,MAAlC,CAAyCwB,GAAzC,CAA6C,GAA7C;AACD,KAZC,CAAF;AAaD,GA1CO,CAAR;AA4CA3B,EAAAA,EAAE,CAAE,iCAAF,EAAqC,kBAAkB;AACvD,UAAMT,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,MAAAA,WAAW,EAAE;AACX,wBAAgB;AAACsB,UAAAA,CAAC,EAAE;AAAJ,SADL;AAEX,6BAAqB;AAFV;AADmB,KAA5B,EAKH5B,MALG,CAKIC,UALJ,CAKeC,EALf,CAKkBC,YALlB,CAK+BC,YAAOC,sBALtC,EAK8D,eAL9D,CAAN;AAMD,GAPC,CAAF;AASAR,EAAAA,EAAE,CAAC,kCAAD,EAAqC,kBAAkB;AACvD,SAAKkB,OAAL,CAAa,GAAb;AAEA3B,IAAAA,CAAC,CAACqB,qBAAF,GAA0B;AACxB,sBAAgB;AACdoB,QAAAA,UAAU,EAAE;AADE;AADQ,KAA1B;AAMA,UAAMzC,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,MAAAA,WAAW,EAAE;AACX,wBAAgB,KADL;AAEX,6BAAqB,UAFV;AAGX,+BAAuB;AAHZ;AADmB,KAA5B,CAAN;AAQAZ,oBAAOsB,IAAP,CAAYhB,MAAZ,CAAmBiB,IAAnB,CAAwBC,IAAxB,CAA6BC,MAA7B;AACD,GAlBC,CAAF;AAoBAtB,EAAAA,EAAE,CAAC,qCAAD,EAAwC,kBAAkB;AAC1D,SAAKkB,OAAL,CAAa,GAAb;AAEA3B,IAAAA,CAAC,CAACqB,qBAAF,GAA0B;AACxB,sBAAgB;AACdoB,QAAAA,UAAU,EAAE;AADE;AADQ,KAA1B;AAMA,UAAMzC,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,MAAAA,WAAW,EAAE;AACX,wBAAgB,KADL;AAEX,6BAAqB,UAFV;AAGX,+BAAuB;AAHZ;AADmB,KAA5B,CAAN;AAQAlB,IAAAA,CAAC,CAACK,GAAF,CAAMuB,IAAN,CAAWhB,MAAX,CAAkByB,GAAlB,CAAsBR,IAAtB,CAA2BC,IAA3B,CAAgCC,MAAhC;AACD,GAlBC,CAAF;AAoBAtB,EAAAA,EAAE,CAAC,iDAAD,EAAoD,kBAAkB;AACtET,IAAAA,CAAC,CAACqB,qBAAF,GAA0B;AACxB,aAAO;AACLI,QAAAA,QAAQ,EAAE;AADL;AADiB,KAA1B;;AAMA,QAAI;AACF,YAAMzB,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,QAAAA,WAAW,EAAE;AACXC,UAAAA,YAAY,EAAE,KADH;AAEX,+BAAqB,MAFV;AAGX,wBAAc;AAHH;AADmB,OAA5B,CAAN;AAOD,KARD,SAQU;AACR,YAAMnB,CAAC,CAAC0C,aAAF,EAAN;AACD;;AAED,UAAM1C,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,MAAAA,WAAW,EAAE;AACXC,QAAAA,YAAY,EAAE,KADH;AAEX,6BAAqB,MAFV;AAGX,sBAAc;AAHH;AADmB,KAA5B,EAMHP,MANG,CAMIC,UANJ,CAMeC,EANf,CAMkBC,YANlB,CAM+B,8BAN/B,CAAN;;AAQA,QAAI;AACF,YAAMf,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,QAAAA,WAAW,EAAE;AACXC,UAAAA,YAAY,EAAE,KADH;AAEX,+BAAqB,MAFV;AAGX,wBAAcwB;AAHH;AADmB,OAA5B,CAAN;AAOD,KARD,SAQU;AACR,YAAM3C,CAAC,CAAC0C,aAAF,EAAN;AACD;;AAED,QAAI;AACF,YAAM1C,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,QAAAA,WAAW,EAAE;AACXC,UAAAA,YAAY,EAAE,KADH;AAEX,+BAAqB,MAFV;AAGX,wBAAc;AAHH;AADmB,OAA5B,CAAN;AAOD,KARD,SAQU;AACR,YAAMnB,CAAC,CAAC0C,aAAF,EAAN;AACD;AACF,GAlDC,CAAF;AAoDAjC,EAAAA,EAAE,CAAC,4EAAD,EAA+E,kBAAkB;AACjGT,IAAAA,CAAC,CAACqB,qBAAF,GAA0B;AACxBuB,MAAAA,GAAG,EAAE;AACHrB,QAAAA,QAAQ,EAAE;AADP;AADmB,KAA1B;AAMA,UAAMvB,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAChCQ,MAAAA,WAAW,EAAE;AACXC,QAAAA,YAAY,EAAE,KADH;AAEX,6BAAqB,MAFV;AAGX,sBAAc;AAHH;AADmB,KAA5B,EAMHP,MANG,CAMIC,UANJ,CAMeC,EANf,CAMkBC,YANlB,CAM+B,OAN/B,CAAN;AAQA,UAAMf,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB;AAC1BQ,MAAAA,WAAW,EAAE;AACXC,QAAAA,YAAY,EAAE,KADH;AAEX,6BAAqB,MAFV;AAGX,sBAAc;AAHH;AADa,KAAtB,EAMHP,MANG,CAMIC,UANJ,CAMeC,EANf,CAMkBC,YANlB,CAM+B,OAN/B,CAAN;AAQA,UAAMf,CAAC,CAACU,aAAF,CAAgB;AACpBC,MAAAA,UAAU,EAAE,CAAC;AACXQ,QAAAA,YAAY,EAAE,KADH;AAEX,6BAAqB,MAFV;AAGX,sBAAc;AAHH,OAAD;AADQ,KAAhB,EAMHP,MANG,CAMIC,UANJ,CAMeC,EANf,CAMkBC,YANlB,CAM+B,OAN/B,CAAN;AAQA,UAAMf,CAAC,CAACU,aAAF,CAAgB;AACpBQ,MAAAA,WAAW,EAAE;AACXC,QAAAA,YAAY,EAAE,KADH;AAEX,6BAAqB,MAFV;AAGX,sBAAc;AAHH;AADO,KAAhB,EAMHP,MANG,CAMIC,UANJ,CAMeC,EANf,CAMkBC,YANlB,CAM+B,OAN/B,CAAN;AAQA,UAAMf,CAAC,CAACU,aAAF,CAAgB;AACpBQ,MAAAA,WAAW,EAAE;AACXC,QAAAA,YAAY,EAAE,KADH;AAEX,6BAAqB,MAFV;AAGX,sBAAc;AAHH;AADO,KAAhB,EAMHP,MANG,CAMIC,UANJ,CAMeC,EANf,CAMkBC,YANlB,CAM+B,OAN/B,CAAN;AAOD,GA9CC,CAAF;AAgDAhB,EAAAA,QAAQ,CAAC,KAAD,EAAQ,YAAY;AAC1BU,IAAAA,EAAE,CAAC,gCAAD,EAAmC,kBAAkB;AACrD,YAAM,CAACoC,SAAD,EAAYC,IAAZ,IAAoB,MAAM9C,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B;AAC1DQ,QAAAA,WAAW,EAAE;AACXC,UAAAA,YAAY,EAAE,KADH;AAEX,+BAAqB;AAFV,SAD6C;AAIvDR,QAAAA,UAAU,EAAE,CAAC,EAAD;AAJ2C,OAA5B,CAAhC;;AAMA,UAAI;AACFkC,QAAAA,SAAS,CAACjC,MAAV,CAAiBmC,KAAjB;AACAD,QAAAA,IAAI,CAAClC,MAAL,CAAYwB,GAAZ,CAAgB;AACdjB,UAAAA,YAAY,EAAE,KADA;AAEd6B,UAAAA,UAAU,EAAE;AAFE,SAAhB;AAID,OAND,SAMU;AACR,cAAMhD,CAAC,CAAC0C,aAAF,EAAN;AACD;AACF,KAhBC,CAAF;AAkBAjC,IAAAA,EAAE,CAAC,sEAAD,EAAyE,kBAAkB;AAC3F,YAAMwC,UAAU,GAAG,CAAC,IAAD,EAAO,QAAP,EAAiB,EAAjB,EAAqB,GAArB,CAAnB;AAEA,YAAMC,kBAAEC,GAAF,CAAMF,UAAN,EAAmBG,GAAD,IAASpD,CAAC,CAACU,aAAF,CAAgB,IAAhB,EAAsB,IAAtB,EAA4B0C,GAA5B,EAAiCxC,MAAjC,CAAwCC,UAAxC,CAAmDC,EAAnD,CAAsDC,YAAtD,CAAmEC,YAAOC,sBAA1E,CAA3B,CAAN;AACD,KAJC,CAAF;AAKD,GAxBO,CAAR;AAyBD,CAvXO,CAAR","sourcesContent":["// @ts-check\n\nimport B from 'bluebird';\nimport { default as BaseDriver, errors } from '../../../lib';\nimport logger from '../../../lib/basedriver/logger';\nimport { createSandbox } from 'sinon';\n\ndescribe('Desired Capabilities', function () {\n  let d;\n  let sandbox;\n\n  beforeEach(function () {\n    d = new BaseDriver();\n    sandbox = createSandbox();\n    sandbox.spy(d.log, 'warn');\n    sandbox.spy(logger, 'warn');\n  });\n\n  afterEach(function () {\n    sandbox.restore();\n  });\n\n  it('should require platformName and deviceName', async function () {\n    await d.createSession({\n      firstMatch: [{}]\n    }).should.eventually.be.rejectedWith(errors.SessionNotCreatedError, /platformName/);\n  });\n\n\n  it('should require platformName', async function () {\n    await d.createSession({\n      alwaysMatch: {\n        'appium:deviceName': 'Delorean'\n      }\n    }).should.eventually.be.rejectedWith(errors.SessionNotCreatedError, /platformName/);\n  });\n\n  it('should not care about cap order', async function () {\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        'appium:deviceName': 'Delorean',\n        platformName: 'iOS'\n      }\n    }).should.eventually.be.fulfilled;\n  });\n\n  it('should check required caps which are added to driver', async function () {\n    d.desiredCapConstraints = {\n      necessary: {\n        presence: true\n      },\n      proper: {\n        presence: true,\n        isString: true,\n        inclusion: ['Delorean', 'Reventon']\n      }\n    };\n\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        'platformName': 'iOS',\n        'appium:deviceName': 'Delorean'\n      }\n    }).should.eventually.be.rejectedWith(errors.SessionNotCreatedError, /necessary.*proper/);\n  });\n\n  it('should check added required caps in addition to base', async function () {\n    d.desiredCapConstraints = {\n      necessary: {\n        presence: true\n      },\n      proper: {\n        presence: true,\n        isString: true,\n        inclusion: ['Delorean', 'Reventon']\n      }\n    };\n\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        'appium:necessary': 'yup'\n      }\n    }).should.eventually.be.rejectedWith(errors.SessionNotCreatedError, /platformName/);\n  });\n\n  it('should accept extra capabilities', async function () {\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        'platformName': 'iOS',\n        'appium:deviceName': 'Delorean',\n        'appium:extra': 'cheese',\n        'appium:hold the': 'sauce'\n      }\n    }).should.eventually.be.fulfilled;\n  });\n\n  it('should log the use of extra caps', async function () {\n    this.timeout(500);\n\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        'platformName': 'iOS',\n        'appium:deviceName': 'Delorean',\n        'appium:extra': 'cheese',\n        'appium:hold the': 'sauce'\n      }\n    });\n\n    d.log.warn.should.have.been.called;\n  });\n\n  it('should be sensitive to the case of caps', async function () {\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        'platformname': 'iOS',\n        'appium:deviceName': 'Delorean'\n      }\n    }).should.eventually.be.rejectedWith(errors.SessionNotCreatedError, /platformName/);\n  });\n\n  describe('boolean capabilities', function () {\n    it('should allow a string \"false\"', async function () {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          'platformName': 'iOS',\n          'appium:deviceName': 'Delorean',\n          'appium:noReset': 'false'\n        }\n      });\n      d.log.warn.should.have.been.called;\n\n      let sessions = await d.getSessions();\n      sessions[0].capabilities.noReset.should.eql(false);\n    });\n\n    it('should allow a string \"true\"', async function () {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          'platformName': 'iOS',\n          'appium:deviceName': 'Delorean',\n          'appium:noReset': 'true'\n        }\n      });\n      d.log.warn.should.have.been.called;\n\n      let sessions = await d.getSessions();\n      sessions[0].capabilities.noReset.should.eql(true);\n    });\n\n    it('should allow a string \"true\" in string capabilities', async function () {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          'platformName': 'iOS',\n          'appium:deviceName': 'Delorean',\n          'appium:language': 'true'\n        }\n      });\n      d.log.warn.should.not.have.been.called;\n\n      let sessions = await d.getSessions();\n      sessions[0].capabilities.language.should.eql('true');\n    });\n  });\n\n  describe('number capabilities', function () {\n    it('should allow a string \"1\"', async function () {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          'platformName': 'iOS',\n          'appium:deviceName': 'Delorean',\n          'appium:newCommandTimeout': '1'\n        }\n      });\n      d.log.warn.should.have.been.called;\n\n      let sessions = await d.getSessions();\n      sessions[0].capabilities.newCommandTimeout.should.eql(1);\n    });\n\n    it('should allow a string \"1.1\"', async function () {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          'platformName': 'iOS',\n          'appium:deviceName': 'Delorean',\n          'appium:newCommandTimeout': '1.1'\n        }\n      });\n      d.log.warn.should.have.been.called;\n\n      let sessions = await d.getSessions();\n      sessions[0].capabilities.newCommandTimeout.should.eql(1.1);\n    });\n\n    it('should allow a string \"1\" in string capabilities', async function () {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          'platformName': 'iOS',\n          'appium:deviceName': 'Delorean',\n          'appium:language': '1'\n        }\n      });\n      d.log.warn.should.not.have.been.called;\n\n      let sessions = await d.getSessions();\n      sessions[0].capabilities.language.should.eql('1');\n    });\n  });\n\n  it ('should error if objects in caps', async function () {\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        'platformName': {a: 'iOS'},\n        'appium:deviceName': 'Delorean'\n      }\n    }).should.eventually.be.rejectedWith(errors.SessionNotCreatedError, /platformName/i);\n  });\n\n  it('should check for deprecated caps', async function () {\n    this.timeout(500);\n\n    d.desiredCapConstraints = {\n      'lynx-version': {\n        deprecated: true\n      }\n    };\n\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        'platformName': 'iOS',\n        'appium:deviceName': 'Delorean',\n        'appium:lynx-version': 5\n      }\n    });\n\n    logger.warn.should.have.been.called;\n  });\n\n  it('should not warn if deprecated=false', async function () {\n    this.timeout(500);\n\n    d.desiredCapConstraints = {\n      'lynx-version': {\n        deprecated: false\n      }\n    };\n\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        'platformName': 'iOS',\n        'appium:deviceName': 'Delorean',\n        'appium:lynx-version': 5\n      }\n    });\n\n    d.log.warn.should.not.have.been.called;\n  });\n\n  it('should not validate against null/undefined caps', async function () {\n    d.desiredCapConstraints = {\n      'foo': {\n        isString: true\n      }\n    };\n\n    try {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          platformName: 'iOS',\n          'appium:deviceName': 'Dumb',\n          'appium:foo': null\n        }\n      });\n    } finally {\n      await d.deleteSession();\n    }\n\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        platformName: 'iOS',\n        'appium:deviceName': 'Dumb',\n        'appium:foo': 1\n      }\n    }).should.eventually.be.rejectedWith(/'foo' must be of type string/);\n\n    try {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          platformName: 'iOS',\n          'appium:deviceName': 'Dumb',\n          'appium:foo': undefined\n        }\n      });\n    } finally {\n      await d.deleteSession();\n    }\n\n    try {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          platformName: 'iOS',\n          'appium:deviceName': 'Dumb',\n          'appium:foo': ''\n        }\n      });\n    } finally {\n      await d.deleteSession();\n    }\n  });\n\n  it('should still validate null/undefined/empty caps whose presence is required', async function () {\n    d.desiredCapConstraints = {\n      foo: {\n        presence: true\n      },\n    };\n\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        platformName: 'iOS',\n        'appium:deviceName': 'Dumb',\n        'appium:foo': null\n      }\n    }).should.eventually.be.rejectedWith(/blank/);\n\n    await d.createSession(null, {\n      alwaysMatch: {\n        platformName: 'iOS',\n        'appium:deviceName': 'Dumb',\n        'appium:foo': ''\n      }\n    }).should.eventually.be.rejectedWith(/blank/);\n\n    await d.createSession({\n      firstMatch: [{\n        platformName: 'iOS',\n        'appium:deviceName': 'Dumb',\n        'appium:foo': {}\n      }]\n    }).should.eventually.be.rejectedWith(/blank/);\n\n    await d.createSession({\n      alwaysMatch: {\n        platformName: 'iOS',\n        'appium:deviceName': 'Dumb',\n        'appium:foo': []\n      }\n    }).should.eventually.be.rejectedWith(/blank/);\n\n    await d.createSession({\n      alwaysMatch: {\n        platformName: 'iOS',\n        'appium:deviceName': 'Dumb',\n        'appium:foo': '  '\n      }\n    }).should.eventually.be.rejectedWith(/blank/);\n  });\n\n  describe('w3c', function () {\n    it('should accept w3c capabilities', async function () {\n      const [sessionId, caps] = await d.createSession(null, null, {\n        alwaysMatch: {\n          platformName: 'iOS',\n          'appium:deviceName': 'Delorean'\n        }, firstMatch: [{}],\n      });\n      try {\n        sessionId.should.exist;\n        caps.should.eql({\n          platformName: 'iOS',\n          deviceName: 'Delorean',\n        });\n      } finally {\n        await d.deleteSession();\n      }\n    });\n\n    it('should raise an error if w3c capabilities is not a plain JSON object', async function () {\n      const testValues = [true, 'string', [], 100];\n      // this loop runs in parallel, and does not guarantee all assertions will be made\n      await B.map(testValues, (val) => d.createSession(null, null, val).should.eventually.be.rejectedWith(errors.SessionNotCreatedError));\n    });\n  });\n});\n"]}
@@ -0,0 +1,110 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ require("source-map-support/register");
6
+
7
+ var _lodash = _interopRequireDefault(require("lodash"));
8
+
9
+ var _lib = require("../../../../lib");
10
+
11
+ describe('logging custom events', function () {
12
+ it('should allow logging of events', async function () {
13
+ const d = new _lib.BaseDriver();
14
+
15
+ d._eventHistory.should.eql({
16
+ commands: []
17
+ });
18
+
19
+ await d.logCustomEvent('myorg', 'myevent');
20
+
21
+ _lodash.default.keys(d._eventHistory).should.eql(['commands', 'myorg:myevent']);
22
+ });
23
+ it('should get all events including custom ones', async function () {
24
+ const d = new _lib.BaseDriver();
25
+
26
+ d._eventHistory.should.eql({
27
+ commands: []
28
+ });
29
+
30
+ d.logEvent('appiumEvent');
31
+ await d.logCustomEvent('myorg', 'myevent');
32
+ const events = await d.getLogEvents();
33
+
34
+ _lodash.default.keys(events).should.eql(['commands', 'appiumEvent', 'myorg:myevent']);
35
+ });
36
+ });
37
+ describe('#getLogEvents', function () {
38
+ it('should allow to get all events', async function () {
39
+ const d = new _lib.BaseDriver();
40
+
41
+ d._eventHistory.should.eql({
42
+ commands: []
43
+ });
44
+
45
+ d._eventHistory.testCommand = ['1', '2', '3'];
46
+ await d.getLogEvents().should.eql({
47
+ commands: [],
48
+ testCommand: ['1', '2', '3']
49
+ });
50
+ });
51
+ it('should filter with testCommand', async function () {
52
+ const d = new _lib.BaseDriver();
53
+
54
+ d._eventHistory.should.eql({
55
+ commands: []
56
+ });
57
+
58
+ d._eventHistory.testCommand = ['1', '2', '3'];
59
+ await d.getLogEvents('testCommand').should.eql({
60
+ testCommand: ['1', '2', '3']
61
+ });
62
+ });
63
+ it('should not filter with wrong but can be a part of the event name', async function () {
64
+ const d = new _lib.BaseDriver();
65
+
66
+ d._eventHistory.should.eql({
67
+ commands: []
68
+ });
69
+
70
+ d._eventHistory.testCommand = ['1', '2', '3'];
71
+ await d.getLogEvents('testCommandDummy').should.eql({});
72
+ });
73
+ it('should filter with multiple event keys', async function () {
74
+ const d = new _lib.BaseDriver();
75
+
76
+ d._eventHistory.should.eql({
77
+ commands: []
78
+ });
79
+
80
+ d._eventHistory.testCommand = ['1', '2', '3'];
81
+ d._eventHistory.testCommand2 = ['4', '5'];
82
+ await d.getLogEvents(['testCommand', 'testCommand2']).should.eql({
83
+ testCommand: ['1', '2', '3'],
84
+ testCommand2: ['4', '5']
85
+ });
86
+ });
87
+ it('should filter with custom events', async function () {
88
+ const d = new _lib.BaseDriver();
89
+
90
+ d._eventHistory.should.eql({
91
+ commands: []
92
+ });
93
+
94
+ d._eventHistory['custom:appiumEvent'] = ['1', '2', '3'];
95
+ await d.getLogEvents(['custom:appiumEvent']).should.eql({
96
+ 'custom:appiumEvent': ['1', '2', '3']
97
+ });
98
+ });
99
+ it('should not filter with no existed event name', async function () {
100
+ const d = new _lib.BaseDriver();
101
+
102
+ d._eventHistory.should.eql({
103
+ commands: []
104
+ });
105
+
106
+ d._eventHistory.testCommand = ['1', '2', '3'];
107
+ await d.getLogEvents(['noEventName']).should.eql({});
108
+ });
109
+ });
110
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../test/unit/basedriver/commands/event.spec.js"],"names":["describe","it","d","BaseDriver","_eventHistory","should","eql","commands","logCustomEvent","_","keys","logEvent","events","getLogEvents","testCommand","testCommand2"],"mappings":";;;;;;AAAA;;AACA;;AAIAA,QAAQ,CAAC,uBAAD,EAA0B,YAAY;AAC5CC,EAAAA,EAAE,CAAC,gCAAD,EAAmC,kBAAkB;AACrD,UAAMC,CAAC,GAAG,IAAIC,eAAJ,EAAV;;AACAD,IAAAA,CAAC,CAACE,aAAF,CAAgBC,MAAhB,CAAuBC,GAAvB,CAA2B;AAACC,MAAAA,QAAQ,EAAE;AAAX,KAA3B;;AACA,UAAML,CAAC,CAACM,cAAF,CAAiB,OAAjB,EAA0B,SAA1B,CAAN;;AACAC,oBAAEC,IAAF,CAAOR,CAAC,CAACE,aAAT,EAAwBC,MAAxB,CAA+BC,GAA/B,CAAmC,CAAC,UAAD,EAAa,eAAb,CAAnC;AACD,GALC,CAAF;AAMAL,EAAAA,EAAE,CAAC,6CAAD,EAAgD,kBAAkB;AAClE,UAAMC,CAAC,GAAG,IAAIC,eAAJ,EAAV;;AACAD,IAAAA,CAAC,CAACE,aAAF,CAAgBC,MAAhB,CAAuBC,GAAvB,CAA2B;AAACC,MAAAA,QAAQ,EAAE;AAAX,KAA3B;;AACAL,IAAAA,CAAC,CAACS,QAAF,CAAW,aAAX;AACA,UAAMT,CAAC,CAACM,cAAF,CAAiB,OAAjB,EAA0B,SAA1B,CAAN;AACA,UAAMI,MAAM,GAAG,MAAMV,CAAC,CAACW,YAAF,EAArB;;AACAJ,oBAAEC,IAAF,CAAOE,MAAP,EAAeP,MAAf,CAAsBC,GAAtB,CAA0B,CAAC,UAAD,EAAa,aAAb,EAA4B,eAA5B,CAA1B;AACD,GAPC,CAAF;AAQD,CAfO,CAAR;AAiBAN,QAAQ,CAAC,eAAD,EAAkB,YAAY;AACpCC,EAAAA,EAAE,CAAC,gCAAD,EAAmC,kBAAkB;AACrD,UAAMC,CAAC,GAAG,IAAIC,eAAJ,EAAV;;AACAD,IAAAA,CAAC,CAACE,aAAF,CAAgBC,MAAhB,CAAuBC,GAAvB,CAA2B;AAACC,MAAAA,QAAQ,EAAE;AAAX,KAA3B;;AACAL,IAAAA,CAAC,CAACE,aAAF,CAAgBU,WAAhB,GAA8B,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX,CAA9B;AACA,UAAMZ,CAAC,CAACW,YAAF,GAAiBR,MAAjB,CAAwBC,GAAxB,CAA4B;AAChCC,MAAAA,QAAQ,EAAE,EADsB;AAClBO,MAAAA,WAAW,EAAE,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX;AADK,KAA5B,CAAN;AAGD,GAPC,CAAF;AASAb,EAAAA,EAAE,CAAC,gCAAD,EAAmC,kBAAkB;AACrD,UAAMC,CAAC,GAAG,IAAIC,eAAJ,EAAV;;AACAD,IAAAA,CAAC,CAACE,aAAF,CAAgBC,MAAhB,CAAuBC,GAAvB,CAA2B;AAACC,MAAAA,QAAQ,EAAE;AAAX,KAA3B;;AACAL,IAAAA,CAAC,CAACE,aAAF,CAAgBU,WAAhB,GAA8B,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX,CAA9B;AACA,UAAMZ,CAAC,CAACW,YAAF,CAAe,aAAf,EAA8BR,MAA9B,CAAqCC,GAArC,CAAyC;AAC7CQ,MAAAA,WAAW,EAAE,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX;AADgC,KAAzC,CAAN;AAGD,GAPC,CAAF;AASAb,EAAAA,EAAE,CAAC,kEAAD,EAAqE,kBAAkB;AACvF,UAAMC,CAAC,GAAG,IAAIC,eAAJ,EAAV;;AACAD,IAAAA,CAAC,CAACE,aAAF,CAAgBC,MAAhB,CAAuBC,GAAvB,CAA2B;AAACC,MAAAA,QAAQ,EAAE;AAAX,KAA3B;;AACAL,IAAAA,CAAC,CAACE,aAAF,CAAgBU,WAAhB,GAA8B,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX,CAA9B;AACA,UAAMZ,CAAC,CAACW,YAAF,CAAe,kBAAf,EAAmCR,MAAnC,CAA0CC,GAA1C,CAA8C,EAA9C,CAAN;AACD,GALC,CAAF;AAOAL,EAAAA,EAAE,CAAC,wCAAD,EAA2C,kBAAkB;AAC7D,UAAMC,CAAC,GAAG,IAAIC,eAAJ,EAAV;;AACAD,IAAAA,CAAC,CAACE,aAAF,CAAgBC,MAAhB,CAAuBC,GAAvB,CAA2B;AAACC,MAAAA,QAAQ,EAAE;AAAX,KAA3B;;AACAL,IAAAA,CAAC,CAACE,aAAF,CAAgBU,WAAhB,GAA8B,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX,CAA9B;AACAZ,IAAAA,CAAC,CAACE,aAAF,CAAgBW,YAAhB,GAA+B,CAAC,GAAD,EAAM,GAAN,CAA/B;AACA,UAAMb,CAAC,CAACW,YAAF,CAAe,CAAC,aAAD,EAAgB,cAAhB,CAAf,EAAgDR,MAAhD,CAAuDC,GAAvD,CAA2D;AAC/DQ,MAAAA,WAAW,EAAE,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX,CADkD;AACjCC,MAAAA,YAAY,EAAE,CAAC,GAAD,EAAM,GAAN;AADmB,KAA3D,CAAN;AAGD,GARC,CAAF;AAUAd,EAAAA,EAAE,CAAC,kCAAD,EAAqC,kBAAkB;AACvD,UAAMC,CAAC,GAAG,IAAIC,eAAJ,EAAV;;AACAD,IAAAA,CAAC,CAACE,aAAF,CAAgBC,MAAhB,CAAuBC,GAAvB,CAA2B;AAACC,MAAAA,QAAQ,EAAE;AAAX,KAA3B;;AACAL,IAAAA,CAAC,CAACE,aAAF,CAAgB,oBAAhB,IAAwC,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX,CAAxC;AACA,UAAMF,CAAC,CAACW,YAAF,CAAe,CAAC,oBAAD,CAAf,EAAuCR,MAAvC,CAA8CC,GAA9C,CAAkD;AACtD,4BAAsB,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX;AADgC,KAAlD,CAAN;AAGD,GAPC,CAAF;AASAL,EAAAA,EAAE,CAAC,8CAAD,EAAiD,kBAAkB;AACnE,UAAMC,CAAC,GAAG,IAAIC,eAAJ,EAAV;;AACAD,IAAAA,CAAC,CAACE,aAAF,CAAgBC,MAAhB,CAAuBC,GAAvB,CAA2B;AAACC,MAAAA,QAAQ,EAAE;AAAX,KAA3B;;AACAL,IAAAA,CAAC,CAACE,aAAF,CAAgBU,WAAhB,GAA8B,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX,CAA9B;AACA,UAAMZ,CAAC,CAACW,YAAF,CAAe,CAAC,aAAD,CAAf,EAAgCR,MAAhC,CAAuCC,GAAvC,CAA2C,EAA3C,CAAN;AACD,GALC,CAAF;AAMD,CAnDO,CAAR","sourcesContent":["import _ from 'lodash';\nimport { BaseDriver } from '../../../../lib';\n\n\n\ndescribe('logging custom events', function () {\n  it('should allow logging of events', async function () {\n    const d = new BaseDriver();\n    d._eventHistory.should.eql({commands: []});\n    await d.logCustomEvent('myorg', 'myevent');\n    _.keys(d._eventHistory).should.eql(['commands', 'myorg:myevent']);\n  });\n  it('should get all events including custom ones', async function () {\n    const d = new BaseDriver();\n    d._eventHistory.should.eql({commands: []});\n    d.logEvent('appiumEvent');\n    await d.logCustomEvent('myorg', 'myevent');\n    const events = await d.getLogEvents();\n    _.keys(events).should.eql(['commands', 'appiumEvent', 'myorg:myevent']);\n  });\n});\n\ndescribe('#getLogEvents', function () {\n  it('should allow to get all events', async function () {\n    const d = new BaseDriver();\n    d._eventHistory.should.eql({commands: []});\n    d._eventHistory.testCommand = ['1', '2', '3'];\n    await d.getLogEvents().should.eql({\n      commands: [], testCommand: ['1', '2', '3']\n    });\n  });\n\n  it('should filter with testCommand', async function () {\n    const d = new BaseDriver();\n    d._eventHistory.should.eql({commands: []});\n    d._eventHistory.testCommand = ['1', '2', '3'];\n    await d.getLogEvents('testCommand').should.eql({\n      testCommand: ['1', '2', '3']\n    });\n  });\n\n  it('should not filter with wrong but can be a part of the event name', async function () {\n    const d = new BaseDriver();\n    d._eventHistory.should.eql({commands: []});\n    d._eventHistory.testCommand = ['1', '2', '3'];\n    await d.getLogEvents('testCommandDummy').should.eql({});\n  });\n\n  it('should filter with multiple event keys', async function () {\n    const d = new BaseDriver();\n    d._eventHistory.should.eql({commands: []});\n    d._eventHistory.testCommand = ['1', '2', '3'];\n    d._eventHistory.testCommand2 = ['4', '5'];\n    await d.getLogEvents(['testCommand', 'testCommand2']).should.eql({\n      testCommand: ['1', '2', '3'], testCommand2: ['4', '5']\n    });\n  });\n\n  it('should filter with custom events', async function () {\n    const d = new BaseDriver();\n    d._eventHistory.should.eql({commands: []});\n    d._eventHistory['custom:appiumEvent'] = ['1', '2', '3'];\n    await d.getLogEvents(['custom:appiumEvent']).should.eql({\n      'custom:appiumEvent': ['1', '2', '3']\n    });\n  });\n\n  it('should not filter with no existed event name', async function () {\n    const d = new BaseDriver();\n    d._eventHistory.should.eql({commands: []});\n    d._eventHistory.testCommand = ['1', '2', '3'];\n    await d.getLogEvents(['noEventName']).should.eql({});\n  });\n});\n"]}
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ require("source-map-support/register");
6
+
7
+ var _log = _interopRequireDefault(require("../../../../lib/basedriver/commands/log"));
8
+
9
+ var _sinon = require("sinon");
10
+
11
+ var _lodash = _interopRequireDefault(require("lodash"));
12
+
13
+ const expect = chai.expect;
14
+ const FIRST_LOGS = ['first', 'logs'];
15
+ const SECOND_LOGS = ['second', 'logs'];
16
+ const SUPPORTED_LOG_TYPES = {
17
+ one: {
18
+ description: 'First logs',
19
+ getter: () => _lodash.default.clone(FIRST_LOGS)
20
+ },
21
+ two: {
22
+ description: 'Seconds logs',
23
+ getter: () => _lodash.default.clone(SECOND_LOGS)
24
+ }
25
+ };
26
+ describe('log commands -', function () {
27
+ let sandbox;
28
+ beforeEach(function () {
29
+ sandbox = (0, _sinon.createSandbox)();
30
+ _log.default.supportedLogTypes = {};
31
+ _log.default.log = {
32
+ debug: _lodash.default.noop
33
+ };
34
+ });
35
+ afterEach(function () {
36
+ sandbox.restore();
37
+ });
38
+ describe('getLogTypes', function () {
39
+ it('should return empty array when no supported log types', async function () {
40
+ (await _log.default.getLogTypes()).should.eql([]);
41
+ });
42
+ it('should return keys to log type object', async function () {
43
+ _log.default.supportedLogTypes = SUPPORTED_LOG_TYPES;
44
+ (await _log.default.getLogTypes()).should.eql(['one', 'two']);
45
+ });
46
+ });
47
+ describe('getLog', function () {
48
+ beforeEach(function () {
49
+ sandbox.spy(SUPPORTED_LOG_TYPES.one, 'getter');
50
+ sandbox.spy(SUPPORTED_LOG_TYPES.two, 'getter');
51
+ });
52
+ afterEach(function () {
53
+ SUPPORTED_LOG_TYPES.one.getter.restore();
54
+ SUPPORTED_LOG_TYPES.two.getter.restore();
55
+ });
56
+ it('should throw error if log type not supported', async function () {
57
+ await _log.default.getLog('one').should.eventually.be.rejected;
58
+ SUPPORTED_LOG_TYPES.one.getter.called.should.be.false;
59
+ SUPPORTED_LOG_TYPES.two.getter.called.should.be.false;
60
+ });
61
+ it('should throw an error with available log types if log type not supported', async function () {
62
+ _log.default.supportedLogTypes = SUPPORTED_LOG_TYPES;
63
+ let err;
64
+
65
+ try {
66
+ await _log.default.getLog('three');
67
+ } catch (_err) {
68
+ err = _err;
69
+ }
70
+
71
+ expect(err).to.exist;
72
+ err.message.should.eql(`Unsupported log type 'three'. Supported types: {"one":"First logs","two":"Seconds logs"}`);
73
+ SUPPORTED_LOG_TYPES.one.getter.called.should.be.false;
74
+ SUPPORTED_LOG_TYPES.two.getter.called.should.be.false;
75
+ });
76
+ it('should call getter on appropriate log when found', async function () {
77
+ _log.default.supportedLogTypes = SUPPORTED_LOG_TYPES;
78
+ let logs = await _log.default.getLog('one');
79
+ logs.should.eql(FIRST_LOGS);
80
+ SUPPORTED_LOG_TYPES.one.getter.called.should.be.true;
81
+ SUPPORTED_LOG_TYPES.two.getter.called.should.be.false;
82
+ });
83
+ });
84
+ });
85
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Rlc3QvdW5pdC9iYXNlZHJpdmVyL2NvbW1hbmRzL2xvZy5zcGVjLmpzIl0sIm5hbWVzIjpbImV4cGVjdCIsImNoYWkiLCJGSVJTVF9MT0dTIiwiU0VDT05EX0xPR1MiLCJTVVBQT1JURURfTE9HX1RZUEVTIiwib25lIiwiZGVzY3JpcHRpb24iLCJnZXR0ZXIiLCJfIiwiY2xvbmUiLCJ0d28iLCJkZXNjcmliZSIsInNhbmRib3giLCJiZWZvcmVFYWNoIiwibG9nQ29tbWFuZHMiLCJzdXBwb3J0ZWRMb2dUeXBlcyIsImxvZyIsImRlYnVnIiwibm9vcCIsImFmdGVyRWFjaCIsInJlc3RvcmUiLCJpdCIsImdldExvZ1R5cGVzIiwic2hvdWxkIiwiZXFsIiwic3B5IiwiZ2V0TG9nIiwiZXZlbnR1YWxseSIsImJlIiwicmVqZWN0ZWQiLCJjYWxsZWQiLCJmYWxzZSIsImVyciIsIl9lcnIiLCJ0byIsImV4aXN0IiwibWVzc2FnZSIsImxvZ3MiLCJ0cnVlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFHQSxNQUFNQSxNQUFNLEdBQUdDLElBQUksQ0FBQ0QsTUFBcEI7QUFFQSxNQUFNRSxVQUFVLEdBQUcsQ0FBQyxPQUFELEVBQVUsTUFBVixDQUFuQjtBQUNBLE1BQU1DLFdBQVcsR0FBRyxDQUFDLFFBQUQsRUFBVyxNQUFYLENBQXBCO0FBQ0EsTUFBTUMsbUJBQW1CLEdBQUc7QUFDMUJDLEVBQUFBLEdBQUcsRUFBRTtBQUNIQyxJQUFBQSxXQUFXLEVBQUUsWUFEVjtBQUVIQyxJQUFBQSxNQUFNLEVBQUUsTUFBTUMsZ0JBQUVDLEtBQUYsQ0FBUVAsVUFBUjtBQUZYLEdBRHFCO0FBSzFCUSxFQUFBQSxHQUFHLEVBQUU7QUFDSEosSUFBQUEsV0FBVyxFQUFFLGNBRFY7QUFFSEMsSUFBQUEsTUFBTSxFQUFFLE1BQU1DLGdCQUFFQyxLQUFGLENBQVFOLFdBQVI7QUFGWDtBQUxxQixDQUE1QjtBQVdBUSxRQUFRLENBQUMs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cEIsQ0FBd0JILE1BQXhCLENBQStCdUIsTUFBL0IsQ0FBc0NQLE1BQXRDLENBQTZDSyxFQUE3QyxDQUFnREcsS0FBaEQ7QUFDRCxLQVpDLENBQUY7QUFhQVYsSUFBQUEsRUFBRSxDQUFDLGtEQUFELEVBQXFELGtCQUFrQjtBQUN2RVAsbUJBQVlDLGlCQUFaLEdBQWdDWCxtQkFBaEM7QUFDQSxVQUFJaUMsSUFBSSxHQUFHLE1BQU12QixhQUFZWSxNQUFaLENBQW1CLEtBQW5CLENBQWpCO0FBQ0FXLE1BQUFBLElBQUksQ0FBQ2QsTUFBTCxDQUFZQyxHQUFaLENBQWdCdEIsVUFBaEI7QUFDQUUsTUFBQUEsbUJBQW1CLENBQUNDLEdBQXBCLENBQXdCRSxNQUF4QixDQUErQnVCLE1BQS9CLENBQXNDUCxNQUF0QyxDQUE2Q0ssRUFBN0MsQ0FBZ0RVLElBQWhEO0FBQ0FsQyxNQUFBQSxtQkFBbUIsQ0FBQ00sR0FBcEIsQ0FBd0JILE1BQXhCLENBQStCdUIsTUFBL0IsQ0FBc0NQLE1BQXRDLENBQTZDSyxFQUE3QyxDQUFnREcsS0FBaEQ7QUFDRCxLQU5DLENBQUY7QUFPRCxHQWxDTyxDQUFSO0FBbUNELENBMURPLENBQVIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbG9nQ29tbWFuZHMgZnJvbSAnLi4vLi4vLi4vLi4vbGliL2Jhc2Vkcml2ZXIvY29tbWFuZHMvbG9nJztcbmltcG9ydCB7IGNyZWF0ZVNhbmRib3ggfSBmcm9tICdzaW5vbic7XG5pbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuXG5cbmNvbnN0IGV4cGVjdCA9IGNoYWkuZXhwZWN0O1xuXG5jb25zdCBGSVJTVF9MT0dTID0gWydmaXJzdCcsICdsb2dzJ107XG5jb25zdCBTRUNPTkRfTE9HUyA9IFsnc2Vjb25kJywgJ2xvZ3MnXTtcbmNvbnN0IFNVUFBPUlRFRF9MT0dfVFlQRVMgPSB7XG4gIG9uZToge1xuICAgIGRlc2NyaXB0aW9uOiAnRmlyc3QgbG9ncycsXG4gICAgZ2V0dGVyOiAoKSA9PiBfLmNsb25lKEZJUlNUX0xPR1MpLFxuICB9LFxuICB0d286IHtcbiAgICBkZXNjcmlwdGlvbjogJ1NlY29uZHMgbG9ncycsXG4gICAgZ2V0dGVyOiAoKSA9PiBfLmNsb25lKFNFQ09ORF9MT0dTKSxcbiAgfSxcbn07XG5cbmRlc2NyaWJlKCdsb2cgY29tbWFuZHMgLScsIGZ1bmN0aW9uICgpIHtcbiAgbGV0IHNhbmRib3g7XG5cbiAgYmVmb3JlRWFjaChmdW5jdGlvbiAoKSB7XG4gICAgc2FuZGJveCA9IGNyZWF0ZVNhbmRib3goKTtcbiAgICAvLyByZXNldCB0aGUgc3VwcG9ydGVkIGxvZyB0eXBlc1xuICAgIGxvZ0NvbW1hbmRzLnN1cHBvcnRlZExvZ1R5cGVzID0ge307XG4gICAgbG9nQ29tbWFuZHMubG9nID0ge2RlYnVnOiBfLm5vb3B9O1xuICB9KTtcblxuICBhZnRlckVhY2goZnVuY3Rpb24gKCkge1xuICAgIHNhbmRib3gucmVzdG9yZSgpO1xuICB9KTtcblxuICBkZXNjcmliZSgnZ2V0TG9nVHlwZXMnLCBmdW5jdGlvbiAoKSB7XG4gICAgaXQoJ3Nob3VsZCByZXR1cm4gZW1wdHkgYXJyYXkgd2hlbiBubyBzdXBwb3J0ZWQgbG9nIHR5cGVzJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgICAgKGF3YWl0IGxvZ0NvbW1hbmRzLmdldExvZ1R5cGVzKCkpLnNob3VsZC5lcWwoW10pO1xuICAgIH0pO1xuICAgIGl0KCdzaG91bGQgcmV0dXJuIGtleXMgdG8gbG9nIHR5cGUgb2JqZWN0JywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgICAgbG9nQ29tbWFuZHMuc3VwcG9ydGVkTG9nVHlwZXMgPSBTVVBQT1JURURfTE9HX1RZUEVTO1xuICAgICAgKGF3YWl0IGxvZ0NvbW1hbmRzLmdldExvZ1R5cGVzKCkpLnNob3VsZC5lcWwoWydvbmUnLCAndHdvJ10pO1xuICAgIH0pO1xuICB9KTtcbiAgZGVzY3JpYmUoJ2dldExvZycsIGZ1bmN0aW9uICgpIHtcbiAgICBiZWZvcmVFYWNoKGZ1bmN0aW9uICgpIHtcbiAgICAgIHNhbmRib3guc3B5KFNVUFBPUlRFRF9MT0dfVFlQRVMub25lLCAnZ2V0dGVyJyk7XG4gICAgICBzYW5kYm94LnNweShTVVBQT1JURURfTE9HX1RZUEVTLnR3bywgJ2dldHRlcicpO1xuICAgIH0pO1xuICAgIGFmdGVyRWFjaChmdW5jdGlvbiAoKSB7XG4gICAgICBTVVBQT1JURURfTE9HX1RZUEVTLm9uZS5nZXR0ZXIucmVzdG9yZSgpO1xuICAgICAgU1VQUE9SVEVEX0xPR19UWVBFUy50d28uZ2V0dGVyLnJlc3RvcmUoKTtcbiAgICB9KTtcbiAgICBpdCgnc2hvdWxkIHRocm93IGVycm9yIGlmIGxvZyB0eXBlIG5vdCBzdXBwb3J0ZWQnLCBhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgICBhd2FpdCBsb2dDb21tYW5kcy5nZXRMb2coJ29uZScpLnNob3VsZC5ldmVudHVhbGx5LmJlLnJlamVjdGVkO1xuICAgICAgU1VQUE9SVEVEX0xPR19UWVBFUy5vbmUuZ2V0dGVyLmNhbGxlZC5zaG91bGQuYmUuZmFsc2U7XG4gICAgICBTVVBQT1JURURfTE9HX1RZUEVTLnR3by5nZXR0ZXIuY2FsbGVkLnNob3VsZC5iZS5mYWxzZTtcbiAgICB9KTtcbiAgICBpdCgnc2hvdWxkIHRocm93IGFuIGVycm9yIHdpdGggYXZhaWxhYmxlIGxvZyB0eXBlcyBpZiBsb2cgdHlwZSBub3Qgc3VwcG9ydGVkJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgICAgbG9nQ29tbWFuZHMuc3VwcG9ydGVkTG9nVHlwZXMgPSBTVVBQT1JURURfTE9HX1RZUEVTO1xuICAgICAgbGV0IGVycjtcbiAgICAgIHRyeSB7XG4gICAgICAgIGF3YWl0IGxvZ0NvbW1hbmRzLmdldExvZygndGhyZWUnKTtcbiAgICAgIH0gY2F0Y2ggKF9lcnIpIHtcbiAgICAgICAgZXJyID0gX2VycjtcbiAgICAgIH1cbiAgICAgIGV4cGVjdChlcnIpLnRvLmV4aXN0O1xuICAgICAgZXJyLm1lc3NhZ2Uuc2hvdWxkLmVxbChgVW5zdXBwb3J0ZWQgbG9nIHR5cGUgJ3RocmVlJy4gU3VwcG9ydGVkIHR5cGVzOiB7XCJvbmVcIjpcIkZpcnN0IGxvZ3NcIixcInR3b1wiOlwiU2Vjb25kcyBsb2dzXCJ9YCk7XG4gICAgICBTVVBQT1JURURfTE9HX1RZUEVTLm9uZS5nZXR0ZXIuY2FsbGVkLnNob3VsZC5iZS5mYWxzZTtcbiAgICAgIFNVUFBPUlRFRF9MT0dfVFlQRVMudHdvLmdldHRlci5jYWxsZWQuc2hvdWxkLmJlLmZhbHNlO1xuICAgIH0pO1xuICAgIGl0KCdzaG91bGQgY2FsbCBnZXR0ZXIgb24gYXBwcm9wcmlhdGUgbG9nIHdoZW4gZm91bmQnLCBhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgICBsb2dDb21tYW5kcy5zdXBwb3J0ZWRMb2dUeXBlcyA9IFNVUFBPUlRFRF9MT0dfVFlQRVM7XG4gICAgICBsZXQgbG9ncyA9IGF3YWl0IGxvZ0NvbW1hbmRzLmdldExvZygnb25lJyk7XG4gICAgICBsb2dzLnNob3VsZC5lcWwoRklSU1RfTE9HUyk7XG4gICAgICBTVVBQT1JURURfTE9HX1RZUEVTLm9uZS5nZXR0ZXIuY2FsbGVkLnNob3VsZC5iZS50cnVlO1xuICAgICAgU1VQUE9SVEVEX0xPR19UWVBFUy50d28uZ2V0dGVyLmNhbGxlZC5zaG91bGQuYmUuZmFsc2U7XG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXX0=
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ require("source-map-support/register");
6
+
7
+ var _lib = _interopRequireDefault(require("../../../lib"));
8
+
9
+ var _basedriver = require("../../basedriver");
10
+
11
+ (0, _basedriver.baseDriverUnitTests)(_lib.default, {
12
+ platformName: 'iOS',
13
+ 'appium:deviceName': 'Delorean'
14
+ });
15
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Rlc3QvdW5pdC9iYXNlZHJpdmVyL2RyaXZlci5zcGVjLmpzIl0sIm5hbWVzIjpbIkJhc2VEcml2ZXIiLCJwbGF0Zm9ybU5hbWUiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUVBOztBQUNBOztBQUVBLHFDQUFvQkEsWUFBcEIsRUFBZ0M7QUFDOUJDLEVBQUFBLFlBQVksRUFBRSxLQURnQjtBQUU5Qix1QkFBcUI7QUFGUyxDQUFoQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIHRyYW5zcGlsZTptb2NoYVxuXG5pbXBvcnQgQmFzZURyaXZlciBmcm9tICcuLi8uLi8uLi9saWInO1xuaW1wb3J0IHsgYmFzZURyaXZlclVuaXRUZXN0cyB9IGZyb20gJy4uLy4uL2Jhc2Vkcml2ZXInO1xuXG5iYXNlRHJpdmVyVW5pdFRlc3RzKEJhc2VEcml2ZXIsIHtcbiAgcGxhdGZvcm1OYW1lOiAnaU9TJyxcbiAgJ2FwcGl1bTpkZXZpY2VOYW1lJzogJ0RlbG9yZWFuJ1xufSk7XG4iXX0=