@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.
- package/build/lib/basedriver/capabilities.js +3 -1
- package/build/lib/basedriver/commands/find.js +4 -11
- package/build/lib/basedriver/commands/log.js +3 -6
- package/build/lib/basedriver/commands/session.js +18 -27
- package/build/lib/basedriver/commands/settings.js +4 -8
- package/build/lib/basedriver/commands/timeout.js +10 -15
- package/build/lib/basedriver/device-settings.js +14 -2
- package/build/lib/basedriver/driver.js +25 -23
- package/build/lib/basedriver/helpers.js +140 -84
- package/build/lib/express/express-logging.js +2 -2
- package/build/lib/express/idempotency.js +2 -2
- package/build/lib/helpers/capabilities.js +39 -0
- package/build/lib/index.js +7 -7
- package/build/lib/jsonwp-proxy/protocol-converter.js +19 -16
- package/build/lib/jsonwp-proxy/proxy.js +20 -16
- package/build/lib/protocol/errors.js +4 -2
- package/build/lib/protocol/helpers.js +3 -20
- package/build/lib/protocol/protocol.js +44 -45
- package/build/lib/protocol/routes.js +67 -1
- package/build/test/basedriver/capabilities-specs.js +43 -1
- package/build/test/basedriver/capability-specs.js +126 -167
- package/build/test/basedriver/commands/log-specs.js +12 -5
- package/build/test/basedriver/driver-tests.js +11 -14
- package/build/test/basedriver/helpers-specs.js +5 -1
- package/build/test/basedriver/timeout-specs.js +7 -9
- package/build/test/express/server-e2e-specs.js +10 -5
- package/build/test/express/server-specs.js +22 -16
- package/build/test/express/static-specs.js +10 -5
- package/build/test/jsonwp-proxy/proxy-e2e-specs.js +1 -2
- package/build/test/jsonwp-proxy/proxy-specs.js +1 -6
- package/build/test/protocol/fake-driver.js +12 -15
- package/build/test/protocol/protocol-e2e-specs.js +49 -103
- package/build/test/protocol/routes-specs.js +2 -2
- package/lib/basedriver/capabilities.js +3 -0
- package/lib/basedriver/commands/find.js +3 -6
- package/lib/basedriver/commands/log.js +2 -4
- package/lib/basedriver/commands/session.js +21 -22
- package/lib/basedriver/commands/settings.js +3 -5
- package/lib/basedriver/commands/timeout.js +9 -10
- package/lib/basedriver/device-settings.js +10 -1
- package/lib/basedriver/driver.js +29 -16
- package/lib/basedriver/helpers.js +201 -83
- package/lib/express/express-logging.js +1 -1
- package/lib/express/idempotency.js +1 -1
- package/lib/helpers/capabilities.js +25 -0
- package/lib/index.js +6 -4
- package/lib/jsonwp-proxy/protocol-converter.js +15 -18
- package/lib/jsonwp-proxy/proxy.js +17 -15
- package/lib/protocol/errors.js +1 -1
- package/lib/protocol/helpers.js +5 -25
- package/lib/protocol/protocol.js +43 -54
- package/lib/protocol/routes.js +60 -1
- package/package.json +29 -22
- package/test/basedriver/capabilities-specs.js +34 -2
- package/test/basedriver/capability-specs.js +120 -146
- package/test/basedriver/commands/log-specs.js +12 -3
- package/test/basedriver/driver-tests.js +12 -7
- package/test/basedriver/helpers-specs.js +4 -0
- package/test/basedriver/timeout-specs.js +6 -11
- package/build/lib/protocol/sessions-cache.js +0 -88
- 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 =
|
|
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
|
-
|
|
24
|
+
sandbox = (0, _sinon.createSandbox)();
|
|
25
|
+
sandbox.spy(d.log, 'warn');
|
|
26
|
+
sandbox.spy(_logger.default, 'warn');
|
|
23
27
|
});
|
|
24
28
|
afterEach(function () {
|
|
25
|
-
|
|
29
|
+
sandbox.restore();
|
|
26
30
|
});
|
|
27
31
|
it('should require platformName and deviceName', async function () {
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
}
|
|
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
|
-
|
|
40
|
-
|
|
41
|
-
'deviceName': 'Delorean'
|
|
42
|
-
}
|
|
43
|
-
}
|
|
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
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
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
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
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
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
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
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
'
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
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
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
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
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
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,
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
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(
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
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(
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
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(
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
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
|
-
|
|
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 =
|
|
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
|
-
|
|
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,
|
|
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":"../../../.."}
|