@appium/base-driver 8.2.2 → 8.3.0

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 (61) hide show
  1. package/build/lib/basedriver/capabilities.js +3 -1
  2. package/build/lib/basedriver/commands/find.js +4 -11
  3. package/build/lib/basedriver/commands/log.js +3 -6
  4. package/build/lib/basedriver/commands/session.js +18 -27
  5. package/build/lib/basedriver/commands/settings.js +4 -8
  6. package/build/lib/basedriver/commands/timeout.js +10 -15
  7. package/build/lib/basedriver/device-settings.js +14 -2
  8. package/build/lib/basedriver/driver.js +25 -23
  9. package/build/lib/basedriver/helpers.js +140 -84
  10. package/build/lib/express/express-logging.js +2 -2
  11. package/build/lib/express/idempotency.js +2 -2
  12. package/build/lib/helpers/capabilities.js +39 -0
  13. package/build/lib/index.js +7 -7
  14. package/build/lib/jsonwp-proxy/protocol-converter.js +19 -16
  15. package/build/lib/jsonwp-proxy/proxy.js +20 -16
  16. package/build/lib/protocol/errors.js +4 -2
  17. package/build/lib/protocol/helpers.js +3 -20
  18. package/build/lib/protocol/protocol.js +44 -45
  19. package/build/lib/protocol/routes.js +67 -1
  20. package/build/test/basedriver/capabilities-specs.js +43 -1
  21. package/build/test/basedriver/capability-specs.js +126 -167
  22. package/build/test/basedriver/commands/log-specs.js +12 -5
  23. package/build/test/basedriver/driver-tests.js +11 -14
  24. package/build/test/basedriver/helpers-specs.js +5 -1
  25. package/build/test/basedriver/timeout-specs.js +7 -9
  26. package/build/test/express/server-e2e-specs.js +10 -5
  27. package/build/test/express/server-specs.js +22 -16
  28. package/build/test/express/static-specs.js +10 -5
  29. package/build/test/jsonwp-proxy/proxy-e2e-specs.js +1 -2
  30. package/build/test/jsonwp-proxy/proxy-specs.js +1 -6
  31. package/build/test/protocol/fake-driver.js +12 -15
  32. package/build/test/protocol/protocol-e2e-specs.js +49 -103
  33. package/build/test/protocol/routes-specs.js +2 -2
  34. package/lib/basedriver/capabilities.js +3 -0
  35. package/lib/basedriver/commands/find.js +3 -6
  36. package/lib/basedriver/commands/log.js +2 -4
  37. package/lib/basedriver/commands/session.js +21 -22
  38. package/lib/basedriver/commands/settings.js +3 -5
  39. package/lib/basedriver/commands/timeout.js +9 -10
  40. package/lib/basedriver/device-settings.js +10 -1
  41. package/lib/basedriver/driver.js +29 -16
  42. package/lib/basedriver/helpers.js +201 -83
  43. package/lib/express/express-logging.js +1 -1
  44. package/lib/express/idempotency.js +1 -1
  45. package/lib/helpers/capabilities.js +25 -0
  46. package/lib/index.js +6 -4
  47. package/lib/jsonwp-proxy/protocol-converter.js +15 -18
  48. package/lib/jsonwp-proxy/proxy.js +17 -15
  49. package/lib/protocol/errors.js +1 -1
  50. package/lib/protocol/helpers.js +5 -25
  51. package/lib/protocol/protocol.js +43 -54
  52. package/lib/protocol/routes.js +60 -1
  53. package/package.json +29 -22
  54. package/test/basedriver/capabilities-specs.js +34 -2
  55. package/test/basedriver/capability-specs.js +120 -146
  56. package/test/basedriver/commands/log-specs.js +12 -3
  57. package/test/basedriver/driver-tests.js +12 -7
  58. package/test/basedriver/helpers-specs.js +4 -0
  59. package/test/basedriver/timeout-specs.js +6 -11
  60. package/build/lib/protocol/sessions-cache.js +0 -88
  61. package/lib/protocol/sessions-cache.js +0 -74
@@ -4,11 +4,13 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
 
5
5
  require("source-map-support/register");
6
6
 
7
+ var _bluebird = _interopRequireDefault(require("bluebird"));
8
+
7
9
  var _lib = _interopRequireWildcard(require("../../lib"));
8
10
 
9
11
  var _logger = _interopRequireDefault(require("../../lib/basedriver/logger"));
10
12
 
11
- var _sinon = _interopRequireDefault(require("sinon"));
13
+ var _sinon = require("sinon");
12
14
 
13
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); }
14
16
 
@@ -16,37 +18,27 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
16
18
 
