appium 2.0.0-beta.2 → 2.0.0-beta.23
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/README.md +9 -9
- package/build/check-npm-pack-files.js +23 -0
- package/build/commands-yml/parse.js +319 -0
- package/build/commands-yml/validator.js +130 -0
- package/build/index.js +19 -0
- package/build/lib/appium-config.schema.json +0 -0
- package/build/lib/appium.js +160 -53
- package/build/lib/cli/args.js +115 -279
- package/build/lib/cli/driver-command.js +11 -1
- package/build/lib/cli/extension-command.js +60 -8
- package/build/lib/cli/extension.js +30 -7
- package/build/lib/cli/npm.js +43 -29
- package/build/lib/cli/parser.js +156 -89
- package/build/lib/cli/plugin-command.js +11 -1
- package/build/lib/cli/utils.js +29 -3
- package/build/lib/config-file.js +141 -0
- package/build/lib/config.js +53 -65
- package/build/lib/driver-config.js +42 -19
- package/build/lib/drivers.js +8 -4
- package/build/lib/ext-config-io.js +165 -0
- package/build/lib/extension-config.js +130 -61
- package/build/lib/grid-register.js +22 -24
- package/build/lib/logger.js +3 -3
- package/build/lib/logsink.js +11 -13
- package/build/lib/main.js +197 -77
- package/build/lib/plugin-config.js +21 -11
- package/build/lib/plugins.js +4 -2
- package/build/lib/schema/appium-config-schema.js +253 -0
- package/build/lib/schema/arg-spec.js +120 -0
- package/build/lib/schema/cli-args.js +188 -0
- package/build/lib/schema/cli-transformers.js +76 -0
- package/build/lib/schema/index.js +36 -0
- package/build/lib/schema/keywords.js +72 -0
- package/build/lib/schema/schema.js +357 -0
- package/build/lib/utils.js +44 -99
- package/build/postinstall.js +90 -0
- package/build/test/cli/cli-e2e-specs.js +221 -0
- package/build/test/cli/cli-helpers.js +86 -0
- package/build/test/cli/cli-specs.js +71 -0
- package/build/test/cli/fixtures/test-driver/package.json +27 -0
- package/build/test/cli/schema-args-specs.js +48 -0
- package/build/test/cli/schema-e2e-specs.js +47 -0
- package/build/test/config-e2e-specs.js +112 -0
- package/build/test/config-file-e2e-specs.js +209 -0
- package/build/test/config-file-specs.js +281 -0
- package/build/test/config-specs.js +159 -0
- package/build/test/driver-e2e-specs.js +435 -0
- package/build/test/driver-specs.js +321 -0
- package/build/test/ext-config-io-specs.js +181 -0
- package/build/test/extension-config-specs.js +365 -0
- package/build/test/fixtures/allow-feat.txt +5 -0
- package/build/test/fixtures/caps.json +3 -0
- package/build/test/fixtures/config/allow-insecure.txt +3 -0
- package/build/test/fixtures/config/appium.config.bad-nodeconfig.json +5 -0
- package/build/test/fixtures/config/appium.config.bad.json +32 -0
- package/build/test/fixtures/config/appium.config.ext-good.json +9 -0
- package/build/test/fixtures/config/appium.config.ext-unknown-props.json +10 -0
- package/build/test/fixtures/config/appium.config.good.js +40 -0
- package/build/test/fixtures/config/appium.config.good.json +33 -0
- package/build/test/fixtures/config/appium.config.good.yaml +30 -0
- package/build/test/fixtures/config/appium.config.invalid.json +31 -0
- package/build/test/fixtures/config/appium.config.security-array.json +5 -0
- package/build/test/fixtures/config/appium.config.security-delimited.json +5 -0
- package/build/test/fixtures/config/appium.config.security-path.json +5 -0
- package/build/test/fixtures/config/driver-fake.config.json +8 -0
- package/build/test/fixtures/config/nodeconfig.json +3 -0
- package/build/test/fixtures/config/plugin-fake.config.json +0 -0
- package/build/test/fixtures/default-args.js +35 -0
- package/build/test/fixtures/deny-feat.txt +5 -0
- package/build/test/fixtures/driver.schema.js +20 -0
- package/build/test/fixtures/extensions.yaml +27 -0
- package/build/test/fixtures/flattened-schema.js +504 -0
- package/build/test/fixtures/plugin.schema.js +20 -0
- package/build/test/fixtures/schema-with-extensions.js +28 -0
- package/build/test/grid-register-specs.js +74 -0
- package/build/test/helpers.js +75 -0
- package/build/test/logger-specs.js +76 -0
- package/build/test/npm-specs.js +20 -0
- package/build/test/parser-specs.js +314 -0
- package/build/test/plugin-e2e-specs.js +316 -0
- package/build/test/schema/arg-spec-specs.js +70 -0
- package/build/test/schema/cli-args-specs.js +431 -0
- package/build/test/schema/schema-specs.js +389 -0
- package/build/test/utils-specs.js +266 -0
- package/index.js +11 -0
- package/lib/appium-config.schema.json +278 -0
- package/lib/appium.js +207 -65
- package/lib/cli/args.js +174 -375
- package/lib/cli/driver-command.js +4 -0
- package/lib/cli/extension-command.js +70 -5
- package/lib/cli/extension.js +25 -5
- package/lib/cli/npm.js +86 -18
- package/lib/cli/parser.js +257 -79
- package/lib/cli/plugin-command.js +4 -0
- package/lib/cli/utils.js +21 -1
- package/lib/config-file.js +227 -0
- package/lib/config.js +84 -63
- package/lib/driver-config.js +66 -11
- package/lib/drivers.js +4 -1
- package/lib/ext-config-io.js +287 -0
- package/lib/extension-config.js +225 -67
- package/lib/grid-register.js +27 -24
- package/lib/logger.js +1 -1
- package/lib/logsink.js +10 -7
- package/lib/main.js +214 -77
- package/lib/plugin-config.js +35 -6
- package/lib/plugins.js +1 -0
- package/lib/schema/appium-config-schema.js +287 -0
- package/lib/schema/arg-spec.js +222 -0
- package/lib/schema/cli-args.js +285 -0
- package/lib/schema/cli-transformers.js +123 -0
- package/lib/schema/index.js +2 -0
- package/lib/schema/keywords.js +135 -0
- package/lib/schema/schema.js +577 -0
- package/lib/utils.js +42 -88
- package/package.json +55 -84
- package/postinstall.js +71 -0
- package/types/appium-config.d.ts +197 -0
- package/types/types.d.ts +201 -0
- package/CHANGELOG.md +0 -3515
- package/build/lib/cli/parser-helpers.js +0 -82
- package/lib/cli/parser-helpers.js +0 -79
|
@@ -0,0 +1,435 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
require("source-map-support/register");
|
|
6
|
+
|
|
7
|
+
var _lodash = _interopRequireDefault(require("lodash"));
|
|
8
|
+
|
|
9
|
+
var _path = _interopRequireDefault(require("path"));
|
|
10
|
+
|
|
11
|
+
var _bluebird = _interopRequireDefault(require("bluebird"));
|
|
12
|
+
|
|
13
|
+
var _axios = _interopRequireDefault(require("axios"));
|
|
14
|
+
|
|
15
|
+
var _webdriverio = require("webdriverio");
|
|
16
|
+
|
|
17
|
+
var _main = require("../lib/main");
|
|
18
|
+
|
|
19
|
+
var _extensionConfig = require("../lib/extension-config");
|
|
20
|
+
|
|
21
|
+
var _helpers = require("./helpers");
|
|
22
|
+
|
|
23
|
+
var _baseDriver = require("@appium/base-driver");
|
|
24
|
+
|
|
25
|
+
var _driverConfig = _interopRequireDefault(require("../lib/driver-config"));
|
|
26
|
+
|
|
27
|
+
var _extension = require("../lib/cli/extension");
|
|
28
|
+
|
|
29
|
+
var _utils = require("../lib/utils");
|
|
30
|
+
|
|
31
|
+
var _sinon = _interopRequireDefault(require("sinon"));
|
|
32
|
+
|
|
33
|
+
let TEST_SERVER;
|
|
34
|
+
let TEST_PORT;
|
|
35
|
+
const sillyWebServerPort = 1234;
|
|
36
|
+
const sillyWebServerHost = 'hey';
|
|
37
|
+
const FAKE_ARGS = {
|
|
38
|
+
sillyWebServerPort,
|
|
39
|
+
sillyWebServerHost
|
|
40
|
+
};
|
|
41
|
+
const FAKE_DRIVER_ARGS = {
|
|
42
|
+
driver: {
|
|
43
|
+
fake: FAKE_ARGS
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
const shouldStartServer = process.env.USE_RUNNING_SERVER !== '0';
|
|
47
|
+
const caps = _helpers.W3C_PREFIXED_CAPS;
|
|
48
|
+
const wdOpts = {
|
|
49
|
+
hostname: _helpers.TEST_HOST,
|
|
50
|
+
port: null,
|
|
51
|
+
connectionRetryCount: 0
|
|
52
|
+
};
|
|
53
|
+
describe('FakeDriver - via HTTP', function () {
|
|
54
|
+
let server = null;
|
|
55
|
+
const appiumHome = _extensionConfig.DEFAULT_APPIUM_HOME;
|
|
56
|
+
let FakeDriver = null;
|
|
57
|
+
let baseUrl;
|
|
58
|
+
|
|
59
|
+
const FAKE_DRIVER_DIR = _path.default.join(_helpers.PROJECT_ROOT, 'packages', 'fake-driver');
|
|
60
|
+
|
|
61
|
+
before(async function () {
|
|
62
|
+
wdOpts.port = TEST_PORT = await (0, _helpers.getTestPort)();
|
|
63
|
+
TEST_SERVER = `http://${_helpers.TEST_HOST}:${TEST_PORT}`;
|
|
64
|
+
baseUrl = `${TEST_SERVER}/session`;
|
|
65
|
+
const driverList = await (0, _extension.runExtensionCommand)({
|
|
66
|
+
appiumHome,
|
|
67
|
+
driverCommand: 'list',
|
|
68
|
+
showInstalled: true
|
|
69
|
+
}, _extensionConfig.DRIVER_TYPE);
|
|
70
|
+
|
|
71
|
+
if (!_lodash.default.has(driverList, 'fake')) {
|
|
72
|
+
await (0, _extension.runExtensionCommand)({
|
|
73
|
+
appiumHome,
|
|
74
|
+
driverCommand: 'install',
|
|
75
|
+
driver: FAKE_DRIVER_DIR,
|
|
76
|
+
installType: _extensionConfig.INSTALL_TYPE_LOCAL
|
|
77
|
+
}, _extensionConfig.DRIVER_TYPE);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
const config = _driverConfig.default.getInstance(appiumHome);
|
|
81
|
+
|
|
82
|
+
FakeDriver = config.require('fake');
|
|
83
|
+
await serverStart();
|
|
84
|
+
});
|
|
85
|
+
after(async function () {
|
|
86
|
+
await serverClose();
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
async function serverStart(args = {}) {
|
|
90
|
+
args = {
|
|
91
|
+
port: TEST_PORT,
|
|
92
|
+
host: _helpers.TEST_HOST,
|
|
93
|
+
appiumHome,
|
|
94
|
+
...args
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
if (shouldStartServer) {
|
|
98
|
+
server = await (0, _main.main)(args);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
async function serverClose() {
|
|
103
|
+
if (server) {
|
|
104
|
+
await server.close();
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
describe('server updating', function () {
|
|
109
|
+
it('should allow drivers to update the server in arbitrary ways', async function () {
|
|
110
|
+
const {
|
|
111
|
+
data
|
|
112
|
+
} = await _axios.default.get(`${TEST_SERVER}/fakedriver`);
|
|
113
|
+
data.should.eql({
|
|
114
|
+
fakedriver: 'fakeResponse'
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
});
|
|
118
|
+
describe('cli args handling for empty args', function () {
|
|
119
|
+
it('should not recieve user cli args if none passed in', async function () {
|
|
120
|
+
let driver = await (0, _webdriverio.remote)({ ...wdOpts,
|
|
121
|
+
capabilities: caps
|
|
122
|
+
});
|
|
123
|
+
const {
|
|
124
|
+
sessionId
|
|
125
|
+
} = driver;
|
|
126
|
+
|
|
127
|
+
try {
|
|
128
|
+
const {
|
|
129
|
+
data
|
|
130
|
+
} = await _axios.default.get(`${baseUrl}/${sessionId}/fakedriverargs`);
|
|
131
|
+
should.not.exist(data.value.sillyWebServerPort);
|
|
132
|
+
should.not.exist(data.value.sillyWebServerHost);
|
|
133
|
+
} finally {
|
|
134
|
+
await driver.deleteSession();
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
describe('cli args handling for passed in args', function () {
|
|
139
|
+
before(async function () {
|
|
140
|
+
await serverClose();
|
|
141
|
+
await serverStart(FAKE_DRIVER_ARGS);
|
|
142
|
+
});
|
|
143
|
+
after(async function () {
|
|
144
|
+
await serverClose();
|
|
145
|
+
await serverStart();
|
|
146
|
+
});
|
|
147
|
+
it('should receive user cli args from a driver if arguments were passed in', async function () {
|
|
148
|
+
let driver = await (0, _webdriverio.remote)({ ...wdOpts,
|
|
149
|
+
capabilities: caps
|
|
150
|
+
});
|
|
151
|
+
const {
|
|
152
|
+
sessionId
|
|
153
|
+
} = driver;
|
|
154
|
+
|
|
155
|
+
try {
|
|
156
|
+
const {
|
|
157
|
+
data
|
|
158
|
+
} = await _axios.default.get(`${baseUrl}/${sessionId}/fakedriverargs`);
|
|
159
|
+
data.value.sillyWebServerPort.should.eql(sillyWebServerPort);
|
|
160
|
+
data.value.sillyWebServerHost.should.eql(sillyWebServerHost);
|
|
161
|
+
} finally {
|
|
162
|
+
await driver.deleteSession();
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
});
|
|
166
|
+
describe('session handling', function () {
|
|
167
|
+
it('should start and stop a session and not allow commands after session stopped', async function () {
|
|
168
|
+
let driver = await (0, _webdriverio.remote)({ ...wdOpts,
|
|
169
|
+
capabilities: caps
|
|
170
|
+
});
|
|
171
|
+
should.exist(driver.sessionId);
|
|
172
|
+
driver.sessionId.should.be.a('string');
|
|
173
|
+
await driver.deleteSession();
|
|
174
|
+
await driver.getTitle().should.eventually.be.rejectedWith(/terminated/);
|
|
175
|
+
});
|
|
176
|
+
it('should be able to run two FakeDriver sessions simultaneously', async function () {
|
|
177
|
+
let driver1 = await (0, _webdriverio.remote)({ ...wdOpts,
|
|
178
|
+
capabilities: caps
|
|
179
|
+
});
|
|
180
|
+
should.exist(driver1.sessionId);
|
|
181
|
+
driver1.sessionId.should.be.a('string');
|
|
182
|
+
let driver2 = await (0, _webdriverio.remote)({ ...wdOpts,
|
|
183
|
+
capabilities: caps
|
|
184
|
+
});
|
|
185
|
+
should.exist(driver2.sessionId);
|
|
186
|
+
driver2.sessionId.should.be.a('string');
|
|
187
|
+
driver2.sessionId.should.not.equal(driver1.sessionId);
|
|
188
|
+
await driver1.deleteSession();
|
|
189
|
+
await driver2.deleteSession();
|
|
190
|
+
});
|
|
191
|
+
it('should not be able to run two FakeDriver sessions simultaneously when one is unique', async function () {
|
|
192
|
+
let uniqueCaps = _lodash.default.clone(caps);
|
|
193
|
+
|
|
194
|
+
uniqueCaps['appium:uniqueApp'] = true;
|
|
195
|
+
let driver1 = await (0, _webdriverio.remote)({ ...wdOpts,
|
|
196
|
+
capabilities: uniqueCaps
|
|
197
|
+
});
|
|
198
|
+
should.exist(driver1.sessionId);
|
|
199
|
+
driver1.sessionId.should.be.a('string');
|
|
200
|
+
await (0, _webdriverio.remote)({ ...wdOpts,
|
|
201
|
+
capabilities: caps
|
|
202
|
+
}).should.eventually.be.rejected;
|
|
203
|
+
await driver1.deleteSession();
|
|
204
|
+
});
|
|
205
|
+
it('should use the newCommandTimeout of the inner Driver on session creation', async function () {
|
|
206
|
+
let localCaps = Object.assign({
|
|
207
|
+
'appium:newCommandTimeout': 0.25
|
|
208
|
+
}, caps);
|
|
209
|
+
let driver = await (0, _webdriverio.remote)({ ...wdOpts,
|
|
210
|
+
capabilities: localCaps
|
|
211
|
+
});
|
|
212
|
+
should.exist(driver.sessionId);
|
|
213
|
+
await _bluebird.default.delay(250);
|
|
214
|
+
await driver.getPageSource().should.eventually.be.rejectedWith(/terminated/);
|
|
215
|
+
});
|
|
216
|
+
it('should accept valid W3C capabilities and start a W3C session', async function () {
|
|
217
|
+
const w3cCaps = {
|
|
218
|
+
capabilities: {
|
|
219
|
+
alwaysMatch: {
|
|
220
|
+
'appium:automationName': 'Fake',
|
|
221
|
+
platformName: 'Fake'
|
|
222
|
+
},
|
|
223
|
+
firstMatch: [{
|
|
224
|
+
'appium:deviceName': 'Fake',
|
|
225
|
+
'appium:app': _helpers.TEST_FAKE_APP
|
|
226
|
+
}]
|
|
227
|
+
}
|
|
228
|
+
};
|
|
229
|
+
const {
|
|
230
|
+
status,
|
|
231
|
+
value,
|
|
232
|
+
sessionId
|
|
233
|
+
} = (await _axios.default.post(baseUrl, w3cCaps)).data;
|
|
234
|
+
|
|
235
|
+
try {
|
|
236
|
+
should.not.exist(status);
|
|
237
|
+
should.not.exist(sessionId);
|
|
238
|
+
value.sessionId.should.be.a.string;
|
|
239
|
+
value.should.exist;
|
|
240
|
+
value.capabilities.should.deep.equal({
|
|
241
|
+
automationName: 'Fake',
|
|
242
|
+
platformName: 'Fake',
|
|
243
|
+
deviceName: 'Fake',
|
|
244
|
+
app: _helpers.TEST_FAKE_APP
|
|
245
|
+
});
|
|
246
|
+
const {
|
|
247
|
+
status: screenshotStatus,
|
|
248
|
+
value: screenshotValue
|
|
249
|
+
} = (await (0, _axios.default)({
|
|
250
|
+
url: `${baseUrl}/${value.sessionId}/screenshot`
|
|
251
|
+
})).data;
|
|
252
|
+
should.not.exist(screenshotStatus);
|
|
253
|
+
screenshotValue.should.match(/^iVBOR/);
|
|
254
|
+
await _axios.default.post(`${baseUrl}/${value.sessionId}/execute/async`, {
|
|
255
|
+
script: '',
|
|
256
|
+
args: ['a']
|
|
257
|
+
}).should.eventually.be.rejectedWith(/405/);
|
|
258
|
+
} finally {
|
|
259
|
+
await _axios.default.delete(`${baseUrl}/${value.sessionId}`);
|
|
260
|
+
}
|
|
261
|
+
});
|
|
262
|
+
it('should reject invalid W3C capabilities and respond with a 400 Bad Parameters error', async function () {
|
|
263
|
+
const badW3Ccaps = {
|
|
264
|
+
capabilities: {
|
|
265
|
+
alwaysMatch: {},
|
|
266
|
+
firstMatch: [{
|
|
267
|
+
'appium:deviceName': 'Fake',
|
|
268
|
+
'appium:app': _helpers.TEST_FAKE_APP
|
|
269
|
+
}]
|
|
270
|
+
}
|
|
271
|
+
};
|
|
272
|
+
await _axios.default.post(baseUrl, badW3Ccaps).should.eventually.be.rejectedWith(/400/);
|
|
273
|
+
});
|
|
274
|
+
it('should accept a combo of W3C and JSONWP capabilities but completely ignore JSONWP', async function () {
|
|
275
|
+
const combinedCaps = {
|
|
276
|
+
'desiredCapabilities': { ...caps,
|
|
277
|
+
jsonwpParam: 'jsonwpParam'
|
|
278
|
+
},
|
|
279
|
+
'capabilities': {
|
|
280
|
+
'alwaysMatch': { ...caps
|
|
281
|
+
},
|
|
282
|
+
'firstMatch': [{
|
|
283
|
+
'appium:w3cParam': 'w3cParam'
|
|
284
|
+
}]
|
|
285
|
+
}
|
|
286
|
+
};
|
|
287
|
+
const {
|
|
288
|
+
status,
|
|
289
|
+
value,
|
|
290
|
+
sessionId
|
|
291
|
+
} = (await _axios.default.post(baseUrl, combinedCaps)).data;
|
|
292
|
+
|
|
293
|
+
try {
|
|
294
|
+
should.not.exist(status);
|
|
295
|
+
should.not.exist(sessionId);
|
|
296
|
+
value.sessionId.should.exist;
|
|
297
|
+
value.capabilities.should.deep.equal({ ...(0, _utils.removeAppiumPrefixes)(caps),
|
|
298
|
+
w3cParam: 'w3cParam'
|
|
299
|
+
});
|
|
300
|
+
} finally {
|
|
301
|
+
await _axios.default.delete(`${baseUrl}/${value.sessionId}`);
|
|
302
|
+
}
|
|
303
|
+
});
|
|
304
|
+
it('should reject bad automation name with an appropriate error', async function () {
|
|
305
|
+
const w3cCaps = {
|
|
306
|
+
capabilities: {
|
|
307
|
+
alwaysMatch: { ...caps,
|
|
308
|
+
'appium:automationName': 'BadAutomationName'
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
};
|
|
312
|
+
await _axios.default.post(baseUrl, w3cCaps).should.eventually.be.rejectedWith(/500/);
|
|
313
|
+
});
|
|
314
|
+
it('should accept capabilities that are provided in the firstMatch array', async function () {
|
|
315
|
+
const w3cCaps = {
|
|
316
|
+
capabilities: {
|
|
317
|
+
alwaysMatch: {},
|
|
318
|
+
firstMatch: [{}, { ...caps
|
|
319
|
+
}]
|
|
320
|
+
}
|
|
321
|
+
};
|
|
322
|
+
const {
|
|
323
|
+
value,
|
|
324
|
+
sessionId,
|
|
325
|
+
status
|
|
326
|
+
} = (await _axios.default.post(baseUrl, w3cCaps)).data;
|
|
327
|
+
|
|
328
|
+
try {
|
|
329
|
+
should.not.exist(status);
|
|
330
|
+
should.not.exist(sessionId);
|
|
331
|
+
value.capabilities.should.deep.equal((0, _utils.removeAppiumPrefixes)(caps));
|
|
332
|
+
} finally {
|
|
333
|
+
await _axios.default.delete(`${baseUrl}/${value.sessionId}`);
|
|
334
|
+
}
|
|
335
|
+
});
|
|
336
|
+
it('should not fall back to MJSONWP if w3c caps are invalid', async function () {
|
|
337
|
+
const combinedCaps = {
|
|
338
|
+
desiredCapabilities: { ...caps
|
|
339
|
+
},
|
|
340
|
+
capabilities: {
|
|
341
|
+
alwaysMatch: {},
|
|
342
|
+
firstMatch: [{}, { ...caps,
|
|
343
|
+
platformName: null,
|
|
344
|
+
'appium:automationName': null,
|
|
345
|
+
'appium:deviceName': null
|
|
346
|
+
}]
|
|
347
|
+
}
|
|
348
|
+
};
|
|
349
|
+
const res = await _axios.default.post(baseUrl, combinedCaps, {
|
|
350
|
+
validateStatus: null
|
|
351
|
+
});
|
|
352
|
+
res.status.should.eql(400);
|
|
353
|
+
res.data.value.error.should.match(/invalid argument/);
|
|
354
|
+
});
|
|
355
|
+
it('should not fall back to MJSONWP even if Inner Driver is not ready for W3C', async function () {
|
|
356
|
+
const combinedCaps = {
|
|
357
|
+
desiredCapabilities: { ...caps
|
|
358
|
+
},
|
|
359
|
+
capabilities: {
|
|
360
|
+
alwaysMatch: { ...caps,
|
|
361
|
+
'appium:deviceName': 'Fake'
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
};
|
|
365
|
+
|
|
366
|
+
const createSessionStub = _sinon.default.stub(FakeDriver.prototype, 'createSession').callsFake(async function (jsonwpCaps) {
|
|
367
|
+
const res = await _baseDriver.BaseDriver.prototype.createSession.call(this, jsonwpCaps);
|
|
368
|
+
this.protocol.should.equal('MJSONWP');
|
|
369
|
+
return res;
|
|
370
|
+
});
|
|
371
|
+
|
|
372
|
+
const res = await _axios.default.post(baseUrl, combinedCaps, {
|
|
373
|
+
validateStatus: null
|
|
374
|
+
});
|
|
375
|
+
const {
|
|
376
|
+
data,
|
|
377
|
+
status
|
|
378
|
+
} = res;
|
|
379
|
+
status.should.eql(500);
|
|
380
|
+
data.value.message.should.match(/older capabilities/);
|
|
381
|
+
createSessionStub.restore();
|
|
382
|
+
});
|
|
383
|
+
it('should allow drivers to update the method map with new routes and commands', async function () {
|
|
384
|
+
let driver = await (0, _webdriverio.remote)({ ...wdOpts,
|
|
385
|
+
capabilities: caps
|
|
386
|
+
});
|
|
387
|
+
const {
|
|
388
|
+
sessionId
|
|
389
|
+
} = driver;
|
|
390
|
+
|
|
391
|
+
try {
|
|
392
|
+
await _axios.default.post(`${baseUrl}/${sessionId}/fakedriver`, {
|
|
393
|
+
thing: {
|
|
394
|
+
yes: 'lolno'
|
|
395
|
+
}
|
|
396
|
+
});
|
|
397
|
+
(await _axios.default.get(`${baseUrl}/${sessionId}/fakedriver`)).data.value.should.eql({
|
|
398
|
+
yes: 'lolno'
|
|
399
|
+
});
|
|
400
|
+
} finally {
|
|
401
|
+
await driver.deleteSession();
|
|
402
|
+
}
|
|
403
|
+
});
|
|
404
|
+
});
|
|
405
|
+
});
|
|
406
|
+
describe.skip('Logsink', function () {
|
|
407
|
+
let server = null;
|
|
408
|
+
let logs = [];
|
|
409
|
+
|
|
410
|
+
let logHandler = function (level, message) {
|
|
411
|
+
logs.push([level, message]);
|
|
412
|
+
};
|
|
413
|
+
|
|
414
|
+
let args = {
|
|
415
|
+
port: TEST_PORT,
|
|
416
|
+
host: _helpers.TEST_HOST,
|
|
417
|
+
appiumHome: _extensionConfig.DEFAULT_APPIUM_HOME,
|
|
418
|
+
logHandler
|
|
419
|
+
};
|
|
420
|
+
before(async function () {
|
|
421
|
+
server = await (0, _main.main)(args);
|
|
422
|
+
});
|
|
423
|
+
after(async function () {
|
|
424
|
+
await server.close();
|
|
425
|
+
});
|
|
426
|
+
it('should send logs to a logHandler passed in by a parent package', function () {
|
|
427
|
+
logs.length.should.be.above(1);
|
|
428
|
+
let welcomeIndex = logs[0][1].includes('versions of node') ? 1 : 0;
|
|
429
|
+
logs[welcomeIndex].length.should.equal(2);
|
|
430
|
+
logs[welcomeIndex][1].should.include('Welcome to Appium');
|
|
431
|
+
});
|
|
432
|
+
});require('source-map-support').install();
|
|
433
|
+
|
|
434
|
+
|
|
435
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/driver-e2e-specs.js"],"names":["TEST_SERVER","TEST_PORT","sillyWebServerPort","sillyWebServerHost","FAKE_ARGS","FAKE_DRIVER_ARGS","driver","fake","shouldStartServer","process","env","USE_RUNNING_SERVER","caps","W3C_PREFIXED_CAPS","wdOpts","hostname","TEST_HOST","port","connectionRetryCount","describe","server","appiumHome","DEFAULT_APPIUM_HOME","FakeDriver","baseUrl","FAKE_DRIVER_DIR","path","join","PROJECT_ROOT","before","driverList","driverCommand","showInstalled","DRIVER_TYPE","_","has","installType","INSTALL_TYPE_LOCAL","config","DriverConfig","getInstance","require","serverStart","after","serverClose","args","host","close","it","data","axios","get","should","eql","fakedriver","capabilities","sessionId","not","exist","value","deleteSession","be","a","getTitle","eventually","rejectedWith","driver1","driver2","equal","uniqueCaps","clone","rejected","localCaps","Object","assign","B","delay","getPageSource","w3cCaps","alwaysMatch","platformName","firstMatch","TEST_FAKE_APP","status","post","string","deep","automationName","deviceName","app","screenshotStatus","screenshotValue","url","match","script","delete","badW3Ccaps","combinedCaps","jsonwpParam","w3cParam","desiredCapabilities","res","validateStatus","error","createSessionStub","sinon","stub","prototype","callsFake","jsonwpCaps","BaseDriver","createSession","call","protocol","message","restore","thing","yes","skip","logs","logHandler","level","push","length","above","welcomeIndex","includes","include"],"mappings":"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","sourcesContent":["// transpile:mocha\n\nimport _ from 'lodash';\nimport path from 'path';\nimport B from 'bluebird';\nimport axios from 'axios';\nimport { remote as wdio } from 'webdriverio';\nimport { main as appiumServer } from '../lib/main';\nimport { DEFAULT_APPIUM_HOME, INSTALL_TYPE_LOCAL, DRIVER_TYPE } from '../lib/extension-config';\nimport { W3C_PREFIXED_CAPS, TEST_FAKE_APP, TEST_HOST, getTestPort, PROJECT_ROOT } from './helpers';\nimport { BaseDriver } from '@appium/base-driver';\nimport DriverConfig from '../lib/driver-config';\nimport { runExtensionCommand } from '../lib/cli/extension';\nimport { removeAppiumPrefixes } from '../lib/utils';\nimport sinon from 'sinon';\n\n\nlet TEST_SERVER;\nlet TEST_PORT;\nconst sillyWebServerPort = 1234;\nconst sillyWebServerHost = 'hey';\nconst FAKE_ARGS = {sillyWebServerPort, sillyWebServerHost};\nconst FAKE_DRIVER_ARGS = {driver: {fake: FAKE_ARGS}};\nconst shouldStartServer = process.env.USE_RUNNING_SERVER !== '0';\nconst caps = W3C_PREFIXED_CAPS;\nconst wdOpts = {\n  hostname: TEST_HOST,\n  port: null,\n  connectionRetryCount: 0,\n};\n\ndescribe('FakeDriver - via HTTP', function () {\n  let server = null;\n  const appiumHome = DEFAULT_APPIUM_HOME;\n  // since we update the FakeDriver.prototype below, make sure we update the FakeDriver which is\n  // actually going to be required by Appium\n  let FakeDriver = null;\n  let baseUrl;\n  const FAKE_DRIVER_DIR = path.join(PROJECT_ROOT, 'packages', 'fake-driver');\n  before(async function () {\n    wdOpts.port = TEST_PORT = await getTestPort();\n    TEST_SERVER = `http://${TEST_HOST}:${TEST_PORT}`;\n    baseUrl = `${TEST_SERVER}/session`;\n    // first ensure we have fakedriver installed\n    const driverList = await runExtensionCommand({\n      appiumHome,\n      driverCommand: 'list',\n      showInstalled: true,\n    }, DRIVER_TYPE);\n    if (!_.has(driverList, 'fake')) {\n      await runExtensionCommand({\n        appiumHome,\n        driverCommand: 'install',\n        driver: FAKE_DRIVER_DIR,\n        installType: INSTALL_TYPE_LOCAL,\n      }, DRIVER_TYPE);\n    }\n\n    const config = DriverConfig.getInstance(appiumHome);\n    FakeDriver = config.require('fake');\n    // then start server if we need to\n    await serverStart();\n  });\n\n  after(async function () {\n    await serverClose();\n  });\n\n  async function serverStart (args = {}) {\n    args = {port: TEST_PORT, host: TEST_HOST, appiumHome, ...args};\n    if (shouldStartServer) {\n      server = await appiumServer(args);\n    }\n  }\n\n  async function serverClose () {\n    if (server) {\n      await server.close();\n    }\n  }\n\n  describe('server updating', function () {\n    it('should allow drivers to update the server in arbitrary ways', async function () {\n      const {data} = await axios.get(`${TEST_SERVER}/fakedriver`);\n      data.should.eql({fakedriver: 'fakeResponse'});\n    });\n  });\n\n  describe('cli args handling for empty args', function () {\n    it('should not recieve user cli args if none passed in', async function () {\n      let driver = await wdio({...wdOpts, capabilities: caps});\n      const {sessionId} = driver;\n      try {\n        const {data} = await axios.get(`${baseUrl}/${sessionId}/fakedriverargs`);\n        should.not.exist(data.value.sillyWebServerPort);\n        should.not.exist(data.value.sillyWebServerHost);\n      } finally {\n        await driver.deleteSession();\n      }\n    });\n  });\n\n  describe('cli args handling for passed in args', function () {\n    before(async function () {\n      await serverClose();\n      await serverStart(FAKE_DRIVER_ARGS);\n    });\n    after(async function () {\n      await serverClose();\n      await serverStart();\n    });\n    it('should receive user cli args from a driver if arguments were passed in', async function () {\n      let driver = await wdio({...wdOpts, capabilities: caps});\n      const {sessionId} = driver;\n      try {\n        const {data} = await axios.get(`${baseUrl}/${sessionId}/fakedriverargs`);\n        data.value.sillyWebServerPort.should.eql(sillyWebServerPort);\n        data.value.sillyWebServerHost.should.eql(sillyWebServerHost);\n      } finally {\n        await driver.deleteSession();\n      }\n    });\n  });\n\n  describe('session handling', function () {\n    it('should start and stop a session and not allow commands after session stopped', async function () {\n      let driver = await wdio({...wdOpts, capabilities: caps});\n      should.exist(driver.sessionId);\n      driver.sessionId.should.be.a('string');\n      await driver.deleteSession();\n      await driver.getTitle().should.eventually.be.rejectedWith(/terminated/);\n    });\n\n    it('should be able to run two FakeDriver sessions simultaneously', async function () {\n      let driver1 = await wdio({...wdOpts, capabilities: caps});\n      should.exist(driver1.sessionId);\n      driver1.sessionId.should.be.a('string');\n      let driver2 = await wdio({...wdOpts, capabilities: caps});\n      should.exist(driver2.sessionId);\n      driver2.sessionId.should.be.a('string');\n      driver2.sessionId.should.not.equal(driver1.sessionId);\n      await driver1.deleteSession();\n      await driver2.deleteSession();\n    });\n\n    it('should not be able to run two FakeDriver sessions simultaneously when one is unique', async function () {\n      let uniqueCaps = _.clone(caps);\n      uniqueCaps['appium:uniqueApp'] = true;\n      let driver1 = await wdio({...wdOpts, capabilities: uniqueCaps});\n      should.exist(driver1.sessionId);\n      driver1.sessionId.should.be.a('string');\n      await wdio({...wdOpts, capabilities: caps}).should.eventually.be.rejected;\n      await driver1.deleteSession();\n    });\n\n    it('should use the newCommandTimeout of the inner Driver on session creation', async function () {\n      let localCaps = Object.assign({\n        'appium:newCommandTimeout': 0.25,\n      }, caps);\n      let driver = await wdio({...wdOpts, capabilities: localCaps});\n      should.exist(driver.sessionId);\n\n      await B.delay(250);\n      await driver.getPageSource().should.eventually.be.rejectedWith(/terminated/);\n    });\n\n    it('should accept valid W3C capabilities and start a W3C session', async function () {\n      // Try with valid capabilities and check that it returns a session ID\n      const w3cCaps = {\n        capabilities: {\n          alwaysMatch: {'appium:automationName': 'Fake', platformName: 'Fake'},\n          firstMatch: [{'appium:deviceName': 'Fake', 'appium:app': TEST_FAKE_APP}],\n        }\n      };\n\n      // Create the session\n      const {status, value, sessionId} = (await axios.post(baseUrl, w3cCaps)).data;\n      try {\n        should.not.exist(status); // Test that it's a W3C session by checking that 'status' is not in the response\n        should.not.exist(sessionId);\n        value.sessionId.should.be.a.string;\n        value.should.exist;\n        value.capabilities.should.deep.equal({\n          automationName: 'Fake',\n          platformName: 'Fake',\n          deviceName: 'Fake',\n          app: TEST_FAKE_APP,\n        });\n\n        // Now use that sessionId to call /screenshot\n        const {status: screenshotStatus, value: screenshotValue} = (await axios({url: `${baseUrl}/${value.sessionId}/screenshot`})).data;\n        should.not.exist(screenshotStatus);\n        screenshotValue.should.match(/^iVBOR/); // should be a png\n\n        // Now use that sessionID to call an arbitrary W3C-only endpoint that isn't implemented to see if it responds with correct error\n        await axios.post(\n          `${baseUrl}/${value.sessionId}/execute/async`,\n          {script: '', args: ['a']}).should.eventually.be.rejectedWith(/405/);\n      } finally {\n        // End session\n        await axios.delete(`${baseUrl}/${value.sessionId}`);\n      }\n    });\n\n    it('should reject invalid W3C capabilities and respond with a 400 Bad Parameters error', async function () {\n      const badW3Ccaps = {\n        capabilities: {\n          alwaysMatch: {},\n          firstMatch: [{'appium:deviceName': 'Fake', 'appium:app': TEST_FAKE_APP}],\n        }\n      };\n\n      await axios.post(baseUrl, badW3Ccaps).should.eventually.be.rejectedWith(/400/);\n    });\n\n    it('should accept a combo of W3C and JSONWP capabilities but completely ignore JSONWP', async function () {\n      const combinedCaps = {\n        'desiredCapabilities': {\n          ...caps,\n          jsonwpParam: 'jsonwpParam',\n        },\n        'capabilities': {\n          'alwaysMatch': {...caps},\n          'firstMatch': [{\n            'appium:w3cParam': 'w3cParam',\n          }],\n        }\n      };\n\n      const {status, value, sessionId} = (await axios.post(baseUrl, combinedCaps)).data;\n      try {\n        should.not.exist(status); // If it's a W3C session, should not respond with 'status'\n        should.not.exist(sessionId);\n        value.sessionId.should.exist;\n        value.capabilities.should.deep.equal({\n          ...removeAppiumPrefixes(caps),\n          w3cParam: 'w3cParam',\n        });\n      } finally {\n        // End session\n        await axios.delete(`${baseUrl}/${value.sessionId}`);\n      }\n    });\n\n    it('should reject bad automation name with an appropriate error', async function () {\n      const w3cCaps = {\n        capabilities: {\n          alwaysMatch: {\n            ...caps,\n            'appium:automationName': 'BadAutomationName',\n          },\n        },\n      };\n      await axios.post(baseUrl, w3cCaps).should.eventually.be.rejectedWith(/500/);\n    });\n\n    it('should accept capabilities that are provided in the firstMatch array', async function () {\n      const w3cCaps = {\n        capabilities: {\n          alwaysMatch: {},\n          firstMatch: [{}, {\n            ...caps\n          }],\n        },\n      };\n      const {value, sessionId, status} = (await axios.post(baseUrl, w3cCaps)).data;\n      try {\n        should.not.exist(status);\n        should.not.exist(sessionId);\n        value.capabilities.should.deep.equal(removeAppiumPrefixes(caps));\n      } finally {\n        // End session\n        await axios.delete(`${baseUrl}/${value.sessionId}`);\n      }\n    });\n\n    it('should not fall back to MJSONWP if w3c caps are invalid', async function () {\n      const combinedCaps = {\n        desiredCapabilities: {\n          ...caps,\n        },\n        capabilities: {\n          alwaysMatch: {},\n          firstMatch: [{}, {\n            ...caps,\n            platformName: null,\n            'appium:automationName': null,\n            'appium:deviceName': null,\n          }],\n        },\n      };\n      const res = (await axios.post(baseUrl, combinedCaps, {validateStatus: null}));\n      res.status.should.eql(400);\n      res.data.value.error.should.match(/invalid argument/);\n    });\n\n    it('should not fall back to MJSONWP even if Inner Driver is not ready for W3C', async function () {\n      const combinedCaps = {\n        desiredCapabilities: {\n          ...caps,\n        },\n        capabilities: {\n          alwaysMatch: {\n            ...caps,\n            'appium:deviceName': 'Fake',\n          },\n        },\n      };\n      const createSessionStub = sinon.stub(FakeDriver.prototype, 'createSession').callsFake(async function (jsonwpCaps) {\n        const res = await BaseDriver.prototype.createSession.call(this, jsonwpCaps);\n        this.protocol.should.equal('MJSONWP');\n        return res;\n      });\n\n      const res = (await axios.post(baseUrl, combinedCaps, {validateStatus: null}));\n      const {data, status} = res;\n      status.should.eql(500);\n      data.value.message.should.match(/older capabilities/);\n\n      createSessionStub.restore();\n    });\n\n    it('should allow drivers to update the method map with new routes and commands', async function () {\n      let driver = await wdio({...wdOpts, capabilities: caps});\n      const {sessionId} = driver;\n      try {\n        await axios.post(`${baseUrl}/${sessionId}/fakedriver`, {thing: {yes: 'lolno'}});\n        (await axios.get(`${baseUrl}/${sessionId}/fakedriver`)).data.value.should.eql({yes: 'lolno'});\n      } finally {\n        await driver.deleteSession();\n      }\n    });\n  });\n});\n\n// TODO this test only works if the log has not previously been initialized in the same process.\n// there seems to be some global state that is not cleaned up between tests.\ndescribe.skip('Logsink', function () {\n  let server = null;\n  let logs = [];\n  let logHandler = function (level, message) {\n    logs.push([level, message]);\n  };\n  let args = {\n    port: TEST_PORT,\n    host: TEST_HOST,\n    appiumHome: DEFAULT_APPIUM_HOME,\n    logHandler,\n  };\n\n  before(async function () {\n    server = await appiumServer(args);\n  });\n\n  after(async function () {\n    await server.close();\n  });\n\n  it('should send logs to a logHandler passed in by a parent package', function () {\n    logs.length.should.be.above(1);\n    let welcomeIndex = logs[0][1].includes('versions of node') ? 1 : 0;\n    logs[welcomeIndex].length.should.equal(2);\n    logs[welcomeIndex][1].should.include('Welcome to Appium');\n  });\n});\n"],"file":"test/driver-e2e-specs.js","sourceRoot":"../.."}
|