appium 2.0.0-beta.20 → 2.0.0-beta.24

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 (90) hide show
  1. package/README.md +1 -2
  2. package/build/check-npm-pack-files.js +23 -0
  3. package/build/commands-yml/parse.js +319 -0
  4. package/build/commands-yml/validator.js +130 -0
  5. package/build/index.js +19 -0
  6. package/build/lib/appium.js +22 -7
  7. package/build/lib/cli/args.js +13 -15
  8. package/build/lib/cli/npm.js +27 -16
  9. package/build/lib/cli/parser.js +7 -3
  10. package/build/lib/config.js +27 -47
  11. package/build/lib/extension-config.js +1 -1
  12. package/build/lib/main.js +29 -28
  13. package/build/lib/plugin-config.js +2 -2
  14. package/build/lib/plugins.js +4 -2
  15. package/build/lib/schema/appium-config-schema.js +3 -2
  16. package/build/lib/schema/arg-spec.js +5 -3
  17. package/build/lib/schema/cli-args.js +25 -16
  18. package/build/lib/schema/keywords.js +14 -4
  19. package/build/lib/schema/schema.js +80 -9
  20. package/build/lib/utils.js +16 -36
  21. package/build/postinstall.js +90 -0
  22. package/build/test/cli/cli-e2e-specs.js +221 -0
  23. package/build/test/cli/cli-helpers.js +86 -0
  24. package/build/test/cli/cli-specs.js +71 -0
  25. package/build/test/cli/fixtures/test-driver/package.json +27 -0
  26. package/build/test/cli/schema-args-specs.js +48 -0
  27. package/build/test/cli/schema-e2e-specs.js +47 -0
  28. package/build/test/config-e2e-specs.js +112 -0
  29. package/build/test/config-file-e2e-specs.js +209 -0
  30. package/build/test/config-file-specs.js +281 -0
  31. package/build/test/config-specs.js +246 -0
  32. package/build/test/driver-e2e-specs.js +435 -0
  33. package/build/test/driver-specs.js +386 -0
  34. package/build/test/ext-config-io-specs.js +181 -0
  35. package/build/test/extension-config-specs.js +365 -0
  36. package/build/test/fixtures/allow-feat.txt +5 -0
  37. package/build/test/fixtures/caps.json +3 -0
  38. package/build/test/fixtures/config/allow-insecure.txt +3 -0
  39. package/build/test/fixtures/config/appium.config.bad-nodeconfig.json +5 -0
  40. package/build/test/fixtures/config/appium.config.bad.json +32 -0
  41. package/build/test/fixtures/config/appium.config.ext-good.json +9 -0
  42. package/build/test/fixtures/config/appium.config.ext-unknown-props.json +10 -0
  43. package/build/test/fixtures/config/appium.config.good.js +40 -0
  44. package/build/test/fixtures/config/appium.config.good.json +33 -0
  45. package/build/test/fixtures/config/appium.config.good.yaml +30 -0
  46. package/build/test/fixtures/config/appium.config.invalid.json +31 -0
  47. package/build/test/fixtures/config/appium.config.security-array.json +5 -0
  48. package/build/test/fixtures/config/appium.config.security-delimited.json +5 -0
  49. package/build/test/fixtures/config/appium.config.security-path.json +5 -0
  50. package/build/test/fixtures/config/driver-fake.config.json +8 -0
  51. package/build/test/fixtures/config/nodeconfig.json +3 -0
  52. package/build/test/fixtures/config/plugin-fake.config.json +0 -0
  53. package/build/test/fixtures/default-args.js +35 -0
  54. package/build/test/fixtures/deny-feat.txt +5 -0
  55. package/build/test/fixtures/driver.schema.js +20 -0
  56. package/build/test/fixtures/extensions.yaml +27 -0
  57. package/build/test/fixtures/flattened-schema.js +532 -0
  58. package/build/test/fixtures/plugin.schema.js +20 -0
  59. package/build/test/fixtures/schema-with-extensions.js +28 -0
  60. package/build/test/grid-register-specs.js +74 -0
  61. package/build/test/helpers.js +75 -0
  62. package/build/test/logger-specs.js +76 -0
  63. package/build/test/npm-specs.js +20 -0
  64. package/build/test/parser-specs.js +319 -0
  65. package/build/test/plugin-e2e-specs.js +316 -0
  66. package/build/test/schema/arg-spec-specs.js +70 -0
  67. package/build/test/schema/cli-args-specs.js +408 -0
  68. package/build/test/schema/schema-specs.js +407 -0
  69. package/build/test/utils-specs.js +288 -0
  70. package/index.js +11 -0
  71. package/lib/appium-config.schema.json +2 -1
  72. package/lib/appium.js +51 -8
  73. package/lib/cli/args.js +17 -14
  74. package/lib/cli/npm.js +68 -6
  75. package/lib/cli/parser.js +5 -2
  76. package/lib/config.js +72 -54
  77. package/lib/extension-config.js +1 -1
  78. package/lib/main.js +93 -40
  79. package/lib/plugin-config.js +1 -1
  80. package/lib/plugins.js +2 -0
  81. package/lib/schema/appium-config-schema.js +1 -0
  82. package/lib/schema/arg-spec.js +12 -2
  83. package/lib/schema/cli-args.js +22 -34
  84. package/lib/schema/keywords.js +20 -4
  85. package/lib/schema/schema.js +142 -22
  86. package/lib/utils.js +28 -29
  87. package/package.json +10 -14
  88. package/types/types.d.ts +5 -0
  89. package/build/lib/cli/argparse-actions.js +0 -104
  90. package/lib/cli/argparse-actions.js +0 -77