17
19
  describe('Desired Capabilities', function () {
18
20
  let d;
21
+ let sandbox;
19
22
  beforeEach(function () {
20
23
  d = new _lib.default();
21
-
22
- _sinon.default.spy(_logger.default, 'warn');
24
+ sandbox = (0, _sinon.createSandbox)();
25
+ sandbox.spy(d.log, 'warn');
26
+ sandbox.spy(_logger.default, 'warn');
23
27
  });
24
28
  afterEach(function () {
25
- _logger.default.warn.restore();
29
+ sandbox.restore();
26
30
  });
27
31
  it('should require platformName and deviceName', async function () {
28
- try {
29
- await d.createSession(null, null, {});
30
- } catch (e) {
31
- e.should.be.instanceof(_lib.errors.SessionNotCreatedError);
32
- e.message.should.contain('platformName');
33
- return;
34
- }
35
-
36
- should.fail('error should have been thrown');
32
+ await d.createSession({
33
+ firstMatch: [{}]
34
+ }).should.eventually.be.rejectedWith(_lib.errors.SessionNotCreatedError, /platformName/);
37
35
  });
38
36
  it('should require platformName', async function () {
39
- try {
40
- await d.createSession(null, null, {
41
- 'deviceName': 'Delorean'
42
- });
43
- } catch (e) {
44
- e.should.be.instanceof(_lib.errors.SessionNotCreatedError);
45
- e.message.should.contain('platformName');
46
- return;
47
- }
48
-
49
- should.fail('error should have been thrown');
37
+ await d.createSession({
38
+ alwaysMatch: {
39
+ 'appium:deviceName': 'Delorean'
40
+ }
41
+ }).should.eventually.be.rejectedWith(_lib.errors.SessionNotCreatedError, /platformName/);
50
42
  });
51
43
  it('should not care about cap order', async function () {
52
44
  await d.createSession(null, null, {
@@ -54,7 +46,7 @@ describe('Desired Capabilities', function () {
54
46
  'appium:deviceName': 'Delorean',
55
47
  platformName: 'iOS'
56
48
  }
57
- });
49
+ }).should.eventually.be.fulfilled;
58
50
  });
59
51
  it('should check required caps which are added to driver', async function () {
60
52
  d.desiredCapConstraints = {
@@ -67,22 +59,12 @@ describe('Desired Capabilities', function () {
67
59
  inclusion: ['Delorean', 'Reventon']
68
60
  }
69
61
  };
70
-
71
- try {
72
- await d.createSession(null, null, {
73
- alwaysMatch: {
74
- 'platformName': 'iOS',
75
- 'appium:deviceName': 'Delorean'
76
- }
77
- });
78
- } catch (e) {
79
- e.should.be.instanceof(_lib.errors.SessionNotCreatedError);
80
- e.message.should.contain('necessary');
81
- e.message.should.contain('proper');
82
- return;
83
- }
84
-
85
- should.fail('error should have been thrown');
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/);
86
68
  });
87
69
  it('should check added required caps in addition to base', async function () {
88
70
  d.desiredCapConstraints = {
@@ -95,20 +77,11 @@ describe('Desired Capabilities', function () {
95
77
  inclusion: ['Delorean', 'Reventon']
96
78
  }
97
79
  };
98
-
99
- try {
100
- await d.createSession(null, null, {
101
- alwaysMatch: {
102
- 'appium:necessary': 'yup'
103
- }
104
- });
105
- } catch (e) {
106
- e.should.be.instanceof(_lib.errors.SessionNotCreatedError);
107
- e.message.should.contain('platformName');
108
- return;
109
- }
110
-
111
- should.fail('error should have been thrown');
80
+ await d.createSession(null, null, {
81
+ alwaysMatch: {
82
+ 'appium:necessary': 'yup'
83
+ }
84
+ }).should.eventually.be.rejectedWith(_lib.errors.SessionNotCreatedError, /platformName/);
112
85
  });
113
86
  it('should accept extra capabilities', async function () {
114
87
  await d.createSession(null, null, {
@@ -118,7 +91,7 @@ describe('Desired Capabilities', function () {
118
91
  'appium:extra': 'cheese',
119
92
  'appium:hold the': 'sauce'
120
93
  }
121
- });
94
+ }).should.eventually.be.fulfilled;
122
95
  });
123
96
  it('should log the use of extra caps', async function () {
124
97
  this.timeout(500);
@@ -130,24 +103,15 @@ describe('Desired Capabilities', function () {
130
103
  'appium:hold the': 'sauce'
131
104
  }
132
105
  });
133
-
134
- _logger.default.warn.callCount.should.be.above(0);
106
+ d.log.warn.should.have.been.called;
135
107
  });
136
108
  it('should be sensitive to the case of caps', async function () {
137
- try {
138
- await d.createSession(null, null, {
139
- alwaysMatch: {
140
- 'platformname': 'iOS',
141
- 'appium:deviceName': 'Delorean'
142
- }
143
- });
144
- } catch (e) {
145
- e.should.be.instanceof(_lib.errors.SessionNotCreatedError);
146
- e.message.should.contain('platformName');
147
- return;
148
- }
149
-
150
- should.fail('error should have been thrown');
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/);
151
115
  });
152
116
  describe('boolean capabilities', function () {
153
117
  it('should allow a string "false"', async function () {
@@ -158,9 +122,7 @@ describe('Desired Capabilities', function () {
158
122
  'appium:noReset': 'false'
159
123
  }
160
124
  });
161
-
162
- _logger.default.warn.callCount.should.be.above(0);
163
-
125
+ d.log.warn.should.have.been.called;
164
126
  let sessions = await d.getSessions();
165
127
  sessions[0].capabilities.noReset.should.eql(false);
166
128
  });
@@ -172,9 +134,7 @@ describe('Desired Capabilities', function () {
172
134
  'appium:noReset': 'true'
173
135
  }
174
136
  });
