UNPKG

@appium/support

Version:

Support libs used across Appium packages

165 lines 6.58 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.resolveManifestPath = exports.resolveAppiumHome = exports.readPackageInDir = exports.findAppiumDependencyPackage = exports.MANIFEST_RELATIVE_PATH = exports.MANIFEST_BASENAME = exports.DEFAULT_APPIUM_HOME = void 0; exports.hasAppiumDependency = hasAppiumDependency; // @ts-check const lodash_1 = __importDefault(require("lodash")); const os_1 = require("os"); const path_1 = __importDefault(require("path")); const read_pkg_1 = __importDefault(require("read-pkg")); const semver = __importStar(require("semver")); /** * Path to the default `APPIUM_HOME` dir (`~/.appium`). * @type {string} */ exports.DEFAULT_APPIUM_HOME = path_1.default.resolve((0, os_1.homedir)(), '.appium'); /** * Basename of extension manifest file. * @type {string} */ exports.MANIFEST_BASENAME = 'extensions.yaml'; /** * Relative path to extension manifest file from `APPIUM_HOME`. * @type {string} */ exports.MANIFEST_RELATIVE_PATH = path_1.default.join('node_modules', '.cache', 'appium', exports.MANIFEST_BASENAME); /** * Resolves `true` if an `appium` dependency can be found somewhere in the given `cwd`. * * @param {string} cwd * @returns {Promise<boolean>} */ async function hasAppiumDependency(cwd) { return Boolean(await (0, exports.findAppiumDependencyPackage)(cwd)); } /** * Given `cwd`, use `npm` to find the closest package _or workspace root_, and return the path if the root depends upon `appium`. * * Looks at `dependencies` and `devDependencies` for `appium`. */ exports.findAppiumDependencyPackage = lodash_1.default.memoize( /** * @param {string} [cwd] * @param {string|semver.Range} [acceptableVersionRange='>=2.0.0-beta'] The expected * semver-compatible range for the Appium dependency. Packages that have 'appium' dependency * not satisfying this range will be skipped. * @returns {Promise<string|undefined>} */ async function findAppiumDependencyPackage(cwd = process.cwd(), acceptableVersionRange = '>=2.0.0-beta') { /** * Tries to read `package.json` in `root` and resolves the identity if it depends on `appium`; * otherwise resolves `undefined`. * @param {string} root * @returns {Promise<string|undefined>} */ const readPkg = async (root) => { try { const pkg = await (0, exports.readPackageInDir)(root); const version = semver.minVersion(String(pkg?.dependencies?.appium ?? pkg?.devDependencies?.appium ?? pkg?.peerDependencies?.appium)); return version && semver.satisfies(version, acceptableVersionRange) ? root : undefined; } catch { } }; let currentDir = path_1.default.resolve(cwd); let isAtFsRoot = false; while (!isAtFsRoot) { const result = await readPkg(currentDir); if (result) { return result; } currentDir = path_1.default.dirname(currentDir); isAtFsRoot = currentDir.length <= path_1.default.dirname(currentDir).length; } }); /** * Read a `package.json` in dir `cwd`. If none found, return `undefined`. */ exports.readPackageInDir = lodash_1.default.memoize( /** * * @param {string} cwd - Directory ostensibly having a `package.json` * @returns {Promise<import('read-pkg').NormalizedPackageJson|undefined>} */ async function _readPackageInDir(cwd) { return await (0, read_pkg_1.default)({ cwd, normalize: true }); }); /** * Determines location of Appium's "home" dir * * - If `APPIUM_HOME` is set in the environment, use that * - If we find a `package.json` in or above `cwd` and it has an `appium` dependency, use that. * * All returned paths will be absolute. */ exports.resolveAppiumHome = lodash_1.default.memoize( /** * @param {string} [cwd] - Current working directory. _Must_ be absolute, if specified. * @returns {Promise<string>} */ async function _resolveAppiumHome(cwd = process.cwd()) { if (!path_1.default.isAbsolute(cwd)) { throw new TypeError('`cwd` parameter must be an absolute path'); } if (process.env.APPIUM_HOME) { return path_1.default.resolve(cwd, process.env.APPIUM_HOME); } return await (0, exports.findAppiumDependencyPackage)(cwd) ?? exports.DEFAULT_APPIUM_HOME; }); /** * Figure out manifest path based on `appiumHome`. * * The assumption is that, if `appiumHome` has been provided, it was resolved via {@link resolveAppiumHome `resolveAppiumHome()`}! If unsure, * don't pass a parameter and let `resolveAppiumHome()` handle it. */ exports.resolveManifestPath = lodash_1.default.memoize( /** * @param {string} [appiumHome] - Appium home directory * @returns {Promise<string>} */ async function _resolveManifestPath(appiumHome) { // can you "await" in a default parameter? is that a good idea? appiumHome = appiumHome ?? (await (0, exports.resolveAppiumHome)()); return path_1.default.join(appiumHome, exports.MANIFEST_RELATIVE_PATH); }); /** * @typedef {import('read-pkg').NormalizedPackageJson} NormalizedPackageJson */ //# sourceMappingURL=env.js.map