appium 2.0.0-beta.24 → 2.0.0-beta.25
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/config-file.js +4 -7
- package/build/lib/config.js +44 -15
- package/build/lib/main.js +3 -4
- package/build/lib/schema/arg-spec.js +1 -1
- package/build/lib/schema/schema.js +9 -3
- package/build/test/config-file-e2e-specs.js +11 -29
- package/build/test/config-specs.js +25 -13
- package/lib/config-file.js +9 -12
- package/lib/config.js +50 -20
- package/lib/main.js +6 -5
- package/lib/schema/arg-spec.js +1 -1
- package/lib/schema/schema.js +8 -2
- package/package.json +4 -4
package/build/lib/config-file.js
CHANGED
|
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
8
|
exports.formatErrors = formatErrors;
|
|
9
|
+
exports.normalizeConfig = normalizeConfig;
|
|
9
10
|
exports.readConfigFile = readConfigFile;
|
|
10
11
|
|
|
11
12
|
require("source-map-support/register");
|
|
@@ -74,9 +75,8 @@ async function readConfigFile(filepath, opts = {}) {
|
|
|
74
75
|
});
|
|
75
76
|
const result = filepath ? await loadConfigFile(lc, filepath) : await searchConfigFile(lc);
|
|
76
77
|
|
|
77
|
-
if (result &&
|
|
78
|
+
if (result !== null && result !== void 0 && result.filepath && !(result !== null && result !== void 0 && result.isEmpty)) {
|
|
78
79
|
const {
|
|
79
|
-
normalize = true,
|
|
80
80
|
pretty = true
|
|
81
81
|
} = opts;
|
|
82
82
|
|
|
@@ -101,10 +101,7 @@ async function readConfigFile(filepath, opts = {}) {
|
|
|
101
101
|
};
|
|
102
102
|
}
|
|
103
103
|
|
|
104
|
-
|
|
105
|
-
configResult.config = normalizeConfig(configResult.config);
|
|
106
|
-
}
|
|
107
|
-
|
|
104
|
+
configResult.config = normalizeConfig(configResult.config);
|
|
108
105
|
return configResult;
|
|
109
106
|
} finally {
|
|
110
107
|
rawConfig.delete(result.filepath);
|
|
@@ -138,4 +135,4 @@ function normalizeConfig(config) {
|
|
|
138
135
|
}require('source-map-support').install();
|
|
139
136
|
|
|
140
137
|
|
|
141
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/config-file.js"],"names":["yamlLoader","filepath","content","yaml","parse","rawConfig","Map","jsonLoader","set","JSON","loadConfigFile","lc","load","err","code","message","SyntaxError","searchConfigFile","search","formatErrors","errors","config","opts","length","TypeError","schemaId","json","format","readConfigFile","loaders","noExt","packageProp","result","isEmpty","normalize","pretty","configResult","_","reason","get","normalizeConfig","delete","schema","section","obj","isUndefined","mappedObj","mapKeys","__","prop","properties","appiumCliDest","camelCase","mapValues","value","property","nextSection","isSchemaTypeObject","Boolean"],"mappings":"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","sourcesContent":["// @ts-check\n\nimport betterAjvErrors from '@sidvind/better-ajv-errors';\nimport { lilconfig } from 'lilconfig';\nimport _ from 'lodash';\nimport yaml from 'yaml';\nimport { getSchema, validate } from './schema/schema';\n\n/**\n * lilconfig loader to handle `.yaml` files\n * @type {import('lilconfig').LoaderSync}\n */\nfunction yamlLoader (filepath, content) {\n  return yaml.parse(content);\n}\n\n/**\n * A cache of the raw config file (a JSON string) at a filepath.\n * This is used for better error reporting.\n * Note that config files needn't be JSON, but it helps if they are.\n * @type {Map<string,RawJson>}\n */\nconst rawConfig = new Map();\n\n/**\n * Custom JSON loader that caches the raw config file (for use with `better-ajv-errors`).\n * If it weren't for this cache, this would be unnecessary.\n * @type {import('lilconfig').LoaderSync}\n */\nfunction jsonLoader (filepath, content) {\n  rawConfig.set(filepath, content);\n  return JSON.parse(content);\n}\n\n/**\n * Loads a config file from an explicit path\n * @param {LilconfigAsyncSearcher} lc - lilconfig instance\n * @param {string} filepath - Path to config file\n * @returns {Promise<import('lilconfig').LilconfigResult>}\n */\nasync function loadConfigFile (lc, filepath) {\n  try {\n    // removing \"await\" will cause any rejection to _not_ be caught in this block!\n    return await lc.load(filepath);\n  } catch (/** @type {unknown} */err) {\n    if (/** @type {NodeJS.ErrnoException} */(err).code === 'ENOENT') {\n      /** @type {NodeJS.ErrnoException} */(err).message = `Config file not found at user-provided path: ${filepath}`;\n      throw err;\n    } else if (err instanceof SyntaxError) {\n      // generally invalid JSON\n      err.message = `Config file at user-provided path ${filepath} is invalid:\\n${err.message}`;\n      throw err;\n    }\n    throw err;\n  }\n}\n\n/**\n * Searches for a config file\n * @param {LilconfigAsyncSearcher} lc - lilconfig instance\n * @returns {Promise<import('lilconfig').LilconfigResult>}\n */\nasync function searchConfigFile (lc) {\n  return await lc.search();\n}\n\n/**\n * Given an array of errors and the result of loading a config file, generate a\n * helpful string for the user.\n *\n * - If `opts` contains a `json` property, this should be the original JSON\n *   _string_ of the config file.  This is only applicable if the config file\n *   was in JSON format. If present, it will associate line numbers with errors.\n * - If `errors` happens to be empty, this will throw.\n * @param {import('ajv').ErrorObject[]} errors - Non-empty array of errors. Required.\n * @param {ReadConfigFileResult['config']|any} [config] -\n * Configuration & metadata\n * @param {FormatConfigErrorsOptions} [opts]\n * @throws {TypeError} If `errors` is empty\n * @returns {string}\n */\nexport function formatErrors (errors = [], config = {}, opts = {}) {\n  if (errors && !errors.length) {\n    throw new TypeError('Array of errors must be non-empty');\n  }\n  return betterAjvErrors(getSchema(opts.schemaId), config, errors, {\n    json: opts.json,\n    format: 'cli',\n  });\n}\n\n/**\n * Given an optional path, read a config file. Validates the config file.\n *\n * Call {@link validate} if you already have a config object.\n * @param {string} [filepath] - Path to config file, if we have one\n * @param {ReadConfigFileOptions} [opts] - Options\n * @public\n * @returns {Promise<ReadConfigFileResult>} Contains config and filepath, if found, and any errors\n */\nexport async function readConfigFile (filepath, opts = {}) {\n  const lc = lilconfig('appium', {\n    loaders: {\n      '.yaml': yamlLoader,\n      '.yml': yamlLoader,\n      '.json': jsonLoader,\n      noExt: jsonLoader,\n    },\n    packageProp: 'appiumConfig'\n  });\n\n  const result = filepath\n    ? await loadConfigFile(lc, filepath)\n    : await searchConfigFile(lc);\n\n  if (result && !result.isEmpty && result.filepath) {\n    const {normalize = true, pretty = true} = opts;\n    try {\n      /** @type {ReadConfigFileResult} */\n      let configResult;\n      const errors = validate(result.config);\n      if (_.isEmpty(errors)) {\n        configResult = {...result, errors};\n      } else {\n        const reason = formatErrors(errors, result.config, {\n          json: rawConfig.get(result.filepath),\n          pretty,\n        });\n        configResult = reason\n          ? {...result, errors, reason}\n          : {...result, errors};\n      }\n\n      if (normalize) {\n        // normalize (to camel case) all top-level property names of the config file\n        configResult.config = normalizeConfig(\n          /** @type {AppiumConfig} */ (configResult.config),\n        );\n      }\n\n      return configResult;\n    } finally {\n      // clean up the raw config file cache, which is only kept to better report errors.\n      rawConfig.delete(result.filepath);\n    }\n  }\n  return result ?? {};\n}\n\n/**\n * Convert schema property names to either a) the value of the `appiumCliDest` property, if any; or b) camel-case\n * @param {AppiumConfig} config - Configuration object\n * @returns {NormalizedAppiumConfig} New object with camel-cased keys (or `dest` keys).\n */\nfunction normalizeConfig (config) {\n  const schema = getSchema();\n  /**\n   * @param {AppiumConfig} config\n   * @param {string} [section] - Keypath (lodash `_.get()` style) to section of config. If omitted, assume root Appium config schema\n   * @returns Normalized section of config\n   */\n  const normalize = (config, section) => {\n    const obj = _.isUndefined(section) ? config : _.get(config, section, config);\n\n    const mappedObj = _.mapKeys(obj, (__, prop) =>\n      schema.properties[prop]?.appiumCliDest ?? _.camelCase(prop),\n    );\n\n    return _.mapValues(mappedObj, (value, property) => {\n      const nextSection = section ? `${section}.${property}` : property;\n      return isSchemaTypeObject(value) ? normalize(config, nextSection) : value;\n    });\n  };\n\n  /**\n   * Returns `true` if the schema prop references an object, or if it's an object itself\n   * @param {import('ajv').SchemaObject|object} schema - Referencing schema object\n   */\n  const isSchemaTypeObject = (schema) => Boolean(schema.properties);\n\n  return normalize(config);\n}\n\n/**\n * Result of calling {@link readConfigFile}.\n * @typedef {Object} ReadConfigFileResult\n * @property {import('ajv').ErrorObject[]} [errors] - Validation errors\n * @property {string} [filepath] - The path to the config file, if found\n * @property {boolean} [isEmpty] - If `true`, the config file exists but is empty\n * @property {AppiumConfig} [config] - The parsed configuration\n * @property {string|betterAjvErrors.IOutputError[]} [reason] - Human-readable error messages and suggestions. If the `pretty` option is `true`, this will be a nice string to print.\n */\n\n/**\n * Options for {@link readConfigFile}.\n * @typedef {Object} ReadConfigFileOptions\n * @property {boolean} [pretty=true] If `false`, do not use color and fancy formatting in the `reason` property of the {@link ReadConfigFileResult}. The value of `reason` is then suitable for machine-reading.\n * @property {boolean} [normalize=true] If `false`, do not normalize key names to camel case.\n */\n\n/**\n * This is an `AsyncSearcher` which is inexplicably _not_ exported by the `lilconfig` type definition.\n * @typedef {ReturnType<import('lilconfig')[\"lilconfig\"]>} LilconfigAsyncSearcher\n */\n\n/**\n * The contents of an Appium config file. Generated from schema\n * @typedef {import('../types/types').AppiumConfig} AppiumConfig\n */\n\n/**\n * The contents of an Appium config file with camelcased property names (and using `appiumCliDest` value if present). Generated from {@link AppiumConfig}\n * @typedef {import('../types/types').NormalizedAppiumConfig} NormalizedAppiumConfig\n */\n\n/**\n * The string should be a raw JSON string.\n * @typedef {string} RawJson\n */\n\n/**\n * Options for {@link formatErrors}.\n * @typedef {Object} FormatConfigErrorsOptions\n * @property {import('./config-file').RawJson} [json] - Raw JSON config (as string)\n * @property {boolean} [pretty=true] - Whether to format errors as a CLI-friendly string\n * @property {string}  [schemaId] - Specific ID of a prop; otherwise entire schema\n */\n"],"file":"lib/config-file.js","sourceRoot":"../.."}
|
|
138
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/config-file.js"],"names":["yamlLoader","filepath","content","yaml","parse","rawConfig","Map","jsonLoader","set","JSON","loadConfigFile","lc","load","err","code","message","SyntaxError","searchConfigFile","search","formatErrors","errors","config","opts","length","TypeError","schemaId","json","format","readConfigFile","loaders","noExt","packageProp","result","isEmpty","pretty","configResult","_","reason","get","normalizeConfig","delete","schema","normalize","section","obj","isUndefined","mappedObj","mapKeys","__","prop","properties","appiumCliDest","camelCase","mapValues","value","property","nextSection","isSchemaTypeObject","Boolean"],"mappings":"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","sourcesContent":["// @ts-check\n\nimport betterAjvErrors from '@sidvind/better-ajv-errors';\nimport { lilconfig } from 'lilconfig';\nimport _ from 'lodash';\nimport yaml from 'yaml';\nimport { getSchema, validate } from './schema/schema';\n\n/**\n * lilconfig loader to handle `.yaml` files\n * @type {import('lilconfig').LoaderSync}\n */\nfunction yamlLoader (filepath, content) {\n  return yaml.parse(content);\n}\n\n/**\n * A cache of the raw config file (a JSON string) at a filepath.\n * This is used for better error reporting.\n * Note that config files needn't be JSON, but it helps if they are.\n * @type {Map<string,RawJson>}\n */\nconst rawConfig = new Map();\n\n/**\n * Custom JSON loader that caches the raw config file (for use with `better-ajv-errors`).\n * If it weren't for this cache, this would be unnecessary.\n * @type {import('lilconfig').LoaderSync}\n */\nfunction jsonLoader (filepath, content) {\n  rawConfig.set(filepath, content);\n  return JSON.parse(content);\n}\n\n/**\n * Loads a config file from an explicit path\n * @param {LilconfigAsyncSearcher} lc - lilconfig instance\n * @param {string} filepath - Path to config file\n * @returns {Promise<import('lilconfig').LilconfigResult>}\n */\nasync function loadConfigFile (lc, filepath) {\n  try {\n    // removing \"await\" will cause any rejection to _not_ be caught in this block!\n    return await lc.load(filepath);\n  } catch (/** @type {unknown} */err) {\n    if (/** @type {NodeJS.ErrnoException} */(err).code === 'ENOENT') {\n      /** @type {NodeJS.ErrnoException} */(err).message = `Config file not found at user-provided path: ${filepath}`;\n      throw err;\n    } else if (err instanceof SyntaxError) {\n      // generally invalid JSON\n      err.message = `Config file at user-provided path ${filepath} is invalid:\\n${err.message}`;\n      throw err;\n    }\n    throw err;\n  }\n}\n\n/**\n * Searches for a config file\n * @param {LilconfigAsyncSearcher} lc - lilconfig instance\n * @returns {Promise<import('lilconfig').LilconfigResult>}\n */\nasync function searchConfigFile (lc) {\n  return await lc.search();\n}\n\n/**\n * Given an array of errors and the result of loading a config file, generate a\n * helpful string for the user.\n *\n * - If `opts` contains a `json` property, this should be the original JSON\n *   _string_ of the config file.  This is only applicable if the config file\n *   was in JSON format. If present, it will associate line numbers with errors.\n * - If `errors` happens to be empty, this will throw.\n * @param {import('ajv').ErrorObject[]} errors - Non-empty array of errors. Required.\n * @param {ReadConfigFileResult['config']|any} [config] -\n * Configuration & metadata\n * @param {FormatConfigErrorsOptions} [opts]\n * @throws {TypeError} If `errors` is empty\n * @returns {string}\n */\nexport function formatErrors (errors = [], config = {}, opts = {}) {\n  if (errors && !errors.length) {\n    throw new TypeError('Array of errors must be non-empty');\n  }\n  return betterAjvErrors(getSchema(opts.schemaId), config, errors, {\n    json: opts.json,\n    format: 'cli',\n  });\n}\n\n/**\n * Given an optional path, read a config file. Validates the config file.\n *\n * Call {@link validate} if you already have a config object.\n * @param {string} [filepath] - Path to config file, if we have one\n * @param {ReadConfigFileOptions} [opts] - Options\n * @public\n * @returns {Promise<ReadConfigFileResult>} Contains config and filepath, if found, and any errors\n */\nexport async function readConfigFile (filepath, opts = {}) {\n  const lc = lilconfig('appium', {\n    loaders: {\n      '.yaml': yamlLoader,\n      '.yml': yamlLoader,\n      '.json': jsonLoader,\n      noExt: jsonLoader,\n    },\n    packageProp: 'appiumConfig'\n  });\n\n  const result = filepath\n    ? await loadConfigFile(lc, filepath)\n    : await searchConfigFile(lc);\n\n  if (result?.filepath && !result?.isEmpty) {\n    const {pretty = true} = opts;\n    try {\n      let configResult;\n      const errors = validate(result.config);\n      if (_.isEmpty(errors)) {\n        configResult = {...result, errors};\n      } else {\n        const reason = formatErrors(errors, result.config, {\n          json: rawConfig.get(result.filepath),\n          pretty,\n        });\n        configResult = reason\n          ? {...result, errors, reason}\n          : {...result, errors};\n      }\n\n      // normalize (to camel case) all top-level property names of the config file\n      configResult.config = normalizeConfig(\n        /** @type {AppiumConfig} */ (configResult.config),\n      );\n\n      return configResult;\n    } finally {\n      // clean up the raw config file cache, which is only kept to better report errors.\n      rawConfig.delete(result.filepath);\n    }\n  }\n  return result ?? {};\n}\n\n/**\n * Convert schema property names to either a) the value of the `appiumCliDest` property, if any; or b) camel-case\n * @param {AppiumConfig} config - Configuration object\n * @returns {NormalizedAppiumConfig} New object with camel-cased keys (or `dest` keys).\n */\nexport function normalizeConfig (config) {\n  const schema = getSchema();\n  /**\n   * @param {AppiumConfig} config\n   * @param {string} [section] - Keypath (lodash `_.get()` style) to section of config. If omitted, assume root Appium config schema\n   * @todo Rewrite as a loop\n   * @returns Normalized section of config\n   */\n  const normalize = (config, section) => {\n    const obj = _.isUndefined(section) ? config : _.get(config, section, config);\n\n    const mappedObj = _.mapKeys(obj, (__, prop) =>\n      schema.properties[prop]?.appiumCliDest ?? _.camelCase(prop),\n    );\n\n    return _.mapValues(mappedObj, (value, property) => {\n      const nextSection = section ? `${section}.${property}` : property;\n      return isSchemaTypeObject(value) ? normalize(config, nextSection) : value;\n    });\n  };\n\n  /**\n   * Returns `true` if the schema prop references an object, or if it's an object itself\n   * @param {import('ajv').SchemaObject|object} schema - Referencing schema object\n   */\n  const isSchemaTypeObject = (schema) => Boolean(schema.properties);\n\n  return normalize(config);\n}\n\n/**\n * Result of calling {@link readConfigFile}.\n * @typedef {Object} ReadConfigFileResult\n * @property {import('ajv').ErrorObject[]} [errors] - Validation errors\n * @property {string} [filepath] - The path to the config file, if found\n * @property {boolean} [isEmpty] - If `true`, the config file exists but is empty\n * @property {NormalizedAppiumConfig} [config] - The parsed configuration\n * @property {string|betterAjvErrors.IOutputError[]} [reason] - Human-readable error messages and suggestions. If the `pretty` option is `true`, this will be a nice string to print.\n */\n\n/**\n * Options for {@link readConfigFile}.\n * @typedef {Object} ReadConfigFileOptions\n * @property {boolean} [pretty=true] If `false`, do not use color and fancy formatting in the `reason` property of the {@link ReadConfigFileResult}. The value of `reason` is then suitable for machine-reading.\n */\n\n/**\n * This is an `AsyncSearcher` which is inexplicably _not_ exported by the `lilconfig` type definition.\n * @typedef {ReturnType<import('lilconfig')[\"lilconfig\"]>} LilconfigAsyncSearcher\n */\n\n/**\n * The contents of an Appium config file. Generated from schema\n * @typedef {import('../types/types').AppiumConfig} AppiumConfig\n */\n\n/**\n * The contents of an Appium config file with camelcased property names (and using `appiumCliDest` value if present). Generated from {@link AppiumConfig}\n * @typedef {import('../types/types').NormalizedAppiumConfig} NormalizedAppiumConfig\n */\n\n/**\n * The string should be a raw JSON string.\n * @typedef {string} RawJson\n */\n\n/**\n * Options for {@link formatErrors}.\n * @typedef {Object} FormatConfigErrorsOptions\n * @property {import('./config-file').RawJson} [json] - Raw JSON config (as string)\n * @property {boolean} [pretty=true] - Whether to format errors as a CLI-friendly string\n * @property {string}  [schemaId] - Specific ID of a prop; otherwise entire schema\n */\n"],"file":"lib/config-file.js","sourceRoot":"../.."}
|
package/build/lib/config.js
CHANGED
|
@@ -172,16 +172,35 @@ async function showBuildInfo() {
|
|
|
172
172
|
console.log(JSON.stringify(getBuildInfo()));
|
|
173
173
|
}
|
|
174
174
|
|
|
175
|
-
function getNonDefaultServerArgs(
|
|
176
|
-
const
|
|
175
|
+
function getNonDefaultServerArgs(parsedArgs) {
|
|
176
|
+
const flatten = args => {
|
|
177
|
+
const argSpecs = (0, _schema.getAllArgSpecs)();
|
|
178
|
+
|
|
179
|
+
const flattened = _lodash.default.reduce([...argSpecs.values()], (acc, argSpec) => {
|
|
180
|
+
if (_lodash.default.has(args, argSpec.dest)) {
|
|
181
|
+
acc[argSpec.dest] = {
|
|
182
|
+
value: _lodash.default.get(args, argSpec.dest),
|
|
183
|
+
argSpec
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
return acc;
|
|
188
|
+
}, {});
|
|
189
|
+
|
|
190
|
+
return flattened;
|
|
191
|
+
};
|
|
192
|
+
|
|
193
|
+
const args = flatten(parsedArgs);
|
|
194
|
+
|
|
195
|
+
const typesDiffer = dest => typeof args[dest].value !== typeof defaultsFromSchema[dest];
|
|
177
196
|
|
|
178
197
|
const defaultValueIsArray = dest => _lodash.default.isArray(defaultsFromSchema[dest]);
|
|
179
198
|
|
|
180
|
-
const argsValueIsArray = dest => _lodash.default.isArray(args[dest]);
|
|
199
|
+
const argsValueIsArray = dest => _lodash.default.isArray(args[dest].value);
|
|
181
200
|
|
|
182
|
-
const arraysDiffer = dest => _lodash.default.gt(_lodash.default.size(_lodash.default.difference(args[dest], defaultsFromSchema[dest])), 0);
|
|
201
|
+
const arraysDiffer = dest => _lodash.default.gt(_lodash.default.size(_lodash.default.difference(args[dest].value, defaultsFromSchema[dest])), 0);
|
|
183
202
|
|
|
184
|
-
const valuesDiffer = dest => args[dest] !== defaultsFromSchema[dest];
|
|
203
|
+
const valuesDiffer = dest => args[dest].value !== defaultsFromSchema[dest];
|
|
185
204
|
|
|
186
205
|
const defaultIsDefined = dest => !_lodash.default.isUndefined(defaultsFromSchema[dest]);
|
|
187
206
|
|
|
@@ -191,26 +210,36 @@ function getNonDefaultServerArgs(args) {
|
|
|
191
210
|
|
|
192
211
|
const isNotDefault = _lodash.default.overEvery([defaultIsDefined, _lodash.default.overSome([typesDiffer, _lodash.default.overEvery([defaultValueIsArray, argValueNotArrayOrArraysDiffer]), defaultValueNotArrayAndValuesDiffer])]);
|
|
193
212
|
|
|
194
|
-
const defaultsFromSchema = (0, _schema.getDefaultsForSchema)();
|
|
195
|
-
return _lodash.default.pickBy(args, (__, key) => isNotDefault(key))
|
|
213
|
+
const defaultsFromSchema = (0, _schema.getDefaultsForSchema)(true);
|
|
214
|
+
return _lodash.default.reduce(_lodash.default.pickBy(args, (__, key) => isNotDefault(key)), (acc, {
|
|
215
|
+
value,
|
|
216
|
+
argSpec
|
|
217
|
+
}) => _lodash.default.set(acc, argSpec.dest, value), {});
|
|
196
218
|
}
|
|
197
219
|
|
|
198
220
|
const compactConfig = _lodash.default.partial(_lodash.default.omitBy, _lodash.default, (value, key) => key === 'subcommand' || _lodash.default.isUndefined(value) || _lodash.default.isObject(value) && _lodash.default.isEmpty(value));
|
|
199
221
|
|
|
200
|
-
function showConfig(
|
|
222
|
+
function showConfig(nonDefaultPreConfigParsedArgs, configResult, defaults, parsedArgs) {
|
|
201
223
|
console.log('Appium Configuration\n');
|
|
224
|
+
console.log('from defaults:\n');
|
|
225
|
+
console.dir(compactConfig(defaults));
|
|
202
226
|
|
|
203
227
|
if (configResult.config) {
|
|
204
|
-
console.log(
|
|
228
|
+
console.log(`\nfrom config file at ${configResult.filepath}:\n`);
|
|
205
229
|
console.dir(compactConfig(configResult.config));
|
|
206
230
|
} else {
|
|
207
|
-
console.log(
|
|
231
|
+
console.log(`\n(no configuration file loaded)`);
|
|
208
232
|
}
|
|
209
233
|
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
234
|
+
if (_lodash.default.isEmpty(nonDefaultPreConfigParsedArgs)) {
|
|
235
|
+
console.log(`\n(no CLI parameters provided)`);
|
|
236
|
+
} else {
|
|
237
|
+
console.log('\nvia CLI or function call:\n');
|
|
238
|
+
console.dir(compactConfig(nonDefaultPreConfigParsedArgs));
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
console.log('\nfinal configuration:\n');
|
|
242
|
+
console.dir(compactConfig(parsedArgs));
|
|
214
243
|
}
|
|
215
244
|
|
|
216
245
|
async function validateTmpDir(tmpDir) {
|
|
@@ -222,4 +251,4 @@ async function validateTmpDir(tmpDir) {
|
|
|
222
251
|
}require('source-map-support').install();
|
|
223
252
|
|
|
224
253
|
|
|
225
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/config.js"],"names":["npmPackage","fs","readPackageJsonFrom","__dirname","APPIUM_VER","version","MIN_NODE_VERSION","engines","node","GIT_META_ROOT","GIT_BINARY","system","isWindows","GITHUB_API","BUILD_INFO","getNodeVersion","semver","coerce","process","updateBuildInfo","useGithubApiFallback","sha","getGitRev","built","getGitTimestamp","_","isEmpty","findGitRoot","cwd","rootDir","type","gitRoot","stdout","trim","ign","resBodyObj","axios","get","headers","data","isArray","name","commit","commitSha","committer","date","author","getBuildInfo","checkNodeOk","satisfies","logger","errorAndThrow","warnNodeDeprecations","showBuildInfo","console","log","JSON","stringify","getNonDefaultServerArgs","args","typesDiffer","dest","defaultsFromSchema","defaultValueIsArray","argsValueIsArray","arraysDiffer","gt","size","difference","valuesDiffer","defaultIsDefined","isUndefined","argValueNotArrayOrArraysDiffer","overSome","negate","defaultValueNotArrayAndValuesDiffer","overEvery","isNotDefault","pickBy","__","key","compactConfig","partial","omitBy","value","isObject","showConfig","preConfigParsedArgs","configResult","defaults","config","filepath","dir","validateTmpDir","tmpDir","e","Error"],"mappings":"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","sourcesContent":["// @ts-check\n\n/* eslint-disable no-console */\nimport _ from 'lodash';\nimport { mkdirp, system, fs } from '@appium/support';\nimport axios from 'axios';\nimport { exec } from 'teen_process';\nimport { rootDir } from './utils';\nimport logger from './logger';\nimport semver from 'semver';\nimport findUp from 'find-up';\nimport { getDefaultsForSchema } from './schema/schema';\n\nconst npmPackage = fs.readPackageJsonFrom(__dirname);\n\nconst APPIUM_VER = npmPackage.version;\nconst MIN_NODE_VERSION = npmPackage.engines.node;\n\nconst GIT_META_ROOT = '.git';\nconst GIT_BINARY = `git${system.isWindows() ? '.exe' : ''}`;\nconst GITHUB_API = 'https://api.github.com/repos/appium/appium';\n\nconst BUILD_INFO = {\n  version: APPIUM_VER,\n};\n\nfunction getNodeVersion () {\n  return /** @type {import('semver').SemVer} */(semver.coerce(process.version));\n}\n\nasync function updateBuildInfo (useGithubApiFallback = false) {\n  const sha = await getGitRev(useGithubApiFallback);\n  if (!sha) {\n    return;\n  }\n  BUILD_INFO['git-sha'] = sha;\n  const built = await getGitTimestamp(sha, useGithubApiFallback);\n  if (!_.isEmpty(built)) {\n    BUILD_INFO.built = built;\n  }\n}\n\n/**\n * Finds the Git metadata dir (see `GIT_META_ROOT`)\n *\n * This is needed because Appium cannot assume `package.json` and `.git` are in the same\n * directory.  Monorepos, see?\n * @returns {Promise<string|undefined>} Path to dir or `undefined` if not found\n */\nasync function findGitRoot () {\n  return await findUp(GIT_META_ROOT, {cwd: rootDir, type: 'directory'});\n}\n\nasync function getGitRev (useGithubApiFallback = false) {\n  const gitRoot = await findGitRoot();\n  if (gitRoot) {\n    try {\n      const {stdout} = await exec(GIT_BINARY, ['rev-parse', 'HEAD'], {\n        cwd: gitRoot\n      });\n      return stdout.trim();\n    } catch (ign) {}\n  }\n\n  if (!useGithubApiFallback) {\n    return null;\n  }\n\n  try {\n    const resBodyObj = (await axios.get(`${GITHUB_API}/tags`, {\n      headers: {\n        'User-Agent': `Appium ${APPIUM_VER}`\n      }\n    })).data;\n    if (_.isArray(resBodyObj)) {\n      for (const {name, commit} of resBodyObj) {\n        if (name === `v${APPIUM_VER}` && commit && commit.sha) {\n          return commit.sha;\n        }\n      }\n    }\n  } catch (ign) {}\n  return null;\n}\n\n/**\n * @param {string} commitSha\n * @param {boolean} [useGithubApiFallback]\n * @returns {Promise<number?>}\n */\nasync function getGitTimestamp (commitSha, useGithubApiFallback = false) {\n  const gitRoot = await findGitRoot();\n  if (gitRoot) {\n    try {\n      const {stdout} = await exec(GIT_BINARY, ['show', '-s', '--format=%ci', commitSha], {\n        cwd: gitRoot\n      });\n      return stdout.trim();\n    } catch (ign) {}\n  }\n\n  if (!useGithubApiFallback) {\n    return null;\n  }\n\n  try {\n    const resBodyObj = (await axios.get(`${GITHUB_API}/commits/${commitSha}`, {\n      headers: {\n        'User-Agent': `Appium ${APPIUM_VER}`\n      }\n    })).data;\n    if (resBodyObj && resBodyObj.commit) {\n      if (resBodyObj.commit.committer && resBodyObj.commit.committer.date) {\n        return resBodyObj.commit.committer.date;\n      }\n      if (resBodyObj.commit.author && resBodyObj.commit.author.date) {\n        return resBodyObj.commit.author.date;\n      }\n    }\n  } catch (ign) {}\n  return null;\n}\n\n/**\n * @return Mutable object containing Appium build information. By default it\n * only contains the Appium version, but is updated with the build timestamp\n * and git commit hash asynchronously as soon as `updateBuildInfo` is called\n * and succeeds.\n */\nfunction getBuildInfo () {\n  return BUILD_INFO;\n}\n\nfunction checkNodeOk () {\n  const version = getNodeVersion();\n  if (!semver.satisfies(version, MIN_NODE_VERSION)) {\n    logger.errorAndThrow(`Node version must be ${MIN_NODE_VERSION}. Currently ${version.version}`);\n  }\n}\n\nfunction warnNodeDeprecations () {\n  /**\n   * Uncomment this section to get node version deprecation warnings\n   * Also add test cases to config-specs.js to cover the cases added\n   **/\n\n  // const version = getNodeVersion();\n  // if (version.major < 8) {\n  //   logger.warn(`Appium support for versions of node < ${version.major} has been ` +\n  //               'deprecated and will be removed in a future version. Please ' +\n  //               'upgrade!');\n  // }\n}\n\nasync function showBuildInfo () {\n  await updateBuildInfo(true);\n  console.log(JSON.stringify(getBuildInfo())); // eslint-disable-line no-console\n}\n\n/**\n * Returns k/v pairs of server arguments which are _not_ the defaults.\n * @param {ParsedArgs} args\n * @returns {Partial<ParsedArgs>}\n */\nfunction getNonDefaultServerArgs (args) {\n  // hopefully these function names are descriptive enough\n\n  const typesDiffer = /** @param {string} dest */(dest) => typeof args[dest] !== typeof defaultsFromSchema[dest];\n\n  const defaultValueIsArray = /** @param {string} dest */(dest) => _.isArray(defaultsFromSchema[dest]);\n\n  const argsValueIsArray = /** @param {string} dest */(dest) => _.isArray(args[dest]);\n\n  const arraysDiffer = /** @param {string} dest */(dest) => _.gt(_.size(_.difference(args[dest], defaultsFromSchema[dest])), 0);\n\n  const valuesDiffer = /** @param {string} dest */(dest) => args[dest] !== defaultsFromSchema[dest];\n\n  const defaultIsDefined = /** @param {string} dest */(dest) => !_.isUndefined(defaultsFromSchema[dest]);\n\n  // note that `_.overEvery` is like an \"AND\", and `_.overSome` is like an \"OR\"\n\n  const argValueNotArrayOrArraysDiffer = _.overSome([\n    _.negate(argsValueIsArray),\n    arraysDiffer\n  ]);\n\n  const defaultValueNotArrayAndValuesDiffer = _.overEvery([\n    _.negate(defaultValueIsArray), valuesDiffer\n  ]);\n\n  /**\n   * This used to be a hideous conditional, but it's broken up into a hideous function instead.\n   * hopefully this makes things a little more understandable.\n   * - checks if the default value is defined\n   * - if so, and the default is not an array:\n   *   - ensures the types are the same\n   *   - ensures the values are equal\n   * - if so, and the default is an array:\n   *   - ensures the args value is an array\n   *   - ensures the args values do not differ from the default values\n   * @type {(dest: string) => boolean}\n   */\n  const isNotDefault = _.overEvery([\n    defaultIsDefined,\n    _.overSome([\n      typesDiffer,\n      _.overEvery([\n        defaultValueIsArray,\n        argValueNotArrayOrArraysDiffer\n      ]),\n      defaultValueNotArrayAndValuesDiffer\n    ])\n  ]);\n\n  const defaultsFromSchema = getDefaultsForSchema();\n\n  return _.pickBy(args, (__, key) => isNotDefault(key));\n}\n\n/**\n * Compacts an object for {@link showConfig}:\n * 1. Removes `subcommand` key/value\n * 2. Removes `undefined` values\n * 3. Removes empty objects (but not `false` values)\n * Does not operate recursively.\n */\nconst compactConfig = _.partial(\n  _.omitBy,\n  _,\n  (value, key) => key === 'subcommand' || _.isUndefined(value) || (_.isObject(value) && _.isEmpty(value))\n);\n\n/**\n * Shows a breakdown of the current config after CLI params, config file loaded & defaults applied.\n *\n * The actual shape of `preConfigParsedArgs` and `defaults` does not matter for the purposes of this function,\n * but it's intended to be called with values of type {@link ParsedArgs} and `DefaultValues<true>`, respectively.\n *\n * @param {object} preConfigParsedArgs - Parsed CLI args (or param to `init()`) before config & defaults applied\n * @param {import('./config-file').ReadConfigFileResult} configResult - Result of attempting to load a config file\n * @param {object} defaults - Configuration defaults from schemas\n */\nfunction showConfig (preConfigParsedArgs, configResult, defaults) {\n  console.log('Appium Configuration\\n');\n  if (configResult.config) {\n    console.log(`via config file at ${configResult.filepath}:\\n`);\n    console.dir(compactConfig(configResult.config));\n  } else {\n    console.log(`(no configuration file loaded)\\n`);\n  }\n  console.log('via CLI or function call:\\n');\n  console.dir(compactConfig(preConfigParsedArgs));\n  console.log('\\nvia defaults:\\n');\n  console.dir(compactConfig(defaults));\n}\n\n/**\n * @param {string} tmpDir\n */\nasync function validateTmpDir (tmpDir) {\n  try {\n    await mkdirp(tmpDir);\n  } catch (e) {\n    throw new Error(`We could not ensure that the temp dir you specified ` +\n                    `(${tmpDir}) exists. Please make sure it's writeable.`);\n  }\n}\n\nexport {\n  getBuildInfo, checkNodeOk, showBuildInfo,\n  warnNodeDeprecations, validateTmpDir, getNonDefaultServerArgs,\n  getGitRev, APPIUM_VER, updateBuildInfo, showConfig\n};\n\n/**\n * @typedef {import('../types/types').ParsedArgs} ParsedArgs\n */\n"],"file":"lib/config.js","sourceRoot":"../.."}
|
|
254
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/config.js"],"names":["npmPackage","fs","readPackageJsonFrom","__dirname","APPIUM_VER","version","MIN_NODE_VERSION","engines","node","GIT_META_ROOT","GIT_BINARY","system","isWindows","GITHUB_API","BUILD_INFO","getNodeVersion","semver","coerce","process","updateBuildInfo","useGithubApiFallback","sha","getGitRev","built","getGitTimestamp","_","isEmpty","findGitRoot","cwd","rootDir","type","gitRoot","stdout","trim","ign","resBodyObj","axios","get","headers","data","isArray","name","commit","commitSha","committer","date","author","getBuildInfo","checkNodeOk","satisfies","logger","errorAndThrow","warnNodeDeprecations","showBuildInfo","console","log","JSON","stringify","getNonDefaultServerArgs","parsedArgs","flatten","args","argSpecs","flattened","reduce","values","acc","argSpec","has","dest","value","typesDiffer","defaultsFromSchema","defaultValueIsArray","argsValueIsArray","arraysDiffer","gt","size","difference","valuesDiffer","defaultIsDefined","isUndefined","argValueNotArrayOrArraysDiffer","overSome","negate","defaultValueNotArrayAndValuesDiffer","overEvery","isNotDefault","pickBy","__","key","set","compactConfig","partial","omitBy","isObject","showConfig","nonDefaultPreConfigParsedArgs","configResult","defaults","dir","config","filepath","validateTmpDir","tmpDir","e","Error"],"mappings":"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","sourcesContent":["// @ts-check\n\n/* eslint-disable no-console */\nimport _ from 'lodash';\nimport { mkdirp, system, fs } from '@appium/support';\nimport axios from 'axios';\nimport { exec } from 'teen_process';\nimport { rootDir } from './utils';\nimport logger from './logger';\nimport semver from 'semver';\nimport findUp from 'find-up';\nimport { getDefaultsForSchema, getAllArgSpecs } from './schema/schema';\n\nconst npmPackage = fs.readPackageJsonFrom(__dirname);\n\nconst APPIUM_VER = npmPackage.version;\nconst MIN_NODE_VERSION = npmPackage.engines.node;\n\nconst GIT_META_ROOT = '.git';\nconst GIT_BINARY = `git${system.isWindows() ? '.exe' : ''}`;\nconst GITHUB_API = 'https://api.github.com/repos/appium/appium';\n\nconst BUILD_INFO = {\n  version: APPIUM_VER,\n};\n\nfunction getNodeVersion () {\n  return /** @type {import('semver').SemVer} */(semver.coerce(process.version));\n}\n\nasync function updateBuildInfo (useGithubApiFallback = false) {\n  const sha = await getGitRev(useGithubApiFallback);\n  if (!sha) {\n    return;\n  }\n  BUILD_INFO['git-sha'] = sha;\n  const built = await getGitTimestamp(sha, useGithubApiFallback);\n  if (!_.isEmpty(built)) {\n    BUILD_INFO.built = built;\n  }\n}\n\n/**\n * Finds the Git metadata dir (see `GIT_META_ROOT`)\n *\n * This is needed because Appium cannot assume `package.json` and `.git` are in the same\n * directory.  Monorepos, see?\n * @returns {Promise<string|undefined>} Path to dir or `undefined` if not found\n */\nasync function findGitRoot () {\n  return await findUp(GIT_META_ROOT, {cwd: rootDir, type: 'directory'});\n}\n\nasync function getGitRev (useGithubApiFallback = false) {\n  const gitRoot = await findGitRoot();\n  if (gitRoot) {\n    try {\n      const {stdout} = await exec(GIT_BINARY, ['rev-parse', 'HEAD'], {\n        cwd: gitRoot\n      });\n      return stdout.trim();\n    } catch (ign) {}\n  }\n\n  if (!useGithubApiFallback) {\n    return null;\n  }\n\n  try {\n    const resBodyObj = (await axios.get(`${GITHUB_API}/tags`, {\n      headers: {\n        'User-Agent': `Appium ${APPIUM_VER}`\n      }\n    })).data;\n    if (_.isArray(resBodyObj)) {\n      for (const {name, commit} of resBodyObj) {\n        if (name === `v${APPIUM_VER}` && commit && commit.sha) {\n          return commit.sha;\n        }\n      }\n    }\n  } catch (ign) {}\n  return null;\n}\n\n/**\n * @param {string} commitSha\n * @param {boolean} [useGithubApiFallback]\n * @returns {Promise<number?>}\n */\nasync function getGitTimestamp (commitSha, useGithubApiFallback = false) {\n  const gitRoot = await findGitRoot();\n  if (gitRoot) {\n    try {\n      const {stdout} = await exec(GIT_BINARY, ['show', '-s', '--format=%ci', commitSha], {\n        cwd: gitRoot\n      });\n      return stdout.trim();\n    } catch (ign) {}\n  }\n\n  if (!useGithubApiFallback) {\n    return null;\n  }\n\n  try {\n    const resBodyObj = (await axios.get(`${GITHUB_API}/commits/${commitSha}`, {\n      headers: {\n        'User-Agent': `Appium ${APPIUM_VER}`\n      }\n    })).data;\n    if (resBodyObj && resBodyObj.commit) {\n      if (resBodyObj.commit.committer && resBodyObj.commit.committer.date) {\n        return resBodyObj.commit.committer.date;\n      }\n      if (resBodyObj.commit.author && resBodyObj.commit.author.date) {\n        return resBodyObj.commit.author.date;\n      }\n    }\n  } catch (ign) {}\n  return null;\n}\n\n/**\n * @return Mutable object containing Appium build information. By default it\n * only contains the Appium version, but is updated with the build timestamp\n * and git commit hash asynchronously as soon as `updateBuildInfo` is called\n * and succeeds.\n */\nfunction getBuildInfo () {\n  return BUILD_INFO;\n}\n\nfunction checkNodeOk () {\n  const version = getNodeVersion();\n  if (!semver.satisfies(version, MIN_NODE_VERSION)) {\n    logger.errorAndThrow(`Node version must be ${MIN_NODE_VERSION}. Currently ${version.version}`);\n  }\n}\n\nfunction warnNodeDeprecations () {\n  /**\n   * Uncomment this section to get node version deprecation warnings\n   * Also add test cases to config-specs.js to cover the cases added\n   **/\n\n  // const version = getNodeVersion();\n  // if (version.major < 8) {\n  //   logger.warn(`Appium support for versions of node < ${version.major} has been ` +\n  //               'deprecated and will be removed in a future version. Please ' +\n  //               'upgrade!');\n  // }\n}\n\nasync function showBuildInfo () {\n  await updateBuildInfo(true);\n  console.log(JSON.stringify(getBuildInfo())); // eslint-disable-line no-console\n}\n\n/**\n * Returns k/v pairs of server arguments which are _not_ the defaults.\n * @param {ParsedArgs} parsedArgs\n * @returns {Partial<ParsedArgs>}\n */\nfunction getNonDefaultServerArgs (parsedArgs) {\n  /**\n   * Flattens parsed args into a single level object for comparison with\n   * flattened defaults across server args and extension args.\n   * @param {ParsedArgs} args\n   * @returns {Record<string, { value: any, argSpec: import('./schema/arg-spec').ArgSpec }>}\n   */\n  const flatten = (args) => {\n    const argSpecs = getAllArgSpecs();\n    const flattened = _.reduce([...argSpecs.values()], (acc, argSpec) => {\n      if (_.has(args, argSpec.dest)) {\n        acc[argSpec.dest] = {value: _.get(args, argSpec.dest), argSpec};\n      }\n      return acc;\n    }, /** @type {Record<string, { value: any, argSpec: import('./schema/arg-spec').ArgSpec }>} */({}));\n\n    return flattened;\n  };\n\n  const args = flatten(parsedArgs);\n\n  // hopefully these function names are descriptive enough\n  const typesDiffer = /** @param {string} dest */(dest) => typeof args[dest].value !== typeof defaultsFromSchema[dest];\n\n  const defaultValueIsArray = /** @param {string} dest */(dest) => _.isArray(defaultsFromSchema[dest]);\n\n  const argsValueIsArray = /** @param {string} dest */(dest) => _.isArray(args[dest].value);\n\n  const arraysDiffer = /** @param {string} dest */(dest) => _.gt(_.size(_.difference(args[dest].value, defaultsFromSchema[dest])), 0);\n\n  const valuesDiffer = /** @param {string} dest */(dest) => args[dest].value !== defaultsFromSchema[dest];\n\n  const defaultIsDefined = /** @param {string} dest */(dest) => !_.isUndefined(defaultsFromSchema[dest]);\n\n  // note that `_.overEvery` is like an \"AND\", and `_.overSome` is like an \"OR\"\n\n  const argValueNotArrayOrArraysDiffer = _.overSome([\n    _.negate(argsValueIsArray),\n    arraysDiffer\n  ]);\n\n  const defaultValueNotArrayAndValuesDiffer = _.overEvery([\n    _.negate(defaultValueIsArray), valuesDiffer\n  ]);\n\n  /**\n   * This used to be a hideous conditional, but it's broken up into a hideous function instead.\n   * hopefully this makes things a little more understandable.\n   * - checks if the default value is defined\n   * - if so, and the default is not an array:\n   *   - ensures the types are the same\n   *   - ensures the values are equal\n   * - if so, and the default is an array:\n   *   - ensures the args value is an array\n   *   - ensures the args values do not differ from the default values\n   * @type {(dest: string) => boolean}\n   */\n  const isNotDefault = _.overEvery([\n    defaultIsDefined,\n    _.overSome([\n      typesDiffer,\n      _.overEvery([\n        defaultValueIsArray,\n        argValueNotArrayOrArraysDiffer\n      ]),\n      defaultValueNotArrayAndValuesDiffer\n    ])\n  ]);\n\n  const defaultsFromSchema = getDefaultsForSchema(true);\n\n  return _.reduce(\n    _.pickBy(args, (__, key) => isNotDefault(key)),\n    // explodes the flattened object back into nested one\n    (acc, {value, argSpec}) => _.set(acc, argSpec.dest, value), /** @type {Partial<ParsedArgs>} */({})\n  );\n}\n\n/**\n * Compacts an object for {@link showConfig}:\n * 1. Removes `subcommand` key/value\n * 2. Removes `undefined` values\n * 3. Removes empty objects (but not `false` values)\n * Does not operate recursively.\n */\nconst compactConfig = _.partial(\n  _.omitBy,\n  _,\n  (value, key) => key === 'subcommand' || _.isUndefined(value) || (_.isObject(value) && _.isEmpty(value))\n);\n\n/**\n * Shows a breakdown of the current config after CLI params, config file loaded & defaults applied.\n *\n * The actual shape of `preConfigParsedArgs` and `defaults` does not matter for the purposes of this function,\n * but it's intended to be called with values of type {@link ParsedArgs} and `DefaultValues<true>`, respectively.\n *\n * @param {Partial<ParsedArgs>} nonDefaultPreConfigParsedArgs - Parsed CLI args (or param to `init()`) before config & defaults applied\n * @param {import('./config-file').ReadConfigFileResult} configResult - Result of attempting to load a config file.  _Must_ be normalized\n * @param {Partial<ParsedArgs>} defaults - Configuration defaults from schemas\n * @param {ParsedArgs} parsedArgs - Entire parsed args object\n */\nfunction showConfig (nonDefaultPreConfigParsedArgs, configResult, defaults, parsedArgs) {\n  console.log('Appium Configuration\\n');\n  console.log('from defaults:\\n');\n  console.dir(compactConfig(defaults));\n  if (configResult.config) {\n    console.log(`\\nfrom config file at ${configResult.filepath}:\\n`);\n    console.dir(compactConfig(configResult.config));\n  } else {\n    console.log(`\\n(no configuration file loaded)`);\n  }\n  if (_.isEmpty(nonDefaultPreConfigParsedArgs)) {\n    console.log(`\\n(no CLI parameters provided)`);\n  } else {\n    console.log('\\nvia CLI or function call:\\n');\n    console.dir(compactConfig(nonDefaultPreConfigParsedArgs));\n  }\n  console.log('\\nfinal configuration:\\n');\n  console.dir(compactConfig(parsedArgs));\n}\n\n/**\n * @param {string} tmpDir\n */\nasync function validateTmpDir (tmpDir) {\n  try {\n    await mkdirp(tmpDir);\n  } catch (e) {\n    throw new Error(`We could not ensure that the temp dir you specified ` +\n                    `(${tmpDir}) exists. Please make sure it's writeable.`);\n  }\n}\n\nexport {\n  getBuildInfo, checkNodeOk, showBuildInfo,\n  warnNodeDeprecations, validateTmpDir, getNonDefaultServerArgs,\n  getGitRev, APPIUM_VER, updateBuildInfo, showConfig\n};\n\n/**\n * @typedef {import('../types/types').ParsedArgs} ParsedArgs\n */\n"],"file":"lib/config.js","sourceRoot":"../.."}
|
package/build/lib/main.js
CHANGED
|
@@ -220,13 +220,12 @@ async function init(args) {
|
|
|
220
220
|
var _configResult$config;
|
|
221
221
|
|
|
222
222
|
defaults = (0, _schema.getDefaultsForSchema)(false);
|
|
223
|
+
parsedArgs = _lodash.default.defaultsDeep(preConfigParsedArgs, (_configResult$config = configResult.config) === null || _configResult$config === void 0 ? void 0 : _configResult$config.server, defaults);
|
|
223
224
|
|
|
224
225
|
if (preConfigParsedArgs.showConfig) {
|
|
225
|
-
(0, _config.showConfig)(preConfigParsedArgs, configResult, defaults);
|
|
226
|
+
(0, _config.showConfig)((0, _config.getNonDefaultServerArgs)(preConfigParsedArgs), configResult, defaults, parsedArgs);
|
|
226
227
|
return {};
|
|
227
228
|
}
|
|
228
|
-
|
|
229
|
-
parsedArgs = _lodash.default.defaultsDeep(preConfigParsedArgs, (_configResult$config = configResult.config) === null || _configResult$config === void 0 ? void 0 : _configResult$config.server, defaults);
|
|
230
229
|
} else {
|
|
231
230
|
parsedArgs = preConfigParsedArgs;
|
|
232
231
|
}
|
|
@@ -360,4 +359,4 @@ if (require.main === module) {
|
|
|
360
359
|
}require('source-map-support').install();
|
|
361
360
|
|
|
362
361
|
|
|
363
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/main.js"],"names":["preflightChecks","args","throwInsteadOfExit","longStacktrace","require","async_trace_limit","showBuildInfo","process","exit","tmpDir","err","logger","error","message","red","logNonDefaultArgsWarning","info","logDefaultCapabilitiesWarning","caps","logStartupInfo","welcome","APPIUM_VER","appiumRev","showArgs","_","size","isEmpty","defaultCapabilities","logServerPort","address","port","logMessage","getActivePlugins","pluginConfig","compact","Object","keys","installedExtensions","filter","pluginName","includes","usePlugins","length","USE_ALL_PLUGINS","map","PluginClass","debug","stack","getActiveDrivers","driverConfig","driverName","useDrivers","getServerUpdaters","driverClasses","pluginClasses","getExtraMethodMap","reduce","klass","newMethodMap","init","parser","preConfigParsedArgs","parsedArgs","defaults","subcommand","SERVER_SUBCOMMAND","parseArgs","configResult","configFile","errors","Error","filepath","reason","showConfig","defaultsDeep","config","server","DRIVER_TYPE","PLUGIN_TYPE","logFilters","issues","rules","logFactory","loadSecureValuesPreprocessingRules","JSON","stringify","warn","util","pluralize","appiumDriver","AppiumDriver","main","routeConfiguringFunction","serverUpdaters","extraMethodMap","serverOpts","hostname","allowCors","basePath","keepAliveTimeout","nodeconfig","close","signal","once","onSignal","deleteAllSessions","force","e","print","p","module"],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\n// transpile:main\n// @ts-check\n\nimport logger from './logger'; // logger needs to remain first of imports\n// @ts-ignore\nimport { routeConfiguringFunction as makeRouter, server as baseServer } from '@appium/base-driver';\nimport { logger as logFactory, util } from '@appium/support';\nimport { asyncify } from 'asyncbox';\nimport _ from 'lodash';\nimport { AppiumDriver } from './appium';\nimport { driverConfig, pluginConfig, USE_ALL_PLUGINS } from './cli/args';\nimport { runExtensionCommand } from './cli/extension';\nimport { default as getParser, SERVER_SUBCOMMAND } from './cli/parser';\nimport { APPIUM_VER, checkNodeOk, getGitRev, getNonDefaultServerArgs, showBuildInfo, validateTmpDir, warnNodeDeprecations, showConfig } from './config';\nimport { readConfigFile } from './config-file';\nimport { DRIVER_TYPE, PLUGIN_TYPE } from './extension-config';\nimport registerNode from './grid-register';\nimport { init as logsinkInit } from './logsink';\nimport { getDefaultsForSchema } from './schema/schema';\nimport { inspect } from './utils';\n\n/**\n *\n * @param {ParsedArgs} args\n * @param {boolean} [throwInsteadOfExit]\n */\nasync function preflightChecks (args, throwInsteadOfExit = false) {\n  try {\n    checkNodeOk();\n    if (args.longStacktrace) {\n      require('longjohn').async_trace_limit = -1;\n    }\n    if (args.showBuildInfo) {\n      await showBuildInfo();\n      process.exit(0);\n    }\n    warnNodeDeprecations();\n\n    if (args.tmpDir) {\n      await validateTmpDir(args.tmpDir);\n    }\n  } catch (err) {\n    logger.error(err.message.red);\n    if (throwInsteadOfExit) {\n      throw err;\n    }\n\n    process.exit(1);\n  }\n}\n\n/**\n * @param {Partial<ParsedArgs>} args\n */\nfunction logNonDefaultArgsWarning (args) {\n  logger.info('Non-default server args:');\n  inspect(args);\n}\n\nfunction logDefaultCapabilitiesWarning (caps) {\n  logger.info('Default capabilities, which will be added to each request ' +\n              'unless overridden by desired capabilities:');\n  inspect(caps);\n}\n\n/**\n * @param {ParsedArgs} args\n */\nasync function logStartupInfo (args) {\n  let welcome = `Welcome to Appium v${APPIUM_VER}`;\n  let appiumRev = await getGitRev();\n  if (appiumRev) {\n    welcome += ` (REV ${appiumRev})`;\n  }\n  logger.info(welcome);\n\n  let showArgs = getNonDefaultServerArgs(args);\n  if (_.size(showArgs)) {\n    logNonDefaultArgsWarning(showArgs);\n  }\n  if (!_.isEmpty(args.defaultCapabilities)) {\n    logDefaultCapabilitiesWarning(args.defaultCapabilities);\n  }\n  // TODO: bring back loglevel reporting below once logger is flushed out\n  // logger.info('Console LogLevel: ' + logger.transports.console.level);\n  // if (logger.transports.file) {\n  //   logger.info('File LogLevel: ' + logger.transports.file.level);\n  // }\n}\n\n/**\n * Logs the address and port the server is listening on\n * @param {string} address - Address\n * @param {number} port - Port\n * @returns {void}\n */\nfunction logServerPort (address, port) {\n  let logMessage = `Appium REST http interface listener started on ` +\n                   `${address}:${port}`;\n  logger.info(logMessage);\n}\n\n/**\n * Find any plugin name which has been installed, and which has been requested for activation by\n * using the --use-plugins flag, and turn each one into its class, so we can send them as objects\n * to the server init. We also want to send/assign them to the umbrella driver so it can use them\n * to wrap command execution\n *\n * @param {Object} args - argparser parsed dict\n * @param {import('./plugin-config').default} pluginConfig - a plugin extension config\n * @returns {PluginExtensionClass[]}\n */\nfunction getActivePlugins (args, pluginConfig) {\n  return _.compact(Object.keys(pluginConfig.installedExtensions).filter((pluginName) =>\n    _.includes(args.usePlugins, pluginName) ||\n    (args.usePlugins.length === 1 && args.usePlugins[0] === USE_ALL_PLUGINS)\n  ).map((pluginName) => {\n    try {\n      logger.info(`Attempting to load plugin ${pluginName}...`);\n      const PluginClass = /** @type {PluginExtensionClass} */(pluginConfig.require(pluginName));\n\n      PluginClass.pluginName = pluginName; // store the plugin name on the class so it can be used later\n      return PluginClass;\n    } catch (err) {\n      logger.error(`Could not load plugin '${pluginName}', so it will not be available. Error ` +\n                   `in loading the plugin was: ${err.message}`);\n      logger.debug(err.stack);\n    }\n  }));\n}\n\n/**\n * Find any driver name which has been installed, and turn each one into its class, so we can send\n * them as objects to the server init in case they need to add methods/routes or update the server.\n * If the --drivers flag was given, this method only loads the given drivers.\n *\n * @param {Object} args - argparser parsed dict\n * @param {import('./driver-config').default} driverConfig - a driver extension config\n */\nfunction getActiveDrivers (args, driverConfig) {\n  return _.compact(Object.keys(driverConfig.installedExtensions).filter((driverName) =>\n    _.includes(args.useDrivers, driverName) || args.useDrivers.length === 0\n  ).map((driverName) => {\n    try {\n      logger.info(`Attempting to load driver ${driverName}...`);\n      return driverConfig.require(driverName);\n    } catch (err) {\n      logger.error(`Could not load driver '${driverName}', so it will not be available. Error ` +\n                   `in loading the driver was: ${err.message}`);\n      logger.debug(err.stack);\n    }\n  }));\n}\n\n/**\n * Gets a list of `updateServer` functions from all extensions\n * @param {DriverExtensionClass[]} driverClasses\n * @param {PluginExtensionClass[]} pluginClasses\n * @returns {StaticExtMembers['updateServer'][]}\n */\nfunction getServerUpdaters (driverClasses, pluginClasses) {\n  return _.compact(_.map([...driverClasses, ...pluginClasses], 'updateServer'));\n}\n\n/**\n * Makes a big `MethodMap` from all the little `MethodMap`s in the extensions\n * @param {DriverExtensionClass[]} driverClasses\n * @param {PluginExtensionClass[]} pluginClasses\n * @returns {import('@appium/base-driver').MethodMap}\n */\nfunction getExtraMethodMap (driverClasses, pluginClasses) {\n  return [...driverClasses, ...pluginClasses].reduce(\n    (map, klass) => ({...map, ...klass.newMethodMap}),\n    {}\n  );\n}\n\n/**\n * Initializes Appium, but does not start the server.\n *\n * Use this to get at the configuration schema.\n *\n * If `args` contains a non-empty `subcommand` which is not `server`, this function\n * will resolve with an empty object.\n *\n * @param {ParsedArgs} [args] - Parsed args\n * @returns {Promise<Partial<{appiumDriver: AppiumDriver, parsedArgs: ParsedArgs}>>}\n * @example\n * import {init, getSchema} from 'appium';\n * const options = {}; // config object\n * await init(options);\n * const schema = getSchema(); // entire config schema including plugins and drivers\n */\nasync function init (args) {\n  const parser = await getParser();\n  let throwInsteadOfExit = false;\n  /** @type {ParsedArgs} */\n  let preConfigParsedArgs;\n  /** @type {typeof preConfigParsedArgs & import('type-fest').AsyncReturnType<readConfigFile>['config']} */\n  let parsedArgs;\n  /**\n   * This is a definition (instead of declaration) because TS can't figure out\n   * the value will be defined when it's used.\n   * @type {ReturnType<getDefaultsForSchema>}\n   */\n  let defaults = {};\n  if (args) {\n    // if we have a containing package instead of running as a CLI process,\n    // that package might not appreciate us calling 'process.exit' willy-\n    // nilly, so give it the option to have us throw instead of exit\n    if (args.throwInsteadOfExit) {\n      throwInsteadOfExit = true;\n      // but remove it since it's not a real server arg per se\n      delete args.throwInsteadOfExit;\n    }\n    preConfigParsedArgs = {...args, subcommand: args.subcommand ?? SERVER_SUBCOMMAND};\n  } else {\n    // otherwise parse from CLI\n    preConfigParsedArgs = parser.parseArgs();\n  }\n\n  const configResult = await readConfigFile(preConfigParsedArgs.configFile);\n\n  if (!_.isEmpty(configResult.errors)) {\n    throw new Error(`Errors in config file ${configResult.filepath}:\\n ${configResult.reason ?? configResult.errors}`);\n  }\n\n\n  // merge config and apply defaults.\n  // the order of precendece is:\n  // 1. command line args\n  // 2. config file\n  // 3. defaults from config file.\n  if (preConfigParsedArgs.subcommand === SERVER_SUBCOMMAND) {\n    defaults = getDefaultsForSchema(false);\n\n    if (preConfigParsedArgs.showConfig) {\n      showConfig(preConfigParsedArgs, configResult, defaults);\n      return {};\n    }\n\n    parsedArgs = _.defaultsDeep(\n      preConfigParsedArgs,\n      configResult.config?.server,\n      defaults\n    );\n  } else {\n    parsedArgs = preConfigParsedArgs;\n  }\n\n  await logsinkInit(parsedArgs);\n\n  // if the user has requested the 'driver' CLI, don't run the normal server,\n  // but instead pass control to the driver CLI\n  if (parsedArgs.subcommand === DRIVER_TYPE) {\n    await runExtensionCommand(parsedArgs, parsedArgs.subcommand, driverConfig);\n    return {};\n  }\n  if (parsedArgs.subcommand === PLUGIN_TYPE) {\n    await runExtensionCommand(parsedArgs, parsedArgs.subcommand, pluginConfig);\n    return {};\n  }\n\n  if (parsedArgs.logFilters) {\n    const {issues, rules} = await logFactory.loadSecureValuesPreprocessingRules(parsedArgs.logFilters);\n    if (!_.isEmpty(issues)) {\n      throw new Error(`The log filtering rules config '${parsedArgs.logFilters}' has issues: ` +\n        JSON.stringify(issues, null, 2));\n    }\n    if (_.isEmpty(rules)) {\n      logger.warn(`Found no log filtering rules in '${parsedArgs.logFilters}'. Is that expected?`);\n    } else {\n      logger.info(`Loaded ${util.pluralize('filtering rule', rules.length, true)} from '${parsedArgs.logFilters}'`);\n    }\n  }\n\n  const appiumDriver = new AppiumDriver(parsedArgs);\n  // set the config on the umbrella driver so it can match drivers to caps\n  appiumDriver.driverConfig = driverConfig;\n  await preflightChecks(parsedArgs, throwInsteadOfExit);\n\n  return {appiumDriver, parsedArgs};\n}\n\n/**\n * Initializes Appium's config.  Starts server if appropriate and resolves the\n * server instance if so; otherwise resolves w/ `undefined`.\n * @param {ParsedArgs} [args] - Arguments from CLI or otherwise\n * @returns {Promise<import('express').Express|undefined>}\n */\nasync function main (args) {\n  const {appiumDriver, parsedArgs} = await init(args);\n\n  if (!appiumDriver || !parsedArgs) {\n    // if this branch is taken, we've run a different subcommand, so there's nothing\n    // left to do here.\n    return;\n  }\n\n  const pluginClasses = getActivePlugins(parsedArgs, pluginConfig);\n  // set the active plugins on the umbrella driver so it can use them for commands\n  appiumDriver.pluginClasses = pluginClasses;\n\n  await logStartupInfo(parsedArgs);\n  let routeConfiguringFunction = makeRouter(appiumDriver);\n\n  const driverClasses = getActiveDrivers(parsedArgs, driverConfig);\n  const serverUpdaters = getServerUpdaters(driverClasses, pluginClasses);\n  const extraMethodMap = getExtraMethodMap(driverClasses, pluginClasses);\n\n  const serverOpts = {\n    routeConfiguringFunction,\n    port: parsedArgs.port,\n    hostname: parsedArgs.address,\n    allowCors: parsedArgs.allowCors,\n    basePath: parsedArgs.basePath,\n    serverUpdaters,\n    extraMethodMap,\n  };\n  if (parsedArgs.keepAliveTimeout) {\n    serverOpts.keepAliveTimeout = parsedArgs.keepAliveTimeout * 1000;\n  }\n  let server;\n  try {\n    server = await baseServer(serverOpts);\n  } catch (err) {\n    logger.error(`Could not configure Appium server. It's possible that a driver or plugin tried ` +\n                 `to update the server and failed. Original error: ${err.message}`);\n    logger.debug(err.stack);\n    return process.exit(1);\n  }\n\n  if (parsedArgs.allowCors) {\n    logger.warn('You have enabled CORS requests from any host. Be careful not ' +\n                'to visit sites which could maliciously try to start Appium ' +\n                'sessions on your machine');\n  }\n  appiumDriver.server = server;\n  try {\n    // configure as node on grid, if necessary\n    // falsy values should not cause this to run\n    if (parsedArgs.nodeconfig) {\n      await registerNode(parsedArgs.nodeconfig, parsedArgs.address, parsedArgs.port, parsedArgs.basePath);\n    }\n  } catch (err) {\n    await server.close();\n    throw err;\n  }\n\n  for (const signal of ['SIGINT', 'SIGTERM']) {\n    process.once(signal, async function onSignal () {\n      logger.info(`Received ${signal} - shutting down`);\n      try {\n        await appiumDriver.deleteAllSessions({\n          force: true,\n          reason: `The process has received ${signal} signal`,\n        });\n        await server.close();\n        process.exit(0);\n      } catch (e) {\n        logger.warn(e);\n        process.exit(1);\n      }\n    });\n  }\n\n  logServerPort(parsedArgs.address, parsedArgs.port);\n  driverConfig.print();\n  pluginConfig.print(pluginClasses.map((p) => p.pluginName));\n\n  return server;\n}\n\n// NOTE: this is here for backwards compat for any scripts referencing `main.js` directly\n// (more specifically, `build/lib/main.js`)\n// the executable is now `../index.js`, so that module will typically be `require.main`.\nif (require.main === module) {\n  asyncify(main);\n}\n\n// everything below here is intended to be a public API.\nexport { main, init };\nexport { APPIUM_HOME } from './extension-config';\nexport { getSchema, validate, finalizeSchema } from './schema/schema';\nexport { readConfigFile } from './config-file';\n\n/**\n * @typedef {import('../types/types').ParsedArgs} ParsedArgs\n */\n\n/**\n * @typedef {import('./appium').PluginExtensionClass} PluginExtensionClass\n */\n\n/**\n * @typedef {import('./appium').DriverExtensionClass} DriverExtensionClass\n */\n\n/**\n * @typedef {import('./appium').StaticExtMembers} StaticExtMembers\n */\n"],"file":"lib/main.js","sourceRoot":"../.."}
|
|
362
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/main.js"],"names":["preflightChecks","args","throwInsteadOfExit","longStacktrace","require","async_trace_limit","showBuildInfo","process","exit","tmpDir","err","logger","error","message","red","logNonDefaultArgsWarning","info","logDefaultCapabilitiesWarning","caps","logStartupInfo","welcome","APPIUM_VER","appiumRev","showArgs","_","size","isEmpty","defaultCapabilities","logServerPort","address","port","logMessage","getActivePlugins","pluginConfig","compact","Object","keys","installedExtensions","filter","pluginName","includes","usePlugins","length","USE_ALL_PLUGINS","map","PluginClass","debug","stack","getActiveDrivers","driverConfig","driverName","useDrivers","getServerUpdaters","driverClasses","pluginClasses","getExtraMethodMap","reduce","klass","newMethodMap","init","parser","preConfigParsedArgs","parsedArgs","defaults","subcommand","SERVER_SUBCOMMAND","parseArgs","configResult","configFile","errors","Error","filepath","reason","defaultsDeep","config","server","showConfig","DRIVER_TYPE","PLUGIN_TYPE","logFilters","issues","rules","logFactory","loadSecureValuesPreprocessingRules","JSON","stringify","warn","util","pluralize","appiumDriver","AppiumDriver","main","routeConfiguringFunction","serverUpdaters","extraMethodMap","serverOpts","hostname","allowCors","basePath","keepAliveTimeout","nodeconfig","close","signal","once","onSignal","deleteAllSessions","force","e","print","p","module"],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\n// transpile:main\n// @ts-check\n\nimport logger from './logger'; // logger needs to remain first of imports\n// @ts-ignore\nimport { routeConfiguringFunction as makeRouter, server as baseServer } from '@appium/base-driver';\nimport { logger as logFactory, util } from '@appium/support';\nimport { asyncify } from 'asyncbox';\nimport _ from 'lodash';\nimport { AppiumDriver } from './appium';\nimport { driverConfig, pluginConfig, USE_ALL_PLUGINS } from './cli/args';\nimport { runExtensionCommand } from './cli/extension';\nimport { default as getParser, SERVER_SUBCOMMAND } from './cli/parser';\nimport { APPIUM_VER, checkNodeOk, getGitRev, getNonDefaultServerArgs, showBuildInfo, validateTmpDir, warnNodeDeprecations, showConfig } from './config';\nimport { readConfigFile } from './config-file';\nimport { DRIVER_TYPE, PLUGIN_TYPE } from './extension-config';\nimport registerNode from './grid-register';\nimport { init as logsinkInit } from './logsink';\nimport { getDefaultsForSchema } from './schema/schema';\nimport { inspect } from './utils';\n\n/**\n *\n * @param {ParsedArgs} args\n * @param {boolean} [throwInsteadOfExit]\n */\nasync function preflightChecks (args, throwInsteadOfExit = false) {\n  try {\n    checkNodeOk();\n    if (args.longStacktrace) {\n      require('longjohn').async_trace_limit = -1;\n    }\n    if (args.showBuildInfo) {\n      await showBuildInfo();\n      process.exit(0);\n    }\n    warnNodeDeprecations();\n\n    if (args.tmpDir) {\n      await validateTmpDir(args.tmpDir);\n    }\n  } catch (err) {\n    logger.error(err.message.red);\n    if (throwInsteadOfExit) {\n      throw err;\n    }\n\n    process.exit(1);\n  }\n}\n\n/**\n * @param {Partial<ParsedArgs>} args\n */\nfunction logNonDefaultArgsWarning (args) {\n  logger.info('Non-default server args:');\n  inspect(args);\n}\n\nfunction logDefaultCapabilitiesWarning (caps) {\n  logger.info('Default capabilities, which will be added to each request ' +\n              'unless overridden by desired capabilities:');\n  inspect(caps);\n}\n\n/**\n * @param {ParsedArgs} args\n */\nasync function logStartupInfo (args) {\n  let welcome = `Welcome to Appium v${APPIUM_VER}`;\n  let appiumRev = await getGitRev();\n  if (appiumRev) {\n    welcome += ` (REV ${appiumRev})`;\n  }\n  logger.info(welcome);\n\n  let showArgs = getNonDefaultServerArgs(args);\n  if (_.size(showArgs)) {\n    logNonDefaultArgsWarning(showArgs);\n  }\n  if (!_.isEmpty(args.defaultCapabilities)) {\n    logDefaultCapabilitiesWarning(args.defaultCapabilities);\n  }\n  // TODO: bring back loglevel reporting below once logger is flushed out\n  // logger.info('Console LogLevel: ' + logger.transports.console.level);\n  // if (logger.transports.file) {\n  //   logger.info('File LogLevel: ' + logger.transports.file.level);\n  // }\n}\n\n/**\n * Logs the address and port the server is listening on\n * @param {string} address - Address\n * @param {number} port - Port\n * @returns {void}\n */\nfunction logServerPort (address, port) {\n  let logMessage = `Appium REST http interface listener started on ` +\n                   `${address}:${port}`;\n  logger.info(logMessage);\n}\n\n/**\n * Find any plugin name which has been installed, and which has been requested for activation by\n * using the --use-plugins flag, and turn each one into its class, so we can send them as objects\n * to the server init. We also want to send/assign them to the umbrella driver so it can use them\n * to wrap command execution\n *\n * @param {Object} args - argparser parsed dict\n * @param {import('./plugin-config').default} pluginConfig - a plugin extension config\n * @returns {PluginExtensionClass[]}\n */\nfunction getActivePlugins (args, pluginConfig) {\n  return _.compact(Object.keys(pluginConfig.installedExtensions).filter((pluginName) =>\n    _.includes(args.usePlugins, pluginName) ||\n    (args.usePlugins.length === 1 && args.usePlugins[0] === USE_ALL_PLUGINS)\n  ).map((pluginName) => {\n    try {\n      logger.info(`Attempting to load plugin ${pluginName}...`);\n      const PluginClass = /** @type {PluginExtensionClass} */(pluginConfig.require(pluginName));\n\n      PluginClass.pluginName = pluginName; // store the plugin name on the class so it can be used later\n      return PluginClass;\n    } catch (err) {\n      logger.error(`Could not load plugin '${pluginName}', so it will not be available. Error ` +\n                   `in loading the plugin was: ${err.message}`);\n      logger.debug(err.stack);\n    }\n  }));\n}\n\n/**\n * Find any driver name which has been installed, and turn each one into its class, so we can send\n * them as objects to the server init in case they need to add methods/routes or update the server.\n * If the --drivers flag was given, this method only loads the given drivers.\n *\n * @param {Object} args - argparser parsed dict\n * @param {import('./driver-config').default} driverConfig - a driver extension config\n */\nfunction getActiveDrivers (args, driverConfig) {\n  return _.compact(Object.keys(driverConfig.installedExtensions).filter((driverName) =>\n    _.includes(args.useDrivers, driverName) || args.useDrivers.length === 0\n  ).map((driverName) => {\n    try {\n      logger.info(`Attempting to load driver ${driverName}...`);\n      return driverConfig.require(driverName);\n    } catch (err) {\n      logger.error(`Could not load driver '${driverName}', so it will not be available. Error ` +\n                   `in loading the driver was: ${err.message}`);\n      logger.debug(err.stack);\n    }\n  }));\n}\n\n/**\n * Gets a list of `updateServer` functions from all extensions\n * @param {DriverExtensionClass[]} driverClasses\n * @param {PluginExtensionClass[]} pluginClasses\n * @returns {StaticExtMembers['updateServer'][]}\n */\nfunction getServerUpdaters (driverClasses, pluginClasses) {\n  return _.compact(_.map([...driverClasses, ...pluginClasses], 'updateServer'));\n}\n\n/**\n * Makes a big `MethodMap` from all the little `MethodMap`s in the extensions\n * @param {DriverExtensionClass[]} driverClasses\n * @param {PluginExtensionClass[]} pluginClasses\n * @returns {import('@appium/base-driver').MethodMap}\n */\nfunction getExtraMethodMap (driverClasses, pluginClasses) {\n  return [...driverClasses, ...pluginClasses].reduce(\n    (map, klass) => ({...map, ...klass.newMethodMap}),\n    {}\n  );\n}\n\n/**\n * Initializes Appium, but does not start the server.\n *\n * Use this to get at the configuration schema.\n *\n * If `args` contains a non-empty `subcommand` which is not `server`, this function\n * will resolve with an empty object.\n *\n * @param {ParsedArgs} [args] - Parsed args\n * @returns {Promise<Partial<{appiumDriver: AppiumDriver, parsedArgs: ParsedArgs}>>}\n * @example\n * import {init, getSchema} from 'appium';\n * const options = {}; // config object\n * await init(options);\n * const schema = getSchema(); // entire config schema including plugins and drivers\n */\nasync function init (args) {\n  const parser = await getParser();\n  let throwInsteadOfExit = false;\n  /** @type {ParsedArgs} */\n  let preConfigParsedArgs;\n  /** @type {typeof preConfigParsedArgs & import('type-fest').AsyncReturnType<readConfigFile>['config']} */\n  let parsedArgs;\n  /**\n   * This is a definition (instead of declaration) because TS can't figure out\n   * the value will be defined when it's used.\n   * @type {ReturnType<getDefaultsForSchema>}\n   */\n  let defaults = {};\n  if (args) {\n    // if we have a containing package instead of running as a CLI process,\n    // that package might not appreciate us calling 'process.exit' willy-\n    // nilly, so give it the option to have us throw instead of exit\n    if (args.throwInsteadOfExit) {\n      throwInsteadOfExit = true;\n      // but remove it since it's not a real server arg per se\n      delete args.throwInsteadOfExit;\n    }\n    preConfigParsedArgs = {...args, subcommand: args.subcommand ?? SERVER_SUBCOMMAND};\n  } else {\n    // otherwise parse from CLI\n    preConfigParsedArgs = parser.parseArgs();\n  }\n\n  const configResult = await readConfigFile(preConfigParsedArgs.configFile);\n\n  if (!_.isEmpty(configResult.errors)) {\n    throw new Error(`Errors in config file ${configResult.filepath}:\\n ${configResult.reason ?? configResult.errors}`);\n  }\n\n\n  // merge config and apply defaults.\n  // the order of precendece is:\n  // 1. command line args\n  // 2. config file\n  // 3. defaults from config file.\n  if (preConfigParsedArgs.subcommand === SERVER_SUBCOMMAND) {\n    defaults = getDefaultsForSchema(false);\n\n    parsedArgs = _.defaultsDeep(\n      preConfigParsedArgs,\n      configResult.config?.server,\n      defaults\n    );\n\n    if (preConfigParsedArgs.showConfig) {\n      showConfig(getNonDefaultServerArgs(preConfigParsedArgs), configResult, defaults, parsedArgs);\n      return {};\n    }\n\n  } else {\n    parsedArgs = preConfigParsedArgs;\n  }\n\n  await logsinkInit(parsedArgs);\n\n  // if the user has requested the 'driver' CLI, don't run the normal server,\n  // but instead pass control to the driver CLI\n  if (parsedArgs.subcommand === DRIVER_TYPE) {\n    await runExtensionCommand(parsedArgs, parsedArgs.subcommand, driverConfig);\n    return {};\n  }\n  if (parsedArgs.subcommand === PLUGIN_TYPE) {\n    await runExtensionCommand(parsedArgs, parsedArgs.subcommand, pluginConfig);\n    return {};\n  }\n\n  if (parsedArgs.logFilters) {\n    const {issues, rules} = await logFactory.loadSecureValuesPreprocessingRules(parsedArgs.logFilters);\n    if (!_.isEmpty(issues)) {\n      throw new Error(`The log filtering rules config '${parsedArgs.logFilters}' has issues: ` +\n        JSON.stringify(issues, null, 2));\n    }\n    if (_.isEmpty(rules)) {\n      logger.warn(`Found no log filtering rules in '${parsedArgs.logFilters}'. Is that expected?`);\n    } else {\n      logger.info(`Loaded ${util.pluralize('filtering rule', rules.length, true)} from '${parsedArgs.logFilters}'`);\n    }\n  }\n\n  const appiumDriver = new AppiumDriver(parsedArgs);\n  // set the config on the umbrella driver so it can match drivers to caps\n  appiumDriver.driverConfig = driverConfig;\n  await preflightChecks(parsedArgs, throwInsteadOfExit);\n\n  return {appiumDriver, parsedArgs};\n}\n\n/**\n * Initializes Appium's config.  Starts server if appropriate and resolves the\n * server instance if so; otherwise resolves w/ `undefined`.\n * @param {ParsedArgs} [args] - Arguments from CLI or otherwise\n * @returns {Promise<import('express').Express|undefined>}\n */\nasync function main (args) {\n  const {appiumDriver, parsedArgs} = await init(args);\n\n  if (!appiumDriver || !parsedArgs) {\n    // if this branch is taken, we've run a different subcommand, so there's nothing\n    // left to do here.\n    return;\n  }\n\n  const pluginClasses = getActivePlugins(parsedArgs, pluginConfig);\n  // set the active plugins on the umbrella driver so it can use them for commands\n  appiumDriver.pluginClasses = pluginClasses;\n\n  await logStartupInfo(parsedArgs);\n  let routeConfiguringFunction = makeRouter(appiumDriver);\n\n  const driverClasses = getActiveDrivers(parsedArgs, driverConfig);\n  const serverUpdaters = getServerUpdaters(driverClasses, pluginClasses);\n  const extraMethodMap = getExtraMethodMap(driverClasses, pluginClasses);\n\n  const serverOpts = {\n    routeConfiguringFunction,\n    port: parsedArgs.port,\n    hostname: parsedArgs.address,\n    allowCors: parsedArgs.allowCors,\n    basePath: parsedArgs.basePath,\n    serverUpdaters,\n    extraMethodMap,\n  };\n  if (parsedArgs.keepAliveTimeout) {\n    serverOpts.keepAliveTimeout = parsedArgs.keepAliveTimeout * 1000;\n  }\n  let server;\n  try {\n    server = await baseServer(serverOpts);\n  } catch (err) {\n    logger.error(`Could not configure Appium server. It's possible that a driver or plugin tried ` +\n                 `to update the server and failed. Original error: ${err.message}`);\n    logger.debug(err.stack);\n    return process.exit(1);\n  }\n\n  if (parsedArgs.allowCors) {\n    logger.warn('You have enabled CORS requests from any host. Be careful not ' +\n                'to visit sites which could maliciously try to start Appium ' +\n                'sessions on your machine');\n  }\n  appiumDriver.server = server;\n  try {\n    // configure as node on grid, if necessary\n    // falsy values should not cause this to run\n    if (parsedArgs.nodeconfig) {\n      await registerNode(parsedArgs.nodeconfig, parsedArgs.address, parsedArgs.port, parsedArgs.basePath);\n    }\n  } catch (err) {\n    await server.close();\n    throw err;\n  }\n\n  for (const signal of ['SIGINT', 'SIGTERM']) {\n    process.once(signal, async function onSignal () {\n      logger.info(`Received ${signal} - shutting down`);\n      try {\n        await appiumDriver.deleteAllSessions({\n          force: true,\n          reason: `The process has received ${signal} signal`,\n        });\n        await server.close();\n        process.exit(0);\n      } catch (e) {\n        logger.warn(e);\n        process.exit(1);\n      }\n    });\n  }\n\n  logServerPort(parsedArgs.address, parsedArgs.port);\n  driverConfig.print();\n  pluginConfig.print(pluginClasses.map((p) => p.pluginName));\n\n  return server;\n}\n\n// NOTE: this is here for backwards compat for any scripts referencing `main.js` directly\n// (more specifically, `build/lib/main.js`)\n// the executable is now `../index.js`, so that module will typically be `require.main`.\nif (require.main === module) {\n  asyncify(main);\n}\n\n// everything below here is intended to be a public API.\nexport { main, init };\nexport { APPIUM_HOME } from './extension-config';\nexport { getSchema, validate, finalizeSchema } from './schema/schema';\nexport { readConfigFile } from './config-file';\n\n/**\n * @typedef {import('../types/types').ParsedArgs} ParsedArgs\n */\n\n/**\n * @typedef {import('./appium').PluginExtensionClass} PluginExtensionClass\n */\n\n/**\n * @typedef {import('./appium').DriverExtensionClass} DriverExtensionClass\n */\n\n/**\n * @typedef {import('./appium').StaticExtMembers} StaticExtMembers\n */\n"],"file":"lib/main.js","sourceRoot":"../.."}
|
|
@@ -119,4 +119,4 @@ class ArgSpec {
|
|
|
119
119
|
exports.ArgSpec = ArgSpec;require('source-map-support').install();
|
|
120
120
|
|
|
121
121
|
|
|
122
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/schema/arg-spec.js"],"names":["APPIUM_CONFIG_SCHEMA_ID","SERVER_PROP_NAME","SCHEMA_ID_REGEXP","PROPERTIES","ArgSpec","constructor","name","extType","extName","dest","defaultValue","arg","toArg","ref","toSchemaRef","rawDest","_","camelCase","destKeypath","join","baseRef","toSchemaBaseRef","toNormalizedExtName","properName","kebabCase","replace","extensionInfoFromRootSchemaId","schemaId","matches","match","groups","normalizedExtName","create","opts","Object","freeze","toString","str"],"mappings":"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","sourcesContent":["import _ from 'lodash';\n\n/**\n * The original ID of the Appium config schema.\n * We use this in the CLI to convert it to `argparse` options.\n */\nexport const APPIUM_CONFIG_SCHEMA_ID = 'appium.json';\n\n/**\n * The schema prop containing server-related options. Everything in here\n * is \"native\" to Appium.\n * Used by {@link flattenSchema} for transforming the schema into CLI args.\n */\nexport const SERVER_PROP_NAME = 'server';\n\n/**\n * Used to parse extension info from a schema ID.\n */\nconst SCHEMA_ID_REGEXP = /^(?<extType>.+?)-(?<normalizedExtName>.+)\\.json$/;\n\n/**\n * Avoid typos by using constants!\n */\nconst PROPERTIES = 'properties';\n\n/**\n * An `ArgSpec` is a class representing metadata about an argument (or config\n * option) used for cross-referencing.\n *\n * This class has no instance methods, and is basically just a read-only \"struct\".\n */\nexport class ArgSpec {\n  /**\n   * The canonical name of the argument. Corresponds to key in schema's `properties` prop.\n   * @type {string}\n   */\n  name;\n\n  /**\n   * The `ExtensionType` of the argument. This will be set if the arg came from an extension;\n   * otherwise it will be `undefined`.\n   * @type {ExtensionType|undefined}\n   */\n  extType;\n\n  /**\n   * The name of the extension, if this argument came from an extension.\n   *\n   * Otherwise `undefined`.\n   * @type {string|undefined}\n   */\n  extName;\n\n  /**\n   * The schema ID (`$id`) for the argument.  This is automatically determined, and any user-provided `$id`s will be overwritten.\n   *\n   * @type {string}\n   */\n  ref;\n\n  /**\n   * The CLI argument, sans leading dashes.\n   * @type {string}\n   */\n  arg;\n\n  /**\n   * The desired keypath for the argument after arguments have been parsed.\n   *\n   * Typically this is camelCased.  If the arg came from an extension, it will be prefixed with\n   * `<extType>.<extName>.`\n   * @type {string}\n   */\n  dest;\n\n  /**\n   * The same as {@link ArgSpec.dest} but without the leading `<extType>.<extName>.` prefix.\n   */\n  rawDest;\n\n  /**\n   * Whatever the default value of this argument is, as specified by the\n   * `default` property of the schema.\n   * @type {D}\n   */\n  defaultValue;\n\n  /**\n   * Builds some computed fields and assigns them to the instance.\n   *\n   * Undefined properties are not assigned.\n   *\n   * The _constructor_ is private. Use {@link ArgSpec.create} instead.\n   * @private\n   * @template D\n   * @param {string} name\n   * @param {ArgSpecOptions<D>} [opts]\n   */\n  constructor (name, {extType, extName, dest, defaultValue} = {}) {\n    // we must normalize the extension name to fit into our convention for CLI\n    // args.\n    const arg = ArgSpec.toArg(name, extType, extName);\n\n    const ref = ArgSpec.toSchemaRef(name, extType, extName);\n\n    // if no explicit `dest` provided, just camelCase the name to avoid needing\n    // to use bracket syntax when accessing props on the parsed args object.\n    const rawDest = _.camelCase(dest ?? name);\n\n    const destKeypath =\n      extType && extName ? [extType, extName, rawDest].join('.') : rawDest;\n\n    this.defaultValue = defaultValue;\n    this.name = name;\n    this.extType = extType;\n    this.extName = extName;\n    this.arg = arg;\n    this.dest = destKeypath;\n    this.ref = ref;\n    this.rawDest = rawDest;\n  }\n\n  /**\n   * Return the schema ID (`$id`) for the **argument** given the parameters.\n   *\n   * If you need the \"root\" or \"base\" schema ID, use {@link ArgSpec.toSchemaBaseRef} instead.\n   * @param {string} name - Argument name\n   * @param {ExtensionType} [extType] - Extension type\n   * @param {string} [extName] - Extension name\n   * @returns {string} Schema ID\n   */\n  static toSchemaRef (name, extType, extName) {\n    const baseRef = ArgSpec.toSchemaBaseRef(extType, extName);\n    if (extType && extName) {\n      return [`${baseRef}#`, PROPERTIES, name].join('/');\n    }\n    return [`${baseRef}#`, PROPERTIES, SERVER_PROP_NAME, PROPERTIES, name].join('/');\n  }\n\n  /**\n   * Return the schema ID for an extension or the base schema ID.\n   * @param {ExtensionType} [extType] - Extension type\n   * @param {string} [extName] - Extension name\n   */\n  static toSchemaBaseRef (extType, extName) {\n    if (extType && extName) {\n      return `${extType}-${ArgSpec.toNormalizedExtName(extName)}.json`;\n    }\n    return APPIUM_CONFIG_SCHEMA_ID;\n  }\n\n  /**\n   * Return the unique ID for the argument given the parameters.\n   * @param {string} name - Argument name\n   * @param {ExtensionType} [extType] - Extension type\n   * @param {string} [extName] - Extension name\n   * @returns {string} Unique ID\n   */\n  static toArg (name, extType, extName) {\n    const properName = _.kebabCase(name.replace(/^--?/, ''));\n    if (extType && extName) {\n      return [extType, _.kebabCase(extName), properName].join('-');\n    }\n    return properName;\n  }\n\n  /**\n   * Normalizes a raw extension name (not including the type).\n   * @param {string} extName - Extension name\n   * @returns {string} Normalized extension name\n   */\n  static toNormalizedExtName (extName) {\n    return _.kebabCase(extName);\n  }\n\n  /**\n   * When given the root ID of a schema for an extension (`<extType>-<normalizedExtName>.json`) Returns an object containing the extension type and the _normalized_ extension name.\n   * @param {string} schemaId - Root schema ID\n   * @returns {{extType: ExtensionType|undefined, normalizedExtName: string|undefined}}\n   */\n  static extensionInfoFromRootSchemaId (schemaId) {\n    const matches = schemaId.match(SCHEMA_ID_REGEXP);\n    if (matches?.groups) {\n      const {extType, normalizedExtName} = matches.groups;\n      return {extType, normalizedExtName};\n    }\n    return {};\n  }\n\n  /**\n   * Creates an `ArgSpec`\n   *\n   * @param {string} name - The canonical name of the argument. Corresponds to a key in a schema's\n   * `properties` property.\n   * @param {ArgSpecOptions} [opts] - Options\n   * @returns {Readonly<ArgSpec>}\n   */\n  static create (name, opts) {\n    return Object.freeze(new ArgSpec(name, opts));\n  }\n\n  /**\n   * String representation, useful for debugging\n   * @returns {string}\n   */\n  /* istanbul ignore next */\n  toString () {\n    let str = `[ArgSpec] ${this.name} (${this.ref})`;\n    if (this.extType && this.extName) {\n      str += ` (ext: ${this.extType}/${this.extName})`;\n    }\n    return str;\n  }\n}\n\n/**\n * Options for {@link ArgSpec.create}\n * @template D\n * @typedef {Object} ArgSpecOptions\n * @property {string} [extName]\n * @property {ExtensionType} [extType]\n * @property {string} [dest]\n * @property {D} [defaultValue]\n */\n\n/**\n * @typedef {import('../ext-config-io').ExtensionType} ExtensionType\n */\n"],"file":"lib/schema/arg-spec.js","sourceRoot":"../../.."}
|
|
122
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/schema/arg-spec.js"],"names":["APPIUM_CONFIG_SCHEMA_ID","SERVER_PROP_NAME","SCHEMA_ID_REGEXP","PROPERTIES","ArgSpec","constructor","name","extType","extName","dest","defaultValue","arg","toArg","ref","toSchemaRef","rawDest","_","camelCase","destKeypath","join","baseRef","toSchemaBaseRef","toNormalizedExtName","properName","kebabCase","replace","extensionInfoFromRootSchemaId","schemaId","matches","match","groups","normalizedExtName","create","opts","Object","freeze","toString","str"],"mappings":"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","sourcesContent":["import _ from 'lodash';\n\n/**\n * The original ID of the Appium config schema.\n * We use this in the CLI to convert it to `argparse` options.\n */\nexport const APPIUM_CONFIG_SCHEMA_ID = 'appium.json';\n\n/**\n * The schema prop containing server-related options. Everything in here\n * is \"native\" to Appium.\n * Used by {@link flattenSchema} for transforming the schema into CLI args.\n */\nexport const SERVER_PROP_NAME = 'server';\n\n/**\n * Used to parse extension info from a schema ID.\n */\nconst SCHEMA_ID_REGEXP = /^(?<extType>.+?)-(?<normalizedExtName>.+)\\.json$/;\n\n/**\n * Avoid typos by using constants!\n */\nconst PROPERTIES = 'properties';\n\n/**\n * An `ArgSpec` is a class representing metadata about an argument (or config\n * option) used for cross-referencing.\n *\n * This class has no instance methods, and is basically just a read-only \"struct\".\n */\nexport class ArgSpec {\n  /**\n   * The canonical name of the argument. Corresponds to key in schema's `properties` prop.\n   * @type {string}\n   */\n  name;\n\n  /**\n   * The `ExtensionType` of the argument. This will be set if the arg came from an extension;\n   * otherwise it will be `undefined`.\n   * @type {ExtensionType|undefined}\n   */\n  extType;\n\n  /**\n   * The name of the extension, if this argument came from an extension.\n   *\n   * Otherwise `undefined`.\n   * @type {string|undefined}\n   */\n  extName;\n\n  /**\n   * The schema ID (`$id`) for the argument.  This is automatically determined, and any user-provided `$id`s will be overwritten.\n   *\n   * @type {string}\n   */\n  ref;\n\n  /**\n   * The CLI argument, sans leading dashes.\n   * @type {string}\n   */\n  arg;\n\n  /**\n   * The desired keypath for the argument after arguments have been parsed.\n   *\n   * Typically this is camelCased.  If the arg came from an extension, it will be prefixed with\n   * `<extType>.<extName>.`\n   * @type {string}\n   */\n  dest;\n\n  /**\n   * The same as {@link ArgSpec.dest} but without the leading `<extType>.<extName>.` prefix.\n   */\n  rawDest;\n\n  /**\n   * Whatever the default value of this argument is, as specified by the\n   * `default` property of the schema.\n   * @type {D}\n   */\n  defaultValue;\n\n  /**\n   * Builds some computed fields and assigns them to the instance.\n   *\n   * Undefined properties are not assigned.\n   *\n   * The _constructor_ is private. Use {@link ArgSpec.create} instead.\n   * @private\n   * @template D\n   * @param {string} name\n   * @param {ArgSpecOptions<D>} [opts]\n   */\n  constructor (name, {extType, extName, dest, defaultValue} = {}) {\n    // we must normalize the extension name to fit into our convention for CLI\n    // args.\n    const arg = ArgSpec.toArg(name, extType, extName);\n\n    const ref = ArgSpec.toSchemaRef(name, extType, extName);\n\n    // if no explicit `dest` provided, just camelCase the name to avoid needing\n    // to use bracket syntax when accessing props on the parsed args object.\n    const rawDest = _.camelCase(dest ?? name);\n\n    const destKeypath =\n      extType && extName ? [extType, extName, rawDest].join('.') : rawDest;\n\n    this.defaultValue = defaultValue;\n    this.name = name;\n    this.extType = extType;\n    this.extName = extName;\n    this.arg = arg;\n    this.dest = destKeypath;\n    this.ref = ref;\n    this.rawDest = rawDest;\n  }\n\n  /**\n   * Return the schema ID (`$id`) for the **argument** given the parameters.\n   *\n   * If you need the \"root\" or \"base\" schema ID, use {@link ArgSpec.toSchemaBaseRef} instead.\n   * @param {string} name - Argument name\n   * @param {ExtensionType} [extType] - Extension type\n   * @param {string} [extName] - Extension name\n   * @returns {string} Schema ID\n   */\n  static toSchemaRef (name, extType, extName) {\n    const baseRef = ArgSpec.toSchemaBaseRef(extType, extName);\n    if (extType && extName) {\n      return [`${baseRef}#`, PROPERTIES, name].join('/');\n    }\n    return [`${baseRef}#`, PROPERTIES, SERVER_PROP_NAME, PROPERTIES, name].join('/');\n  }\n\n  /**\n   * Return the schema ID for an extension or the base schema ID.\n   * @param {ExtensionType} [extType] - Extension type\n   * @param {string} [extName] - Extension name\n   */\n  static toSchemaBaseRef (extType, extName) {\n    if (extType && extName) {\n      return `${extType}-${ArgSpec.toNormalizedExtName(extName)}.json`;\n    }\n    return APPIUM_CONFIG_SCHEMA_ID;\n  }\n\n  /**\n   * Return the unique ID for the argument given the parameters.\n   * @param {string} name - Argument name\n   * @param {ExtensionType} [extType] - Extension type\n   * @param {string} [extName] - Extension name\n   * @returns {string} Unique ID\n   */\n  static toArg (name, extType, extName) {\n    const properName = _.kebabCase(name.replace(/^--?/, ''));\n    if (extType && extName) {\n      return [extType, _.kebabCase(extName), properName].join('-');\n    }\n    return properName;\n  }\n\n  /**\n   * Normalizes a raw extension name (not including the type).\n   * @param {string} extName - Extension name\n   * @returns {string} Normalized extension name\n   */\n  static toNormalizedExtName (extName) {\n    return _.kebabCase(extName);\n  }\n\n  /**\n   * When given the root ID of a schema for an extension (`<extType>-<normalizedExtName>.json`) Returns an object containing the extension type and the _normalized_ extension name.\n   * @param {string} schemaId - Root schema ID\n   * @returns { {extType: ExtensionType|undefined, normalizedExtName: string|undefined} }\n   */\n  static extensionInfoFromRootSchemaId (schemaId) {\n    const matches = schemaId.match(SCHEMA_ID_REGEXP);\n    if (matches?.groups) {\n      const {extType, normalizedExtName} = matches.groups;\n      return {extType, normalizedExtName};\n    }\n    return {};\n  }\n\n  /**\n   * Creates an `ArgSpec`\n   *\n   * @param {string} name - The canonical name of the argument. Corresponds to a key in a schema's\n   * `properties` property.\n   * @param {ArgSpecOptions} [opts] - Options\n   * @returns {Readonly<ArgSpec>}\n   */\n  static create (name, opts) {\n    return Object.freeze(new ArgSpec(name, opts));\n  }\n\n  /**\n   * String representation, useful for debugging\n   * @returns {string}\n   */\n  /* istanbul ignore next */\n  toString () {\n    let str = `[ArgSpec] ${this.name} (${this.ref})`;\n    if (this.extType && this.extName) {\n      str += ` (ext: ${this.extType}/${this.extName})`;\n    }\n    return str;\n  }\n}\n\n/**\n * Options for {@link ArgSpec.create}\n * @template D\n * @typedef {Object} ArgSpecOptions\n * @property {string} [extName]\n * @property {ExtensionType} [extType]\n * @property {string} [dest]\n * @property {D} [defaultValue]\n */\n\n/**\n * @typedef {import('../ext-config-io').ExtensionType} ExtensionType\n */\n"],"file":"lib/schema/arg-spec.js","sourceRoot":"../../.."}
|