175
-
176
- _logger.default.warn.callCount.should.be.above(0);
177
-
137
+ d.log.warn.should.have.been.called;
178
138
  let sessions = await d.getSessions();
179
139
  sessions[0].capabilities.noReset.should.eql(true);
180
140
  });
@@ -186,9 +146,7 @@ describe('Desired Capabilities', function () {
186
146
  'appium:language': 'true'
187
147
  }
188
148
  });
189
-
190
- _logger.default.warn.callCount.should.equal(0);
191
-
149
+ d.log.warn.should.not.have.been.called;
192
150
  let sessions = await d.getSessions();
193
151
  sessions[0].capabilities.language.should.eql('true');
194
152
  });
@@ -202,9 +160,7 @@ describe('Desired Capabilities', function () {
202
160
  'appium:newCommandTimeout': '1'
203
161
  }
204
162
  });
205
-
206
- _logger.default.warn.callCount.should.be.above(0);
207
-
163
+ d.log.warn.should.have.been.called;
208
164
  let sessions = await d.getSessions();
209
165
  sessions[0].capabilities.newCommandTimeout.should.eql(1);
210
166
  });
@@ -216,9 +172,7 @@ describe('Desired Capabilities', function () {
216
172
  'appium:newCommandTimeout': '1.1'
217
173
  }
218
174
  });
219
-
220
- _logger.default.warn.callCount.should.be.above(0);
221
-
175
+ d.log.warn.should.have.been.called;
222
176
  let sessions = await d.getSessions();
223
177
  sessions[0].capabilities.newCommandTimeout.should.eql(1.1);
224
178
  });
@@ -230,30 +184,20 @@ describe('Desired Capabilities', function () {
230
184
  'appium:language': '1'
231
185
  }
232
186
  });
233
-
234
- _logger.default.warn.callCount.should.equal(0);
235
-
187
+ d.log.warn.should.not.have.been.called;
236
188
  let sessions = await d.getSessions();
237
189
  sessions[0].capabilities.language.should.eql('1');
238
190
  });
239
191
  });
240
192
  it('should error if objects in caps', async function () {
241
- try {
242
- await d.createSession(null, null, {
243
- alwaysMatch: {
244
- 'platformName': {
245
- a: 'iOS'
246
- },
247
- 'appium:deviceName': 'Delorean'
248
- }
249
- });
250
- } catch (e) {
251
- e.should.be.instanceof(_lib.errors.SessionNotCreatedError);
252
- e.message.should.contain('platformName');
253
- return;
254
- }
255
-
256
- should.fail('error should have been thrown');
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);
257
201
  });
258
202
  it('should check for deprecated caps', async function () {
259
203
  this.timeout(500);
@@ -269,8 +213,7 @@ describe('Desired Capabilities', function () {
269
213
  'appium:lynx-version': 5
270
214
  }
271
215
  });
272
-
273
- _logger.default.warn.callCount.should.be.above(0);
216
+ _logger.default.warn.should.have.been.called;
274
217
  });
275
218
  it('should not warn if deprecated=false', async function () {
276
219
  this.timeout(500);
@@ -286,8 +229,7 @@ describe('Desired Capabilities', function () {
286
229
  'appium:lynx-version': 5
287
230
  }
288
231
  });
289
-
290
- _logger.default.warn.callCount.should.equal(0);
232
+ d.log.warn.should.not.have.been.called;
291
233
  });