@@ -0,0 +1,246 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ require("source-map-support/register");
6
+
7
+ var _sinon = _interopRequireDefault(require("sinon"));
8
+
9
+ var _parser = _interopRequireDefault(require("../lib/cli/parser"));
10
+
11
+ var _config = require("../lib/config");
12
+
13
+ var _logger = _interopRequireDefault(require("../lib/logger"));
14
+
15
+ var _schema = require("../lib/schema/schema");
16
+
17
+ describe('Config', function () {
18
+ let sandbox;
19
+ beforeEach(function () {
20
+ sandbox = _sinon.default.createSandbox();
21
+ });
22
+ afterEach(function () {
23
+ sandbox.restore();
24
+ });
25
+ describe('Appium config', function () {
26
+ let log;
27
+ let dir;
28
+ beforeEach(function () {
29
+ log = sandbox.spy(console, 'log');
30
+ dir = sandbox.spy(console, 'dir');
31
+ });
32
+ describe('showBuildInfo()', function () {
33
+ it('should log build info to console', async function () {
34
+ const config = (0, _config.getBuildInfo)();
35
+ await (0, _config.showBuildInfo)();
36
+ log.should.have.been.calledOnce;
37
+ log.firstCall.args.should.contain(JSON.stringify(config));
38
+ });
39
+ });
40
+ describe('showConfig', function () {
41
+ describe('when a config file is present', function () {
42
+ it('should dump the current Appium config', function () {
43
+ (0, _config.showConfig)({
44
+ foo: 'bar'
45
+ }, {
46
+ config: {
47
+ server: {
48
+ address: 'quux'
49
+ }
50
+ }
51
+ }, {
52
+ spam: 'food'
53
+ });
54
+ log.should.have.been.calledWith('Appium Configuration\n');
55
+ });
56
+ it('should skip empty objects', function () {
57
+ (0, _config.showConfig)({
58
+ foo: 'bar',
59
+ cows: {},
60
+ pigs: [],
61
+ sheep: 0,
62
+ ducks: false
63
+ }, {
64
+ config: {
65
+ server: {
66
+ address: 'quux'
67
+ }
68
+ }
69
+ }, {
70
+ spam: 'food'
71
+ });
72
+ dir.should.have.been.calledWith({
73
+ foo: 'bar',
74
+ sheep: 0,
75
+ ducks: false
76
+ });
77
+ });
78
+ });
79
+ describe('when a config file is not present', function () {
80
+ it('should dump the current Appium config sans config file contents', function () {
81
+ (0, _config.showConfig)({
82
+ foo: 'bar'
83
+ }, {}, {
84
+ spam: 'food'
85
+ });
86
+ log.should.have.been.calledWith('(no configuration file loaded)\n');
87
+ });
88
+ });
89
+ });
90
+ });
91
+ describe('node.js config', function () {
92
+ let _process = process;
93
+ before(function () {
94
+ process = { ...process
95
+ };
96
+ });
97
+ after(function () {
98
+ process = _process;
99
+ });
100
+ describe('checkNodeOk', function () {
101
+ describe('unsupported nodes', function () {
102
+ const unsupportedVersions = ['v0.1', 'v0.9.12', 'v0.10.36', 'v0.12.14', 'v4.4.7', 'v5.7.0', 'v6.3.1', 'v7.1.1', 'v8.0.0', 'v9.2.3', 'v10.1.0'];
103
+
104
+ for (const version of unsupportedVersions) {
105
+ it(`should fail if node is ${version}`, function () {
106
+ process.version = version;
107
+
108
+ _config.checkNodeOk.should.throw();
109
+ });
110
+ }
111
+ });
112
+ describe('supported nodes', function () {
113
+ it('should succeed if node is 12+', function () {
114
+ process.version = 'v12.0.1';
115
+
116
+ _config.checkNodeOk.should.not.throw();
117
+ });
118
+ it('should succeed if node is 13+', function () {
119
+ process.version = 'v13.6.0';
120
+
121
+ _config.checkNodeOk.should.not.throw();
122
+ });
123
+ it('should succeed if node is 14+', function () {
124
+ process.version = 'v14.0.0';
125
+
126
+ _config.checkNodeOk.should.not.throw();
127
+ });
128
+ });
129
+ });
130
+ describe('warnNodeDeprecations', function () {
131
+ let spy;
132
+ before(function () {
133
+ spy = sandbox.spy(_logger.default, 'warn');
134
+ });
135
+ beforeEach(function () {
136
+ spy.resetHistory();
137
+ });
138
+ it('should not log a warning if node is 8+', function () {
139
+ process.version = 'v8.0.0';
140
+ (0, _config.warnNodeDeprecations)();
141
+
142
+ _logger.default.warn.callCount.should.equal(0);
143
+ });
144
+ it('should not log a warning if node is 9+', function () {
145
+ process.version = 'v9.0.0';
146
+ (0, _config.warnNodeDeprecations)();
147
+
148
+ _logger.default.warn.callCount.should.equal(0);
149
+ });
150
+ });
151
+ });
152
+ describe('server arguments', function () {
153
+ let args;
154
+ describe('getNonDefaultServerArgs', function () {
155
+ describe('without extension schemas', function () {
156
+ beforeEach(async function () {
157
+ await (0, _parser.default)(true);
158
+ args = (0, _schema.getDefaultsForSchema)();
159
+ });
160
+ it('should show none if we have all the defaults', function () {
161
+ let nonDefaultArgs = (0, _config.getNonDefaultServerArgs)(args);
162
+ nonDefaultArgs.should.be.empty;
163
+ });
164
+ it('should catch a non-default argument', function () {
165
+ args.allowCors = true;
166
+ let nonDefaultArgs = (0, _config.getNonDefaultServerArgs)(args);
167
+ nonDefaultArgs.should.eql({
168
+ allowCors: true
169
+ });
170
+ });
171
+ describe('when arg is an array', function () {
172
+ it('should return the arg as an array', function () {
173
+ args.usePlugins = ['all'];
174
+ (0, _config.getNonDefaultServerArgs)(args).should.eql({
175
+ usePlugins: ['all']
176
+ });
177
+ });
178
+ });
179
+ });
180
+ describe('with extension schemas', function () {
181
+ beforeEach(async function () {
182
+ (0, _schema.resetSchema)();
183
+ (0, _schema.registerSchema)('plugin', 'crypto-fiend', {
184
+ type: 'object',
185
+ properties: {
186
+ elite: {
187
+ type: 'boolean',
188
+ default: true
189
+ }
190
+ }
191
+ });
192
+ (0, _schema.finalizeSchema)();
193
+ await (0, _parser.default)(true);
194
+ args = (0, _schema.getDefaultsForSchema)();
195
+ });
196
+ it('should take extension schemas into account', function () {
197
+ const nonDefaultArgs = (0, _config.getNonDefaultServerArgs)(args);
198
+ nonDefaultArgs.should.be.empty;
199
+ });
200
+ it('should catch a non-default argument', function () {
201
+ args['plugin.crypto-fiend.elite'] = false;
202
+ const nonDefaultArgs = (0, _config.getNonDefaultServerArgs)(args);
203
+ nonDefaultArgs.should.eql({
204
+ 'plugin.crypto-fiend.elite': false
205
+ });
206
+ });
207
+ });
208
+ });
209
+ });
210
+ describe('validateTmpDir', function () {
211
+ it('should fail to use a tmp dir with incorrect permissions', function () {
212
+ (0, _config.validateTmpDir)('/private/if_you_run_with_sudo_this_wont_fail').should.be.rejectedWith(/could not ensure/);
213
+ });
214
+ it('should fail to use an undefined tmp dir', function () {
215
+ (0, _config.validateTmpDir)().should.be.rejectedWith(/could not ensure/);
216
+ });
217
+ it('should be able to use a tmp dir with correct permissions', function () {
218
+ (0, _config.validateTmpDir)('/tmp/test_tmp_dir/with/any/number/of/levels').should.not.be.rejected;
219
+ });
220
+ });
221
+ describe('parsing args with empty argv[1]', function () {
222
+ let argv1;
223
+ before(function () {
224
+ argv1 = process.argv[1];
225
+ });
226
+ beforeEach(function () {
227
+ (0, _schema.resetSchema)();
228
+ });
229
+ after(function () {
230
+ process.argv[1] = argv1;
231
+ });
232
+ it('should not fail if process.argv[1] is undefined', async function () {
233
+ delete process.argv[1];
234
+ let args = await (0, _parser.default)();
235
+ args.prog.should.be.equal('appium');
236
+ });
237
+ it('should set "prog" to process.argv[1]', async function () {
238
+ process.argv[1] = 'Hello World';
239
+ let args = await (0, _parser.default)();
240
+ args.prog.should.be.equal('Hello World');
241
+ });
242
+ });
243
+ });require('source-map-support').install();
244
+
245
+
246
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/config-specs.js"],"names":["describe","sandbox","beforeEach","sinon","createSandbox","afterEach","restore","log","dir","spy","console","it","config","should","have","been","calledOnce","firstCall","args","contain","JSON","stringify","foo","server","address","spam","calledWith","cows","pigs","sheep","ducks","_process","process","before","after","unsupportedVersions","version","checkNodeOk","throw","not","logger","resetHistory","warn","callCount","equal","nonDefaultArgs","be","empty","allowCors","eql","usePlugins","type","properties","elite","default","rejectedWith","rejected","argv1","argv","prog"],"mappings":";;;;;;AAGA;;AACA;;AACA;;AACA;;AACA;;AAEAA,QAAQ,CAAC,QAAD,EAAW,YAAY;AAE7B,MAAIC,OAAJ;AAEAC,EAAAA,UAAU,CAAC,YAAY;AACrBD,IAAAA,OAAO,GAAGE,eAAMC,aAAN,EAAV;AACD,GAFS,CAAV;AAIAC,EAAAA,SAAS,CAAC,YAAY;AACpBJ,IAAAA,OAAO,CAACK,OAAR;AACD,GAFQ,CAAT;AAIAN,EAAAA,QAAQ,CAAC,eAAD,EAAkB,YAAY;AAEpC,QAAIO,GAAJ;AAEA,QAAIC,GAAJ;AACAN,IAAAA,UAAU,CAAC,YAAY;AACrBK,MAAAA,GAAG,GAAGN,OAAO,CAACQ,GAAR,CAAYC,OAAZ,EAAqB,KAArB,CAAN;AACAF,MAAAA,GAAG,GAAGP,OAAO,CAACQ,GAAR,CAAYC,OAAZ,EAAqB,KAArB,CAAN;AACD,KAHS,CAAV;AAKAV,IAAAA,QAAQ,CAAC,iBAAD,EAAoB,YAAY;AACtCW,MAAAA,EAAE,CAAC,kCAAD,EAAqC,kBAAkB;AACvD,cAAMC,MAAM,GAAG,2BAAf;AACA,cAAM,4BAAN;AACAL,QAAAA,GAAG,CAACM,MAAJ,CAAWC,IAAX,CAAgBC,IAAhB,CAAqBC,UAArB;AACAT,QAAAA,GAAG,CAACU,SAAJ,CAAcC,IAAd,CAAmBL,MAAnB,CAA0BM,OAA1B,CAAkCC,IAAI,CAACC,SAAL,CAAeT,MAAf,CAAlC;AACD,OALC,CAAF;AAMD,KAPO,CAAR;AASAZ,IAAAA,QAAQ,CAAC,YAAD,EAAe,YAAY;AACjCA,MAAAA,QAAQ,CAAC,+BAAD,EAAkC,YAAY;AACpDW,QAAAA,EAAE,CAAC,uCAAD,EAA0C,YAAY;AACtD,kCAAW;AAACW,YAAAA,GAAG,EAAE;AAAN,WAAX,EAAyB;AAACV,YAAAA,MAAM,EAAE;AAACW,cAAAA,MAAM,EAAE;AAACC,gBAAAA,OAAO,EAAE;AAAV;AAAT;AAAT,WAAzB,EAAgE;AAACC,YAAAA,IAAI,EAAE;AAAP,WAAhE;AACAlB,UAAAA,GAAG,CAACM,MAAJ,CAAWC,IAAX,CAAgBC,IAAhB,CAAqBW,UAArB,CAAgC,wBAAhC;AACD,SAHC,CAAF;AAKAf,QAAAA,EAAE,CAAC,2BAAD,EAA8B,YAAY;AAC1C,kCAAW;AAACW,YAAAA,GAAG,EAAE,KAAN;AAAaK,YAAAA,IAAI,EAAE,EAAnB;AAAuBC,YAAAA,IAAI,EAAE,EAA7B;AAAiCC,YAAAA,KAAK,EAAE,CAAxC;AAA2CC,YAAAA,KAAK,EAAE;AAAlD,WAAX,EAAqE;AAAClB,YAAAA,MAAM,EAAE;AAACW,cAAAA,MAAM,EAAE;AAACC,gBAAAA,OAAO,EAAE;AAAV;AAAT;AAAT,WAArE,EAA4G;AAACC,YAAAA,IAAI,EAAE;AAAP,WAA5G;AACAjB,UAAAA,GAAG,CAACK,MAAJ,CAAWC,IAAX,CAAgBC,IAAhB,CAAqBW,UAArB,CAAgC;AAACJ,YAAAA,GAAG,EAAE,KAAN;AAAaO,YAAAA,KAAK,EAAE,CAApB;AAAuBC,YAAAA,KAAK,EAAE;AAA9B,WAAhC;AACD,SAHC,CAAF;AAID,OAVO,CAAR;AAYA9B,MAAAA,QAAQ,CAAC,mCAAD,EAAsC,YAAY;AACxDW,QAAAA,EAAE,CAAC,iEAAD,EAAoE,YAAY;AAChF,kCAAW;AAACW,YAAAA,GAAG,EAAE;AAAN,WAAX,EAAyB,EAAzB,EAA6B;AAACG,YAAAA,IAAI,EAAE;AAAP,WAA7B;AACAlB,UAAAA,GAAG,CAACM,MAAJ,CAAWC,IAAX,CAAgBC,IAAhB,CAAqBW,UAArB,CAAgC,kCAAhC;AACD,SAHC,CAAF;AAID,OALO,CAAR;AAMD,KAnBO,CAAR;AAoBD,GAvCO,CAAR;AAyCA1B,EAAAA,QAAQ,CAAC,gBAAD,EAAmB,YAAY;AACrC,QAAI+B,QAAQ,GAAGC,OAAf;AACAC,IAAAA,MAAM,CAAC,YAAY;AAIjBD,MAAAA,OAAO,GAAG,EAAC,GAAGA;AAAJ,OAAV;AACD,KALK,CAAN;AAMAE,IAAAA,KAAK,CAAC,YAAY;AAChBF,MAAAA,OAAO,GAAGD,QAAV;AACD,KAFI,CAAL;AAGA/B,IAAAA,QAAQ,CAAC,aAAD,EAAgB,YAAY;AAClCA,MAAAA,QAAQ,CAAC,mBAAD,EAAsB,YAAY;AACxC,cAAMmC,mBAAmB,GAAG,CAC1B,MAD0B,EAClB,SADkB,EACP,UADO,EACK,UADL,EAE1B,QAF0B,EAEhB,QAFgB,EAEN,QAFM,EAEI,QAFJ,EAG1B,QAH0B,EAGhB,QAHgB,EAGN,SAHM,CAA5B;;AAKA,aAAK,MAAMC,OAAX,IAAsBD,mBAAtB,EAA2C;AACzCxB,UAAAA,EAAE,CAAE,0BAAyByB,OAAQ,EAAnC,EAAsC,YAAY;AAElDJ,YAAAA,OAAO,CAACI,OAAR,GAAkBA,OAAlB;;AACAC,gCAAYxB,MAAZ,CAAmByB,KAAnB;AACD,WAJC,CAAF;AAKD;AACF,OAbO,CAAR;AAeAtC,MAAAA,QAAQ,CAAC,iBAAD,EAAoB,YAAY;AACtCW,QAAAA,EAAE,CAAC,+BAAD,EAAkC,YAAY;AAE9CqB,UAAAA,OAAO,CAACI,OAAR,GAAkB,SAAlB;;AACAC,8BAAYxB,MAAZ,CAAmB0B,GAAnB,CAAuBD,KAAvB;AACD,SAJC,CAAF;AAKA3B,QAAAA,EAAE,CAAC,+BAAD,EAAkC,YAAY;AAE9CqB,UAAAA,OAAO,CAACI,OAAR,GAAkB,SAAlB;;AACAC,8BAAYxB,MAAZ,CAAmB0B,GAAnB,CAAuBD,KAAvB;AACD,SAJC,CAAF;AAKA3B,QAAAA,EAAE,CAAC,+BAAD,EAAkC,YAAY;AAE9CqB,UAAAA,OAAO,CAACI,OAAR,GAAkB,SAAlB;;AACAC,8BAAYxB,MAAZ,CAAmB0B,GAAnB,CAAuBD,KAAvB;AACD,SAJC,CAAF;AAKD,OAhBO,CAAR;AAiBD,KAjCO,CAAR;AAmCAtC,IAAAA,QAAQ,CAAC,sBAAD,EAAyB,YAAY;AAC3C,UAAIS,GAAJ;AACAwB,MAAAA,MAAM,CAAC,YAAY;AACjBxB,QAAAA,GAAG,GAAGR,OAAO,CAACQ,GAAR,CAAY+B,eAAZ,EAAoB,MAApB,CAAN;AACD,OAFK,CAAN;AAGAtC,MAAAA,UAAU,CAAC,YAAY;AACrBO,QAAAA,GAAG,CAACgC,YAAJ;AACD,OAFS,CAAV;AAGA9B,MAAAA,EAAE,CAAC,wCAAD,EAA2C,YAAY;AAEvDqB,QAAAA,OAAO,CAACI,OAAR,GAAkB,QAAlB;AACA;;AACAI,wBAAOE,IAAP,CAAYC,SAAZ,CAAsB9B,MAAtB,CAA6B+B,KAA7B,CAAmC,CAAnC;AACD,OALC,CAAF;AAMAjC,MAAAA,EAAE,CAAC,wCAAD,EAA2C,YAAY;AAEvDqB,QAAAA,OAAO,CAACI,OAAR,GAAkB,QAAlB;AACA;;AACAI,wBAAOE,IAAP,CAAYC,SAAZ,CAAsB9B,MAAtB,CAA6B+B,KAA7B,CAAmC,CAAnC;AACD,OALC,CAAF;AAMD,KApBO,CAAR;AAqBD,GAnEO,CAAR;AAqEA5C,EAAAA,QAAQ,CAAC,kBAAD,EAAqB,YAAY;AACvC,QAAIkB,IAAJ;AAEAlB,IAAAA,QAAQ,CAAC,yBAAD,EAA4B,YAAY;AAC9CA,MAAAA,QAAQ,CAAC,2BAAD,EAA8B,YAAY;AAChDE,QAAAA,UAAU,CAAC,kBAAkB;AAC3B,gBAAM,qBAAU,IAAV,CAAN;AAEAgB,UAAAA,IAAI,GAAG,mCAAP;AACD,SAJS,CAAV;AAKAP,QAAAA,EAAE,CAAC,8CAAD,EAAiD,YAAY;AAC7D,cAAIkC,cAAc,GAAG,qCAAwB3B,IAAxB,CAArB;AACA2B,UAAAA,cAAc,CAAChC,MAAf,CAAsBiC,EAAtB,CAAyBC,KAAzB;AACD,SAHC,CAAF;AAIApC,QAAAA,EAAE,CAAC,qCAAD,EAAwC,YAAY;AACpDO,UAAAA,IAAI,CAAC8B,SAAL,GAAiB,IAAjB;AACA,cAAIH,cAAc,GAAG,qCAAwB3B,IAAxB,CAArB;AACA2B,UAAAA,cAAc,CAAChC,MAAf,CAAsBoC,GAAtB,CAA0B;AAACD,YAAAA,SAAS,EAAE;AAAZ,WAA1B;AACD,SAJC,CAAF;AAKAhD,QAAAA,QAAQ,CAAC,sBAAD,EAAyB,YAAY;AAC3CW,UAAAA,EAAE,CAAC,mCAAD,EAAsC,YAAY;AAClDO,YAAAA,IAAI,CAACgC,UAAL,GAAkB,CAAC,KAAD,CAAlB;AACA,iDAAwBhC,IAAxB,EAA8BL,MAA9B,CAAqCoC,GAArC,CAAyC;AAACC,cAAAA,UAAU,EAAE,CAAC,KAAD;AAAb,aAAzC;AACD,WAHC,CAAF;AAID,SALO,CAAR;AAMD,OArBO,CAAR;AAsBAlD,MAAAA,QAAQ,CAAC,wBAAD,EAA2B,YAAY;AAC7CE,QAAAA,UAAU,CAAC,kBAAkB;AAC3B;AACA,sCAAe,QAAf,EAAyB,cAAzB,EAAyC;AAACiD,YAAAA,IAAI,EAAE,QAAP;AAAiBC,YAAAA,UAAU,EAAE;AAACC,cAAAA,KAAK,EAAE;AAACF,gBAAAA,IAAI,EAAE,SAAP;AAAkBG,gBAAAA,OAAO,EAAE;AAA3B;AAAR;AAA7B,WAAzC;AACA;AACA,gBAAM,qBAAU,IAAV,CAAN;AACApC,UAAAA,IAAI,GAAG,mCAAP;AACD,SANS,CAAV;AAQAP,QAAAA,EAAE,CAAC,4CAAD,EAA+C,YAAY;AAC3D,gBAAMkC,cAAc,GAAG,qCAAwB3B,IAAxB,CAAvB;AACA2B,UAAAA,cAAc,CAAChC,MAAf,CAAsBiC,EAAtB,CAAyBC,KAAzB;AACD,SAHC,CAAF;AAKApC,QAAAA,EAAE,CAAC,qCAAD,EAAwC,YAAY;AACpDO,UAAAA,IAAI,CAAC,2BAAD,CAAJ,GAAoC,KAApC;AACA,gBAAM2B,cAAc,GAAG,qCAAwB3B,IAAxB,CAAvB;AACA2B,UAAAA,cAAc,CAAChC,MAAf,CAAsBoC,GAAtB,CAA0B;AAAC,yCAA6B;AAA9B,WAA1B;AACD,SAJC,CAAF;AAKD,OAnBO,CAAR;AAoBD,KA3CO,CAAR;AA4CD,GA/CO,CAAR;AAiDAjD,EAAAA,QAAQ,CAAC,gBAAD,EAAmB,YAAY;AACrCW,IAAAA,EAAE,CAAC,yDAAD,EAA4D,YAAY;AACxE,kCAAe,8CAAf,EAA+DE,MAA/D,CAAsEiC,EAAtE,CAAyES,YAAzE,CAAsF,kBAAtF;AACD,KAFC,CAAF;AAGA5C,IAAAA,EAAE,CAAC,yCAAD,EAA4C,YAAY;AAExD,oCAAiBE,MAAjB,CAAwBiC,EAAxB,CAA2BS,YAA3B,CAAwC,kBAAxC;AACD,KAHC,CAAF;AAIA5C,IAAAA,EAAE,CAAC,0DAAD,EAA6D,YAAY;AACzE,kCAAe,6CAAf,EAA8DE,MAA9D,CAAqE0B,GAArE,CAAyEO,EAAzE,CAA4EU,QAA5E;AACD,KAFC,CAAF;AAGD,GAXO,CAAR;AAaAxD,EAAAA,QAAQ,CAAC,iCAAD,EAAoC,YAAY;AACtD,QAAIyD,KAAJ;AAEAxB,IAAAA,MAAM,CAAC,YAAY;AACjBwB,MAAAA,KAAK,GAAGzB,OAAO,CAAC0B,IAAR,CAAa,CAAb,CAAR;AACD,KAFK,CAAN;AAIAxD,IAAAA,UAAU,CAAC,YAAY;AACrB;AACD,KAFS,CAAV;AAIAgC,IAAAA,KAAK,CAAC,YAAY;AAChBF,MAAAA,OAAO,CAAC0B,IAAR,CAAa,CAAb,IAAkBD,KAAlB;AACD,KAFI,CAAL;AAIA9C,IAAAA,EAAE,CAAC,iDAAD,EAAoD,kBAAkB;AACtE,aAAOqB,OAAO,CAAC0B,IAAR,CAAa,CAAb,CAAP;AACA,UAAIxC,IAAI,GAAG,MAAM,sBAAjB;AACAA,MAAAA,IAAI,CAACyC,IAAL,CAAU9C,MAAV,CAAiBiC,EAAjB,CAAoBF,KAApB,CAA0B,QAA1B;AACD,KAJC,CAAF;AAMAjC,IAAAA,EAAE,CAAC,sCAAD,EAAyC,kBAAkB;AAC3DqB,MAAAA,OAAO,CAAC0B,IAAR,CAAa,CAAb,IAAkB,aAAlB;AACA,UAAIxC,IAAI,GAAG,MAAM,sBAAjB;AACAA,MAAAA,IAAI,CAACyC,IAAL,CAAU9C,MAAV,CAAiBiC,EAAjB,CAAoBF,KAApB,CAA0B,aAA1B;AACD,KAJC,CAAF;AAKD,GA1BO,CAAR;AA4BD,CApNO,CAAR","sourcesContent":["// @ts-check\n\n// transpile:mocha\nimport sinon from 'sinon';\nimport getParser from '../lib/cli/parser';\nimport { checkNodeOk, getBuildInfo, getNonDefaultServerArgs, showBuildInfo, showConfig, validateTmpDir, warnNodeDeprecations } from '../lib/config';\nimport logger from '../lib/logger';\nimport { getDefaultsForSchema, resetSchema, registerSchema, finalizeSchema } from '../lib/schema/schema';\n\ndescribe('Config', function () {\n  /** @type {import('sinon').SinonSandbox} */\n  let sandbox;\n\n  beforeEach(function () {\n    sandbox = sinon.createSandbox();\n  });\n\n  afterEach(function () {\n    sandbox.restore();\n  });\n\n  describe('Appium config', function () {\n    /** @type {import('sinon').SinonSpy<[message?: any, ...extra: any[]],void>} */\n    let log;\n    /** @type {import('sinon').SinonSpy<[message?: any, ...extra: any[]],void>} */\n    let dir;\n    beforeEach(function () {\n      log = sandbox.spy(console, 'log');\n      dir = sandbox.spy(console, 'dir');\n    });\n\n    describe('showBuildInfo()', function () {\n      it('should log build info to console', async function () {\n        const config = getBuildInfo();\n        await showBuildInfo();\n        log.should.have.been.calledOnce;\n        log.firstCall.args.should.contain(JSON.stringify(config));\n      });\n    });\n\n    describe('showConfig', function () {\n      describe('when a config file is present', function () {\n        it('should dump the current Appium config', function () {\n          showConfig({foo: 'bar'}, {config: {server: {address: 'quux'}}}, {spam: 'food'});\n          log.should.have.been.calledWith('Appium Configuration\\n');\n        });\n\n        it('should skip empty objects', function () {\n          showConfig({foo: 'bar', cows: {}, pigs: [], sheep: 0, ducks: false}, {config: {server: {address: 'quux'}}}, {spam: 'food'});\n          dir.should.have.been.calledWith({foo: 'bar', sheep: 0, ducks: false});\n        });\n      });\n\n      describe('when a config file is not present', function () {\n        it('should dump the current Appium config sans config file contents', function () {\n          showConfig({foo: 'bar'}, {}, {spam: 'food'});\n          log.should.have.been.calledWith('(no configuration file loaded)\\n');\n        });\n      });\n    });\n  });\n\n  describe('node.js config', function () {\n    let _process = process;\n    before(function () {\n      // need to be able to write to process.version\n      // but also to have access to process methods\n      // so copy them over to a writable object\n      process = {...process}; // eslint-disable-line no-global-assign\n    });\n    after(function () {\n      process = _process; // eslint-disable-line no-global-assign\n    });\n    describe('checkNodeOk', function () {\n      describe('unsupported nodes', function () {\n        const unsupportedVersions = [\n          'v0.1', 'v0.9.12', 'v0.10.36', 'v0.12.14',\n          'v4.4.7', 'v5.7.0', 'v6.3.1', 'v7.1.1',\n          'v8.0.0', 'v9.2.3', 'v10.1.0',\n        ];\n        for (const version of unsupportedVersions) {\n          it(`should fail if node is ${version}`, function () {\n            // @ts-expect-error\n            process.version = version;\n            checkNodeOk.should.throw();\n          });\n        }\n      });\n\n      describe('supported nodes', function () {\n        it('should succeed if node is 12+', function () {\n          // @ts-expect-error\n          process.version = 'v12.0.1';\n          checkNodeOk.should.not.throw();\n        });\n        it('should succeed if node is 13+', function () {\n          // @ts-expect-error\n          process.version = 'v13.6.0';\n          checkNodeOk.should.not.throw();\n        });\n        it('should succeed if node is 14+', function () {\n          // @ts-expect-error\n          process.version = 'v14.0.0';\n          checkNodeOk.should.not.throw();\n        });\n      });\n    });\n\n    describe('warnNodeDeprecations', function () {\n      let spy;\n      before(function () {\n        spy = sandbox.spy(logger, 'warn');\n      });\n      beforeEach(function () {\n        spy.resetHistory();\n      });\n      it('should not log a warning if node is 8+', function () {\n        // @ts-expect-error\n        process.version = 'v8.0.0';\n        warnNodeDeprecations();\n        logger.warn.callCount.should.equal(0);\n      });\n      it('should not log a warning if node is 9+', function () {\n        // @ts-expect-error\n        process.version = 'v9.0.0';\n        warnNodeDeprecations();\n        logger.warn.callCount.should.equal(0);\n      });\n    });\n  });\n\n  describe('server arguments', function () {\n    let args;\n\n    describe('getNonDefaultServerArgs', function () {\n      describe('without extension schemas', function () {\n        beforeEach(async function () {\n          await getParser(true);\n          // get all the defaults\n          args = getDefaultsForSchema();\n        });\n        it('should show none if we have all the defaults', function () {\n          let nonDefaultArgs = getNonDefaultServerArgs(args);\n          nonDefaultArgs.should.be.empty;\n        });\n        it('should catch a non-default argument', function () {\n          args.allowCors = true;\n          let nonDefaultArgs = getNonDefaultServerArgs(args);\n          nonDefaultArgs.should.eql({allowCors: true});\n        });\n        describe('when arg is an array', function () {\n          it('should return the arg as an array', function () {\n            args.usePlugins = ['all'];\n            getNonDefaultServerArgs(args).should.eql({usePlugins: ['all']});\n          });\n        });\n      });\n      describe('with extension schemas', function () {\n        beforeEach(async function () {\n          resetSchema();\n          registerSchema('plugin', 'crypto-fiend', {type: 'object', properties: {elite: {type: 'boolean', default: true}}});\n          finalizeSchema();\n          await getParser(true);\n          args = getDefaultsForSchema();\n        });\n\n        it('should take extension schemas into account', function () {\n          const nonDefaultArgs = getNonDefaultServerArgs(args);\n          nonDefaultArgs.should.be.empty;\n        });\n\n        it('should catch a non-default argument', function () {\n          args['plugin.crypto-fiend.elite'] = false;\n          const nonDefaultArgs = getNonDefaultServerArgs(args);\n          nonDefaultArgs.should.eql({'plugin.crypto-fiend.elite': false});\n        });\n      });\n    });\n  });\n\n  describe('validateTmpDir', function () {\n    it('should fail to use a tmp dir with incorrect permissions', function () {\n      validateTmpDir('/private/if_you_run_with_sudo_this_wont_fail').should.be.rejectedWith(/could not ensure/);\n    });\n    it('should fail to use an undefined tmp dir', function () {\n      // @ts-expect-error\n      validateTmpDir().should.be.rejectedWith(/could not ensure/);\n    });\n    it('should be able to use a tmp dir with correct permissions', function () {\n      validateTmpDir('/tmp/test_tmp_dir/with/any/number/of/levels').should.not.be.rejected;\n    });\n  });\n\n  describe('parsing args with empty argv[1]', function () {\n    let argv1;\n\n    before(function () {\n      argv1 = process.argv[1];\n    });\n\n    beforeEach(function () {\n      resetSchema();\n    });\n\n    after(function () {\n      process.argv[1] = argv1;\n    });\n\n    it('should not fail if process.argv[1] is undefined', async function () {\n      delete process.argv[1];\n      let args = await getParser();\n      args.prog.should.be.equal('appium');\n    });\n\n    it('should set \"prog\" to process.argv[1]', async function () {\n      process.argv[1] = 'Hello World';\n      let args = await getParser();\n      args.prog.should.be.equal('Hello World');\n    });\n  });\n\n});\n"],"file":"test/config-specs.js","sourceRoot":"../.."}