292
234
  it('should not validate against null/undefined caps', async function () {
293
235
  d.desiredCapConstraints = {
@@ -295,14 +237,19 @@ describe('Desired Capabilities', function () {
295
237
  isString: true
296
238
  }
297
239
  };
298
- await d.createSession(null, null, {
299
- alwaysMatch: {
300
- platformName: 'iOS',
301
- 'appium:deviceName': 'Dumb',
302
- 'appium:foo': null
303
- }
304
- });
305
- await d.deleteSession();
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
+
306
253
  await d.createSession(null, null, {
307
254
  alwaysMatch: {
308
255
  platformName: 'iOS',
@@ -310,22 +257,30 @@ describe('Desired Capabilities', function () {
310
257
  'appium:foo': 1
311
258
  }
312
259
  }).should.eventually.be.rejectedWith(/'foo' must be of type string/);
313
- await d.createSession(null, null, {
314
- alwaysMatch: {
315
- platformName: 'iOS',
316
- 'appium:deviceName': 'Dumb',
317
- 'appium:foo': undefined
318
- }
319
- });
320
- await d.deleteSession();
321
- await d.createSession(null, null, {
322
- alwaysMatch: {
323
- platformName: 'iOS',
324
- 'appium:deviceName': 'Dumb',
325
- 'appium:foo': ''
326
- }
327
- });
328
- await d.deleteSession();
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
+ }
329
284
  });
330
285
  it('should still validate null/undefined/empty caps whose presence is required', async function () {
331
286
  d.desiredCapConstraints = {
@@ -340,25 +295,33 @@ describe('Desired Capabilities', function () {
340
295
  'appium:foo': null
341
296
  }
342
297
  }).should.eventually.be.rejectedWith(/blank/);
343
- await d.createSession(null, null, {
344
- platformName: 'iOS',
345
- 'appium:deviceName': 'Dumb',
346
- 'appium:foo': ''
298
+ await d.createSession(null, {
299
+ alwaysMatch: {
300
+ platformName: 'iOS',
301
+ 'appium:deviceName': 'Dumb',
302
+ 'appium:foo': ''
303
+ }
347
304
  }).should.eventually.be.rejectedWith(/blank/);
348
- await d.createSession(null, null, {
349
- platformName: 'iOS',
350
- 'appium:deviceName': 'Dumb',
351
- 'appium:foo': {}
305
+ await d.createSession({
306
+ firstMatch: [{
307
+ platformName: 'iOS',
308
+ 'appium:deviceName': 'Dumb',
309
+ 'appium:foo': {}
310
+ }]
352
311
  }).should.eventually.be.rejectedWith(/blank/);
353
- await d.createSession(null, null, {
354
- platformName: 'iOS',
355
- 'appium:deviceName': 'Dumb',
356
- 'appium:foo': []
312
+ await d.createSession({
313
+ alwaysMatch: {
314
+ platformName: 'iOS',
315
+ 'appium:deviceName': 'Dumb',
316
+ 'appium:foo': []
317
+ }
357
318
  }).should.eventually.be.rejectedWith(/blank/);
358
- await d.createSession(null, null, {
359
- platformName: 'iOS',
360
- 'appium:deviceName': 'Dumb',
361
- 'appium:foo': ' '
319
+ await d.createSession({
320
+ alwaysMatch: {
321
+ platformName: 'iOS',
322
+ 'appium:deviceName': 'Dumb',
323
+ 'appium:foo': ' '
324
+ }
362
325
  }).should.eventually.be.rejectedWith(/blank/);
363
326
  });
364
327
  describe('w3c', function () {
@@ -370,27 +333,23 @@ describe('Desired Capabilities', function () {
370
333
  },
371
334
  firstMatch: [{}]
372
335
  });
373
- sessionId.should.exist;
374
- caps.should.eql({
375
- platformName: 'iOS',
376
- deviceName: 'Delorean'
377
- });
378
- await d.deleteSession();
379
- });
380
- it('should raise an error if w3c capabilities is not a plain JSON object', async function () {
381
- for (const val of [true, 'string', [], 100]) {
382
- try {
383
- await d.createSession(null, null, val);
384
- } catch (e) {
385
- e.should.be.instanceof(_lib.errors.SessionNotCreatedError);
386
- continue;
387
- }
388
336
 
389
- should.fail('error should have been thrown');
337
+ try {
338
+ sessionId.should.exist;
339
+ caps.should.eql({
340
+ platformName: 'iOS',
341
+ deviceName: 'Delorean'
342
+ });
343
+ } finally {
344
+ await d.deleteSession();
390
345
  }
391
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
+ });
392
351
  });
393
352
  });require('source-map-support').install();
394
353
 
395
354
 
396
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/basedriver/capability-specs.js"],"names":["describe","d","beforeEach","BaseDriver","sinon","spy","logger","afterEach","warn","restore","it","createSession","e","should","be","instanceof","errors","SessionNotCreatedError","message","contain","fail","alwaysMatch","platformName","desiredCapConstraints","necessary","presence","proper","isString","inclusion","timeout","callCount","above","sessions","getSessions","capabilities","noReset","eql","equal","language","newCommandTimeout","a","deprecated","deleteSession","eventually","rejectedWith","undefined","foo","sessionId","caps","firstMatch","exist","deviceName","val"],"mappings":"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","sourcesContent":["import { default as BaseDriver, errors } from '../../lib';\nimport logger from '../../lib/basedriver/logger';\nimport sinon from 'sinon';\n\n\ndescribe('Desired Capabilities', function () {\n  let d;\n\n  beforeEach(function () {\n    d = new BaseDriver();\n    sinon.spy(logger, 'warn');\n  });\n\n  afterEach(function () {\n    logger.warn.restore();\n  });\n\n  it('should require platformName and deviceName', async function () {\n    try {\n      await d.createSession(null, null, {});\n    } catch (e) {\n      e.should.be.instanceof(errors.SessionNotCreatedError);\n      e.message.should.contain('platformName');\n      return;\n    }\n\n    should.fail('error should have been thrown');\n  });\n\n\n  it('should require platformName', async function () {\n    try {\n      await d.createSession(null, null, {'deviceName': 'Delorean'});\n    } catch (e) {\n      e.should.be.instanceof(errors.SessionNotCreatedError);\n      e.message.should.contain('platformName');\n      return;\n    }\n\n    should.fail('error should have been thrown');\n  });\n\n  it('should not care about cap order', async function () {\n\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        'appium:deviceName': 'Delorean',\n        platformName: 'iOS'\n      }\n    });\n\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    try {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          'platformName': 'iOS',\n          'appium:deviceName': 'Delorean'\n        }\n      });\n    } catch (e) {\n      e.should.be.instanceof(errors.SessionNotCreatedError);\n      e.message.should.contain('necessary');\n      e.message.should.contain('proper');\n      return;\n    }\n\n    should.fail('error should have been thrown');\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    try {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          'appium:necessary': 'yup'\n        }\n      });\n    } catch (e) {\n      e.should.be.instanceof(errors.SessionNotCreatedError);\n      e.message.should.contain('platformName');\n      return;\n    }\n\n    should.fail('error should have been thrown');\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    });\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    logger.warn.callCount.should.be.above(0);\n  });\n\n  it('should be sensitive to the case of caps', async function () {\n    try {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          'platformname': 'iOS',\n          'appium:deviceName': 'Delorean'\n        }\n      });\n    } catch (e) {\n      e.should.be.instanceof(errors.SessionNotCreatedError);\n      e.message.should.contain('platformName');\n      return;\n    }\n\n    should.fail('error should have been thrown');\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      logger.warn.callCount.should.be.above(0);\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      logger.warn.callCount.should.be.above(0);\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      logger.warn.callCount.should.equal(0);\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      logger.warn.callCount.should.be.above(0);\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      logger.warn.callCount.should.be.above(0);\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      logger.warn.callCount.should.equal(0);\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    try {\n      await d.createSession(null, null, {\n        alwaysMatch: {\n          'platformName': {a: 'iOS'},\n          'appium:deviceName': 'Delorean'\n        }\n      });\n    } catch (e) {\n      e.should.be.instanceof(errors.SessionNotCreatedError);\n      e.message.should.contain('platformName');\n      return;\n    }\n\n    should.fail('error should have been thrown');\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.callCount.should.be.above(0);\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    logger.warn.callCount.should.equal(0);\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    await d.createSession(null, null, {\n      alwaysMatch: {\n        platformName: 'iOS',\n        'appium:deviceName': 'Dumb',\n        'appium:foo': null\n      }\n    });\n    await d.deleteSession();\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    await d.createSession(null, null, {\n      alwaysMatch: {\n        platformName: 'iOS',\n        'appium:deviceName': 'Dumb',\n        'appium:foo': undefined\n      }\n    });\n    await d.deleteSession();\n\n    await d.createSession(null, null, {\n      alwaysMatch: {\n        platformName: 'iOS',\n        'appium:deviceName': 'Dumb',\n        'appium:foo': ''\n      }\n    });\n    await d.deleteSession();\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, null, {\n      platformName: 'iOS',\n      'appium:deviceName': 'Dumb',\n      'appium:foo': ''\n    }).should.eventually.be.rejectedWith(/blank/);\n\n    await d.createSession(null, null, {\n      platformName: 'iOS',\n      'appium:deviceName': 'Dumb',\n      'appium:foo': {}\n    }).should.eventually.be.rejectedWith(/blank/);\n\n    await d.createSession(null, null, {\n      platformName: 'iOS',\n      'appium:deviceName': 'Dumb',\n      'appium:foo': []\n    }).should.eventually.be.rejectedWith(/blank/);\n\n    await d.createSession(null, null, {\n      platformName: 'iOS',\n      'appium:deviceName': 'Dumb',\n      'appium:foo': '  '\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      sessionId.should.exist;\n      caps.should.eql({\n        platformName: 'iOS',\n        deviceName: 'Delorean',\n      });\n      await d.deleteSession();\n    });\n\n    it('should raise an error if w3c capabilities is not a plain JSON object', async function () {\n      for (const val of [true, 'string', [], 100]) {\n        try {\n          await d.createSession(null, null, val);\n        } catch (e) {\n          e.should.be.instanceof(errors.SessionNotCreatedError);\n          continue;\n        }\n        should.fail('error should have been thrown');\n      }\n    });\n  });\n});\n"],"file":"test/basedriver/capability-specs.js","sourceRoot":"../../.."}
355
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/basedriver/capability-specs.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":"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","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"],"file":"test/basedriver/capability-specs.js","sourceRoot":"../../.."}
@@ -6,7 +6,7 @@ require("source-map-support/register");
6
6
 
7
7
  var _log = _interopRequireDefault(require("../../../lib/basedriver/commands/log"));
8
8
 
9
- var _sinon = _interopRequireDefault(require("sinon"));
9
+ var _sinon = require("sinon");
10
10
 
11
11
  var _lodash = _interopRequireDefault(require("lodash"));
12
12
 
@@ -24,8 +24,16 @@ const SUPPORTED_LOG_TYPES = {
24
24
  }
25
25
  };
26
26
  describe('log commands -', function () {
27
+ let sandbox;
27
28
  beforeEach(function () {
29
+ sandbox = (0, _sinon.createSandbox)();
28
30
  _log.default.supportedLogTypes = {};
31
+ _log.default.log = {
32
+ debug: _lodash.default.noop
33
+ };
34
+ });
35
+ afterEach(function () {
36
+ sandbox.restore();
29
37
  });
30
38
  describe('getLogTypes', function () {
31
39
  it('should return empty array when no supported log types', async function () {
@@ -38,9 +46,8 @@ describe('log commands -', function () {
38
46
  });
39
47
  describe('getLog', function () {
40
48
  beforeEach(function () {
41
- _sinon.default.spy(SUPPORTED_LOG_TYPES.one, 'getter');
42
-
43
- _sinon.default.spy(SUPPORTED_LOG_TYPES.two, 'getter');
49
+ sandbox.spy(SUPPORTED_LOG_TYPES.one, 'getter');
50
+ sandbox.spy(SUPPORTED_LOG_TYPES.two, 'getter');
44
51
  });
45
52
  afterEach(function () {
46
53
  SUPPORTED_LOG_TYPES.one.getter.restore();
@@ -77,4 +84,4 @@ describe('log commands -', function () {
77
84
  });require('source-map-support').install();
78
85
 
79
86
 
80
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvYmFzZWRyaXZlci9jb21tYW5kcy9sb2ctc3BlY3MuanMiXSwibmFtZXMiOlsiZXhwZWN0IiwiY2hhaSIsIkZJUlNUX0xPR1MiLCJTRUNPTkRfTE9HUyIsIlNVUFBPUlRFRF9MT0dfVFlQRVMiLCJvbmUiLCJkZXNjcmlwdGlvbiIsImdldHRlciIsIl8iLCJjbG9uZSIsInR3byIsImRlc2NyaWJlIiwiYmVmb3JlRWFjaCIsImxvZ0NvbW1hbmRzIiwic3VwcG9ydGVkTG9nVHlwZXMiLCJpdCIsImdldExvZ1R5cGVzIiwic2hvdWxkIiwiZXFsIiwic2lub24iLCJzcHkiLCJhZnRlckVhY2giLCJyZXN0b3JlIiwiZ2V0TG9nIiwiZXZlbnR1YWxseSIsImJlIiwicmVqZWN0ZWQiLCJjYWxsZWQiLCJmYWxzZSIsImVyciIsIl9lcnIiLCJ0byIsImV4aXN0IiwibWVzc2FnZSIsImxvZ3MiLCJ0cnVlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFHQSxNQUFNQSxNQUFNLEdBQUdDLElBQUksQ0FBQ0QsTUFBcEI7QUFFQSxNQUFNRSxVQUFVLEdBQUcsQ0FBQyxPQUFELEVBQVUsTUFBVixDQUFuQjtBQUNBLE1BQU1DLFdBQVcsR0FBRyxDQUFDLFFBQUQsRUFBVyxNQUFYLENBQXBCO0FBQ0EsTUFBTUMsbUJBQW1CLEdBQUc7QUFDMUJDLEVBQUFBLEdBQUcsRUFBRTtBQUNIQyxJQUFBQSxXQUFXLEVBQUUsWUFEVjtBQUVIQyxJQUFBQSxNQUFNLEVBQUUsTUFBTUMsZ0JBQUVDLEtBQUYsQ0FBUVAsVUFBUjtBQUZYLEdBRHFCO0FBSzFCUSxFQUFBQSxHQUFHLEVBQUU7QUFDSEosSUFBQUEsV0FBVyxFQUFFLGNBRFY7QUFFSEMsSUFBQUEsTUFBTSxFQUFFLE1BQU1DLGdCQUFFQyxLQUFGLENBQVFOLFdBQVI7QUFGWDtBQUxxQixDQUE1QjtBQVdBUSxRQUFRLENBQUMsZ0JBQUQsRUFBbUIsWUFBWTtBQUNyQ0MsRUFBQUEsVUFBVSxDQUFDLFlB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LE1BQUwsQ0FBWUMsR0FBWixDQUFnQmhCLFVBQWhCO0FBQ0FFLE1BQUFBLG1CQUFtQixDQUFDQyxHQUFwQixDQUF3QkUsTUFBeEIsQ0FBK0JvQixNQUEvQixDQUFzQ1YsTUFBdEMsQ0FBNkNRLEVBQTdDLENBQWdEVSxJQUFoRDtBQUNBL0IsTUFBQUEsbUJBQW1CLENBQUNNLEdBQXBCLENBQXdCSCxNQUF4QixDQUErQm9CLE1BQS9CLENBQXNDVixNQUF0QyxDQUE2Q1EsRUFBN0MsQ0FBZ0RHLEtBQWhEO0FBQ0QsS0FOQyxDQUFGO0FBT0QsR0FsQ08sQ0FBUjtBQW1DRCxDQWpETyxDQUFSIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGxvZ0NvbW1hbmRzIGZyb20gJy4uLy4uLy4uL2xpYi9iYXNlZHJpdmVyL2NvbW1hbmRzL2xvZyc7XG5pbXBvcnQgc2lub24gZnJvbSAnc2lub24nO1xuaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcblxuXG5jb25zdCBleHBlY3QgPSBjaGFpLmV4cGVjdDtcblxuY29uc3QgRklSU1RfTE9HUyA9IFsnZmlyc3QnLCAnbG9ncyddO1xuY29uc3QgU0VDT05EX0xPR1MgPSBbJ3NlY29uZCcsICdsb2dzJ107XG5jb25zdCBTVVBQT1JURURfTE9HX1RZUEVTID0ge1xuICBvbmU6IHtcbiAgICBkZXNjcmlwdGlvbjogJ0ZpcnN0IGxvZ3MnLFxuICAgIGdldHRlcjogKCkgPT4gXy5jbG9uZShGSVJTVF9MT0dTKSxcbiAgfSxcbiAgdHdvOiB7XG4gICAgZGVzY3JpcHRpb246ICdTZWNvbmRzIGxvZ3MnLFxuICAgIGdldHRlcjogKCkgPT4gXy5jbG9uZShTRUNPTkRfTE9HUyksXG4gIH0sXG59O1xuXG5kZXNjcmliZSgnbG9nIGNvbW1hbmRzIC0nLCBmdW5jdGlvbiAoKSB7XG4gIGJlZm9yZUVhY2goZnVuY3Rpb24gKCkge1xuICAgIC8vIHJlc2V0IHRoZSBzdXBwb3J0ZWQgbG9nIHR5cGVzXG4gICAgbG9nQ29tbWFuZHMuc3VwcG9ydGVkTG9nVHlwZXMgPSB7fTtcbiAgfSk7XG4gIGRlc2NyaWJlKCdnZXRMb2dUeXBlcycsIGZ1bmN0aW9uICgpIHtcbiAgICBpdCgnc2hvdWxkIHJldHVybiBlbXB0eSBhcnJheSB3aGVuIG5vIHN1cHBvcnRlZCBsb2cgdHlwZXMnLCBhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgICAoYXdhaXQgbG9nQ29tbWFuZHMuZ2V0TG9nVHlwZXMoKSkuc2hvdWxkLmVxbChbXSk7XG4gICAgfSk7XG4gICAgaXQoJ3Nob3VsZCByZXR1cm4ga2V5cyB0byBsb2cgdHlwZSBvYmplY3QnLCBhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgICBsb2dDb21tYW5kcy5zdXBwb3J0ZWRMb2dUeXBlcyA9IFNVUFBPUlRFRF9MT0dfVFlQRVM7XG4gICAgICAoYXdhaXQgbG9nQ29tbWFuZHMuZ2V0TG9nVHlwZXMoKSkuc2hvdWxkLmVxbChbJ29uZScsICd0d28nXSk7XG4gICAgfSk7XG4gIH0pO1xuICBkZXNjcmliZSgnZ2V0TG9nJywgZnVuY3Rpb24gKCkge1xuICAgIGJlZm9yZUVhY2goZnVuY3Rpb24gKCkge1xuICAgICAgc2lub24uc3B5KFNVUFBPUlRFRF9MT0dfVFlQRVMub25lLCAnZ2V0dGVyJyk7XG4gICAgICBzaW5vbi5zcHkoU1VQUE9SVEVEX0xPR19UWVBFUy50d28sICdnZXR0ZXInKTtcbiAgICB9KTtcbiAgICBhZnRlckVhY2goZnVuY3Rpb24gKCkge1xuICAgICAgU1VQUE9SVEVEX0xPR19UWVBFUy5vbmUuZ2V0dGVyLnJlc3RvcmUoKTtcbiAgICAgIFNVUFBPUlRFRF9MT0dfVFlQRVMudHdvLmdldHRlci5yZXN0b3JlKCk7XG4gICAgfSk7XG4gICAgaXQoJ3Nob3VsZCB0aHJvdyBlcnJvciBpZiBsb2cgdHlwZSBub3Qgc3VwcG9ydGVkJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgICAgYXdhaXQgbG9nQ29tbWFuZHMuZ2V0TG9nKCdvbmUnKS5zaG91bGQuZXZlbnR1YWxseS5iZS5yZWplY3RlZDtcbiAgICAgIFNVUFBPUlRFRF9MT0dfVFlQRVMub25lLmdldHRlci5jYWxsZWQuc2hvdWxkLmJlLmZhbHNlO1xuICAgICAgU1VQUE9SVEVEX0xPR19UWVBFUy50d28uZ2V0dGVyLmNhbGxlZC5zaG91bGQuYmUuZmFsc2U7XG4gICAgfSk7XG4gICAgaXQoJ3Nob3VsZCB0aHJvdyBhbiBlcnJvciB3aXRoIGF2YWlsYWJsZSBsb2cgdHlwZXMgaWYgbG9nIHR5cGUgbm90IHN1cHBvcnRlZCcsIGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICAgIGxvZ0NvbW1hbmRzLnN1cHBvcnRlZExvZ1R5cGVzID0gU1VQUE9SVEVEX0xPR19UWVBFUztcbiAgICAgIGxldCBlcnI7XG4gICAgICB0cnkge1xuICAgICAgICBhd2FpdCBsb2dDb21tYW5kcy5nZXRMb2coJ3RocmVlJyk7XG4gICAgICB9IGNhdGNoIChfZXJyKSB7XG4gICAgICAgIGVyciA9IF9lcnI7XG4gICAgICB9XG4gICAgICBleHBlY3QoZXJyKS50by5leGlzdDtcbiAgICAgIGVyci5tZXNzYWdlLnNob3VsZC5lcWwoYFVuc3VwcG9ydGVkIGxvZyB0eXBlICd0aHJlZScuIFN1cHBvcnRlZCB0eXBlczoge1wib25lXCI6XCJGaXJzdCBsb2dzXCIsXCJ0d29cIjpcIlNlY29uZHMgbG9nc1wifWApO1xuICAgICAgU1VQUE9SVEVEX0xPR19UWVBFUy5vbmUuZ2V0dGVyLmNhbGxlZC5zaG91bGQuYmUuZmFsc2U7XG4gICAgICBTVVBQT1JURURfTE9HX1RZUEVTLnR3by5nZXR0ZXIuY2FsbGVkLnNob3VsZC5iZS5mYWxzZTtcbiAgICB9KTtcbiAgICBpdCgnc2hvdWxkIGNhbGwgZ2V0dGVyIG9uIGFwcHJvcHJpYXRlIGxvZyB3aGVuIGZvdW5kJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgICAgbG9nQ29tbWFuZHMuc3VwcG9ydGVkTG9nVHlwZXMgPSBTVVBQT1JURURfTE9HX1RZUEVTO1xuICAgICAgbGV0IGxvZ3MgPSBhd2FpdCBsb2dDb21tYW5kcy5nZXRMb2coJ29uZScpO1xuICAgICAgbG9ncy5zaG91bGQuZXFsKEZJUlNUX0xPR1MpO1xuICAgICAgU1VQUE9SVEVEX0xPR19UWVBFUy5vbmUuZ2V0dGVyLmNhbGxlZC5zaG91bGQuYmUudHJ1ZTtcbiAgICAgIFNVUFBPUlRFRF9MT0dfVFlQRVMudHdvLmdldHRlci5jYWxsZWQuc2hvdWxkLmJlLmZhbHNlO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl0sImZpbGUiOiJ0ZXN0L2Jhc2Vkcml2ZXIvY29tbWFuZHMvbG9nLXNwZWNzLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uLy4uIn0=
87
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/basedriver/commands/log-specs.js"],"names":["expect","chai","FIRST_LOGS","SECOND_LOGS","SUPPORTED_LOG_TYPES","one","description","getter","_","clone","two","describe","sandbox","beforeEach","logCommands","supportedLogTypes","log","debug","noop","afterEach","restore","it","getLogTypes","should","eql","spy","getLog","eventually","be","rejected","called","false","err","_err","to","exist","message","logs","true"],"mappings":"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","sourcesContent":["import logCommands from '../../../lib/basedriver/commands/log';\nimport { createSandbox } from 'sinon';\nimport _ from 'lodash';\n\n\nconst expect = chai.expect;\n\nconst FIRST_LOGS = ['first', 'logs'];\nconst SECOND_LOGS = ['second', 'logs'];\nconst SUPPORTED_LOG_TYPES = {\n  one: {\n    description: 'First logs',\n    getter: () => _.clone(FIRST_LOGS),\n  },\n  two: {\n    description: 'Seconds logs',\n    getter: () => _.clone(SECOND_LOGS),\n  },\n};\n\ndescribe('log commands -', function () {\n  let sandbox;\n\n  beforeEach(function () {\n    sandbox = createSandbox();\n    // reset the supported log types\n    logCommands.supportedLogTypes = {};\n    logCommands.log = {debug: _.noop};\n  });\n\n  afterEach(function () {\n    sandbox.restore();\n  });\n\n  describe('getLogTypes', function () {\n    it('should return empty array when no supported log types', async function () {\n      (await logCommands.getLogTypes()).should.eql([]);\n    });\n    it('should return keys to log type object', async function () {\n      logCommands.supportedLogTypes = SUPPORTED_LOG_TYPES;\n      (await logCommands.getLogTypes()).should.eql(['one', 'two']);\n    });\n  });\n  describe('getLog', function () {\n    beforeEach(function () {\n      sandbox.spy(SUPPORTED_LOG_TYPES.one, 'getter');\n      sandbox.spy(SUPPORTED_LOG_TYPES.two, 'getter');\n    });\n    afterEach(function () {\n      SUPPORTED_LOG_TYPES.one.getter.restore();\n      SUPPORTED_LOG_TYPES.two.getter.restore();\n    });\n    it('should throw error if log type not supported', async function () {\n      await logCommands.getLog('one').should.eventually.be.rejected;\n      SUPPORTED_LOG_TYPES.one.getter.called.should.be.false;\n      SUPPORTED_LOG_TYPES.two.getter.called.should.be.false;\n    });\n    it('should throw an error with available log types if log type not supported', async function () {\n      logCommands.supportedLogTypes = SUPPORTED_LOG_TYPES;\n      let err;\n      try {\n        await logCommands.getLog('three');\n      } catch (_err) {\n        err = _err;\n      }\n      expect(err).to.exist;\n      err.message.should.eql(`Unsupported log type 'three'. Supported types: {\"one\":\"First logs\",\"two\":\"Seconds logs\"}`);\n      SUPPORTED_LOG_TYPES.one.getter.called.should.be.false;\n      SUPPORTED_LOG_TYPES.two.getter.called.should.be.false;\n    });\n    it('should call getter on appropriate log when found', async function () {\n      logCommands.supportedLogTypes = SUPPORTED_LOG_TYPES;\n      let logs = await logCommands.getLog('one');\n      logs.should.eql(FIRST_LOGS);\n      SUPPORTED_LOG_TYPES.one.getter.called.should.be.true;\n      SUPPORTED_LOG_TYPES.two.getter.called.should.be.false;\n    });\n  });\n});\n"],"file":"test/basedriver/commands/log-specs.js","sourceRoot":"../../../.."}