appium-espresso-driver 2.8.3 → 2.8.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/build/index.js +2 -4
- package/build/lib/commands/execute.js +2 -4
- package/build/lib/commands/general.js +2 -4
- package/build/lib/commands/idling-resources.js +2 -4
- package/build/lib/commands/index.js +2 -4
- package/build/lib/commands/services.js +2 -4
- package/build/lib/desired-caps.js +2 -4
- package/build/lib/driver.js +6 -7
- package/build/lib/espresso-runner.js +10 -8
- package/build/lib/logger.js +2 -4
- package/build/lib/server-builder.js +2 -4
- package/build/lib/utils.js +73 -2
- package/espresso-server/app/build/outputs/apk/androidTest/debug/app-debug-androidTest.apk +0 -0
- package/espresso-server/app/src/test/java/io/appium/espressoserver/test/helpers/w3c/ActionSequenceTest.kt +2 -0
- package/lib/driver.js +3 -3
- package/lib/espresso-runner.js +8 -6
- package/lib/utils.js +74 -1
- package/npm-shrinkwrap.json +444 -349
- package/package.json +42 -26
|
@@ -200,7 +200,5 @@ class ServerBuilder {
|
|
|
200
200
|
|
|
201
201
|
exports.ServerBuilder = ServerBuilder;
|
|
202
202
|
var _default = ServerBuilder;
|
|
203
|
-
exports.default = _default;
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"file":"lib/server-builder.js","names":["GRADLE_VERSION_KEY","GRADLE_URL_PREFIX","GRADLE_URL_TEMPLATE","GRADLE_MAX_ERROR_LOG_LINES","DEPENDENCY_PROP_NAMES","VERSION_KEYS","buildServerSigningConfig","args","zipAlign","keystoreFile","keystorePassword","keyAlias","keyPassword","ServerBuilder","constructor","log","serverPath","showGradleLog","buildConfiguration","versionConfiguration","toolsVersions","serverVersions","_","reduce","acc","value","key","includes","warn","testAppPackage","signingConfig","propName","build","setGradleWrapperVersion","insertAdditionalDependencies","runBuildProcess","getCommand","cmd","system","isWindows","path","resolve","buildProperty","filter","map","serverVersion","gradleProperty","charAt","toUpperCase","slice","Boolean","push","keys","upperFirst","k","v","version","propertiesPath","originalProperties","fs","readFile","newProperties","updateGradleDistUrl","writeFile","propertiesContent","replace","RegExp","escapeRegExp","hasAdditionalDeps","isArray","Error","isEmpty","line","trim","dep","test","buildPath","configuration","prefix","deps","info","updateDependencyLines","debug","join","gradlebuild","SubProcess","cwd","stdio","windowsVerbatimArguments","buildLastLines","logMsg","on","startsWith","EOL","length","start","err","msg","message","errorAndThrow"],"sourceRoot":"../..","sources":["lib/server-builder.js"],"sourcesContent":["import { SubProcess } from 'teen_process';\nimport { fs, system } from 'appium/support';\nimport _ from 'lodash';\nimport path from 'path';\nimport { EOL } from 'os';\nimport { updateDependencyLines } from './utils';\n\nconst GRADLE_VERSION_KEY = 'gradle';\nconst GRADLE_URL_PREFIX = 'distributionUrl=';\nconst GRADLE_URL_TEMPLATE = 'https\\\\://services.gradle.org/distributions/gradle-VERSION-all.zip';\nconst GRADLE_MAX_ERROR_LOG_LINES = 15;\nconst DEPENDENCY_PROP_NAMES = ['additionalAppDependencies', 'additionalAndroidTestDependencies'];\n\nconst VERSION_KEYS = [\n  GRADLE_VERSION_KEY,\n  'androidGradlePlugin',\n  'compileSdk',\n  'buildTools',\n  'minSdk',\n  'targetSdk',\n  'kotlin',\n  'sourceCompatibility',\n  'targetCompatibility',\n  'jvmTarget',\n  'composeVersion',\n  'annotationVersion'\n];\n\nfunction buildServerSigningConfig (args) {\n  return {\n    zipAlign: true,\n    keystoreFile: args.keystoreFile,\n    keystorePassword: args.keystorePassword,\n    keyAlias: args.keyAlias,\n    keyPassword: args.keyPassword\n  };\n}\n\nclass ServerBuilder {\n  constructor (log, args = {}) {\n    this.log = log;\n    this.serverPath = args.serverPath;\n    this.showGradleLog = args.showGradleLog;\n\n    const buildConfiguration = args.buildConfiguration || {};\n\n    const versionConfiguration = buildConfiguration.toolsVersions || {};\n    this.serverVersions = _.reduce(versionConfiguration, (acc, value, key) => {\n      if (VERSION_KEYS.includes(key)) {\n        acc[key] = value;\n      } else {\n        log.warn(`Got unexpected '${key}' in toolsVersion block of the build configuration`);\n      }\n      return acc;\n    }, {});\n\n    this.testAppPackage = args.testAppPackage;\n    this.signingConfig = args.signingConfig;\n\n    for (const propName of DEPENDENCY_PROP_NAMES) {\n      this[propName] = buildConfiguration[propName] || [];\n    }\n  }\n\n  async build () {\n    if (this.serverVersions[GRADLE_VERSION_KEY]) {\n      await this.setGradleWrapperVersion(this.serverVersions[GRADLE_VERSION_KEY]);\n    }\n\n    await this.insertAdditionalDependencies();\n\n    await this.runBuildProcess();\n  }\n\n  getCommand () {\n    const cmd = system.isWindows() ? 'gradlew.bat' : path.resolve(this.serverPath, 'gradlew');\n    const buildProperty = (key, value) => value ? `-P${key}=${value}` : null;\n    let args = VERSION_KEYS\n      .filter((key) => key !== GRADLE_VERSION_KEY)\n      .map((key) => {\n        const serverVersion = this.serverVersions[key];\n        const gradleProperty = `appium${key.charAt(0).toUpperCase()}${key.slice(1)}`;\n        return buildProperty(gradleProperty, serverVersion);\n      })\n      .filter(Boolean);\n\n    if (this.signingConfig) {\n      args.push(...(\n        _.keys(this.signingConfig)\n        .map((key) => [`appium${_.upperFirst(key)}`, this.signingConfig[key]])\n        .map(([k, v]) => buildProperty(k, v))\n        .filter(Boolean)\n      ));\n    }\n\n    if (this.testAppPackage) {\n      args.push(buildProperty('appiumTargetPackage', this.testAppPackage));\n    }\n    args.push('app:assembleAndroidTest');\n\n    return {cmd, args};\n  }\n\n  async setGradleWrapperVersion (version) {\n    const propertiesPath = path.resolve(this.serverPath, 'gradle', 'wrapper', 'gradle-wrapper.properties');\n    const originalProperties = await fs.readFile(propertiesPath, 'utf8');\n    const newProperties = this.updateGradleDistUrl(originalProperties, version);\n    await fs.writeFile(propertiesPath, newProperties, 'utf8');\n  }\n\n  updateGradleDistUrl (propertiesContent, version) {\n    return propertiesContent.replace(\n      new RegExp(`^(${_.escapeRegExp(GRADLE_URL_PREFIX)}).+$`, 'gm'),\n      `$1${GRADLE_URL_TEMPLATE.replace('VERSION', version)}`\n    );\n  }\n\n  async insertAdditionalDependencies () {\n    let hasAdditionalDeps = false;\n    for (const propName of DEPENDENCY_PROP_NAMES) {\n      if (!_.isArray(this[propName])) {\n        throw new Error(`'${propName}' must be an array`);\n      }\n      if (_.isEmpty(this[propName].filter((line) => _.trim(line)))) {\n        continue;\n      }\n\n      for (const dep of this[propName]) {\n        if (/[\\s'\\\\$]/.test(dep)) {\n          throw new Error('Single quotes, dollar characters and whitespace characters' +\n            ` are disallowed in additional dependencies: ${dep}`);\n        }\n      }\n      hasAdditionalDeps = true;\n    }\n    if (!hasAdditionalDeps) {\n      return;\n    }\n\n    const buildPath = path.resolve(this.serverPath, 'app', 'build.gradle.kts');\n    let configuration = await fs.readFile(buildPath, 'utf8');\n    for (const propName of DEPENDENCY_PROP_NAMES) {\n      const prefix = propName === DEPENDENCY_PROP_NAMES[0]\n        ? 'implementation'\n        : 'androidTestImplementation';\n      const deps = this[propName]\n        .filter((line) => _.trim(line))\n        .map((line) => `${prefix}(\"${line}\")`);\n      if (_.isEmpty(deps)) {\n        continue;\n      }\n\n      this.log.info(`Adding the following ${propName} to build.gradle.kts: ${deps}`);\n      configuration = updateDependencyLines(configuration, propName, deps);\n    }\n    await fs.writeFile(buildPath, configuration, 'utf8');\n  }\n\n  async runBuildProcess () {\n    const {cmd, args} = this.getCommand();\n    this.log.debug(`Beginning build with command '${cmd} ${args.join(' ')}' ` +\n      `in directory '${this.serverPath}'`);\n    const gradlebuild = new SubProcess(cmd, args, {\n      cwd: this.serverPath,\n      stdio: ['ignore', 'pipe', 'pipe'],\n      windowsVerbatimArguments: true\n    });\n    let buildLastLines = [];\n\n    const logMsg = `Output from Gradle ${this.showGradleLog ? 'will' : 'will not'} be logged`;\n    this.log.debug(`${logMsg}. To change this, use 'showGradleLog' desired capability`);\n    gradlebuild.on('stream-line', (line) => {\n      if (this.showGradleLog) {\n        if (line.startsWith('[STDERR]')) {\n          this.log.warn(`[Gradle] ${line}`);\n        } else {\n          this.log.info(`[Gradle] ${line}`);\n        }\n      }\n      buildLastLines.push(`${EOL}${line}`);\n      if (buildLastLines.length > GRADLE_MAX_ERROR_LOG_LINES) {\n        buildLastLines = buildLastLines.slice(-GRADLE_MAX_ERROR_LOG_LINES);\n      }\n    });\n\n    try {\n      await gradlebuild.start();\n      await gradlebuild.join();\n    } catch (err) {\n      let msg = `Unable to build Espresso server - ${err.message}\\n` +\n        `Gradle error message:${EOL}${buildLastLines}`;\n      this.log.errorAndThrow(msg);\n    }\n  }\n}\n\nexport { ServerBuilder, VERSION_KEYS, GRADLE_URL_TEMPLATE, buildServerSigningConfig };\nexport default ServerBuilder;\n"],"mappings":"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"}
|
|
203
|
+
exports.default = _default;
|
|
204
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["GRADLE_VERSION_KEY","GRADLE_URL_PREFIX","GRADLE_URL_TEMPLATE","GRADLE_MAX_ERROR_LOG_LINES","DEPENDENCY_PROP_NAMES","VERSION_KEYS","buildServerSigningConfig","args","zipAlign","keystoreFile","keystorePassword","keyAlias","keyPassword","ServerBuilder","constructor","log","serverPath","showGradleLog","buildConfiguration","versionConfiguration","toolsVersions","serverVersions","_","reduce","acc","value","key","includes","warn","testAppPackage","signingConfig","propName","build","setGradleWrapperVersion","insertAdditionalDependencies","runBuildProcess","getCommand","cmd","system","isWindows","path","resolve","buildProperty","filter","map","serverVersion","gradleProperty","charAt","toUpperCase","slice","Boolean","push","keys","upperFirst","k","v","version","propertiesPath","originalProperties","fs","readFile","newProperties","updateGradleDistUrl","writeFile","propertiesContent","replace","RegExp","escapeRegExp","hasAdditionalDeps","isArray","Error","isEmpty","line","trim","dep","test","buildPath","configuration","prefix","deps","info","updateDependencyLines","debug","join","gradlebuild","SubProcess","cwd","stdio","windowsVerbatimArguments","buildLastLines","logMsg","on","startsWith","EOL","length","start","err","msg","message","errorAndThrow"],"sources":["../../lib/server-builder.js"],"sourcesContent":["import { SubProcess } from 'teen_process';\nimport { fs, system } from 'appium/support';\nimport _ from 'lodash';\nimport path from 'path';\nimport { EOL } from 'os';\nimport { updateDependencyLines } from './utils';\n\nconst GRADLE_VERSION_KEY = 'gradle';\nconst GRADLE_URL_PREFIX = 'distributionUrl=';\nconst GRADLE_URL_TEMPLATE = 'https\\\\://services.gradle.org/distributions/gradle-VERSION-all.zip';\nconst GRADLE_MAX_ERROR_LOG_LINES = 15;\nconst DEPENDENCY_PROP_NAMES = ['additionalAppDependencies', 'additionalAndroidTestDependencies'];\n\nconst VERSION_KEYS = [\n  GRADLE_VERSION_KEY,\n  'androidGradlePlugin',\n  'compileSdk',\n  'buildTools',\n  'minSdk',\n  'targetSdk',\n  'kotlin',\n  'sourceCompatibility',\n  'targetCompatibility',\n  'jvmTarget',\n  'composeVersion',\n  'annotationVersion'\n];\n\nfunction buildServerSigningConfig (args) {\n  return {\n    zipAlign: true,\n    keystoreFile: args.keystoreFile,\n    keystorePassword: args.keystorePassword,\n    keyAlias: args.keyAlias,\n    keyPassword: args.keyPassword\n  };\n}\n\nclass ServerBuilder {\n  constructor (log, args = {}) {\n    this.log = log;\n    this.serverPath = args.serverPath;\n    this.showGradleLog = args.showGradleLog;\n\n    const buildConfiguration = args.buildConfiguration || {};\n\n    const versionConfiguration = buildConfiguration.toolsVersions || {};\n    this.serverVersions = _.reduce(versionConfiguration, (acc, value, key) => {\n      if (VERSION_KEYS.includes(key)) {\n        acc[key] = value;\n      } else {\n        log.warn(`Got unexpected '${key}' in toolsVersion block of the build configuration`);\n      }\n      return acc;\n    }, {});\n\n    this.testAppPackage = args.testAppPackage;\n    this.signingConfig = args.signingConfig;\n\n    for (const propName of DEPENDENCY_PROP_NAMES) {\n      this[propName] = buildConfiguration[propName] || [];\n    }\n  }\n\n  async build () {\n    if (this.serverVersions[GRADLE_VERSION_KEY]) {\n      await this.setGradleWrapperVersion(this.serverVersions[GRADLE_VERSION_KEY]);\n    }\n\n    await this.insertAdditionalDependencies();\n\n    await this.runBuildProcess();\n  }\n\n  getCommand () {\n    const cmd = system.isWindows() ? 'gradlew.bat' : path.resolve(this.serverPath, 'gradlew');\n    const buildProperty = (key, value) => value ? `-P${key}=${value}` : null;\n    let args = VERSION_KEYS\n      .filter((key) => key !== GRADLE_VERSION_KEY)\n      .map((key) => {\n        const serverVersion = this.serverVersions[key];\n        const gradleProperty = `appium${key.charAt(0).toUpperCase()}${key.slice(1)}`;\n        return buildProperty(gradleProperty, serverVersion);\n      })\n      .filter(Boolean);\n\n    if (this.signingConfig) {\n      args.push(...(\n        _.keys(this.signingConfig)\n        .map((key) => [`appium${_.upperFirst(key)}`, this.signingConfig[key]])\n        .map(([k, v]) => buildProperty(k, v))\n        .filter(Boolean)\n      ));\n    }\n\n    if (this.testAppPackage) {\n      args.push(buildProperty('appiumTargetPackage', this.testAppPackage));\n    }\n    args.push('app:assembleAndroidTest');\n\n    return {cmd, args};\n  }\n\n  async setGradleWrapperVersion (version) {\n    const propertiesPath = path.resolve(this.serverPath, 'gradle', 'wrapper', 'gradle-wrapper.properties');\n    const originalProperties = await fs.readFile(propertiesPath, 'utf8');\n    const newProperties = this.updateGradleDistUrl(originalProperties, version);\n    await fs.writeFile(propertiesPath, newProperties, 'utf8');\n  }\n\n  updateGradleDistUrl (propertiesContent, version) {\n    return propertiesContent.replace(\n      new RegExp(`^(${_.escapeRegExp(GRADLE_URL_PREFIX)}).+$`, 'gm'),\n      `$1${GRADLE_URL_TEMPLATE.replace('VERSION', version)}`\n    );\n  }\n\n  async insertAdditionalDependencies () {\n    let hasAdditionalDeps = false;\n    for (const propName of DEPENDENCY_PROP_NAMES) {\n      if (!_.isArray(this[propName])) {\n        throw new Error(`'${propName}' must be an array`);\n      }\n      if (_.isEmpty(this[propName].filter((line) => _.trim(line)))) {\n        continue;\n      }\n\n      for (const dep of this[propName]) {\n        if (/[\\s'\\\\$]/.test(dep)) {\n          throw new Error('Single quotes, dollar characters and whitespace characters' +\n            ` are disallowed in additional dependencies: ${dep}`);\n        }\n      }\n      hasAdditionalDeps = true;\n    }\n    if (!hasAdditionalDeps) {\n      return;\n    }\n\n    const buildPath = path.resolve(this.serverPath, 'app', 'build.gradle.kts');\n    let configuration = await fs.readFile(buildPath, 'utf8');\n    for (const propName of DEPENDENCY_PROP_NAMES) {\n      const prefix = propName === DEPENDENCY_PROP_NAMES[0]\n        ? 'implementation'\n        : 'androidTestImplementation';\n      const deps = this[propName]\n        .filter((line) => _.trim(line))\n        .map((line) => `${prefix}(\"${line}\")`);\n      if (_.isEmpty(deps)) {\n        continue;\n      }\n\n      this.log.info(`Adding the following ${propName} to build.gradle.kts: ${deps}`);\n      configuration = updateDependencyLines(configuration, propName, deps);\n    }\n    await fs.writeFile(buildPath, configuration, 'utf8');\n  }\n\n  async runBuildProcess () {\n    const {cmd, args} = this.getCommand();\n    this.log.debug(`Beginning build with command '${cmd} ${args.join(' ')}' ` +\n      `in directory '${this.serverPath}'`);\n    const gradlebuild = new SubProcess(cmd, args, {\n      cwd: this.serverPath,\n      stdio: ['ignore', 'pipe', 'pipe'],\n      windowsVerbatimArguments: true\n    });\n    let buildLastLines = [];\n\n    const logMsg = `Output from Gradle ${this.showGradleLog ? 'will' : 'will not'} be logged`;\n    this.log.debug(`${logMsg}. To change this, use 'showGradleLog' desired capability`);\n    gradlebuild.on('stream-line', (line) => {\n      if (this.showGradleLog) {\n        if (line.startsWith('[STDERR]')) {\n          this.log.warn(`[Gradle] ${line}`);\n        } else {\n          this.log.info(`[Gradle] ${line}`);\n        }\n      }\n      buildLastLines.push(`${EOL}${line}`);\n      if (buildLastLines.length > GRADLE_MAX_ERROR_LOG_LINES) {\n        buildLastLines = buildLastLines.slice(-GRADLE_MAX_ERROR_LOG_LINES);\n      }\n    });\n\n    try {\n      await gradlebuild.start();\n      await gradlebuild.join();\n    } catch (err) {\n      let msg = `Unable to build Espresso server - ${err.message}\\n` +\n        `Gradle error message:${EOL}${buildLastLines}`;\n      this.log.errorAndThrow(msg);\n    }\n  }\n}\n\nexport { ServerBuilder, VERSION_KEYS, GRADLE_URL_TEMPLATE, buildServerSigningConfig };\nexport default ServerBuilder;\n"],"mappings":"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"}
|
package/build/lib/utils.js
CHANGED
|
@@ -6,6 +6,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
8
|
exports.copyGradleProjectRecursively = copyGradleProjectRecursively;
|
|
9
|
+
exports.getPackageInfo = getPackageInfo;
|
|
10
|
+
exports.getPackageInfoSync = getPackageInfoSync;
|
|
9
11
|
exports.qualifyActivityName = qualifyActivityName;
|
|
10
12
|
exports.requireOptions = requireOptions;
|
|
11
13
|
exports.updateDependencyLines = updateDependencyLines;
|
|
@@ -18,6 +20,11 @@ var _lodash = _interopRequireDefault(require("lodash"));
|
|
|
18
20
|
|
|
19
21
|
var _path = _interopRequireDefault(require("path"));
|
|
20
22
|
|
|
23
|
+
var _fs2 = _interopRequireDefault(require("fs"));
|
|
24
|
+
|
|
25
|
+
let PACKAGE_INFO = null;
|
|
26
|
+
const MODULE_NAME = 'appium-espresso-driver';
|
|
27
|
+
|
|
21
28
|
function qualifyActivityName(activityName, packageName) {
|
|
22
29
|
if ([activityName, packageName].some(name => !name || _lodash.default.includes(name, '*'))) {
|
|
23
30
|
return activityName;
|
|
@@ -79,7 +86,71 @@ function updateDependencyLines(originalContent, dependencyPlaceholder, dependenc
|
|
|
79
86
|
|
|
80
87
|
configurationLines.splice(placeholderIndex + 1, 0, ...dependencyLines.map(line => `${' '.repeat(indentLen)}${line}`));
|
|
81
88
|
return configurationLines.join('\n');
|
|
82
|
-
}
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
async function getPackageInfo() {
|
|
92
|
+
if (PACKAGE_INFO) {
|
|
93
|
+
return PACKAGE_INFO;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
let currentDir = _path.default.dirname(_path.default.resolve(__filename));
|
|
83
97
|
|
|
98
|
+
let isAtFsRoot = false;
|
|
84
99
|
|
|
85
|
-
|
|
100
|
+
while (!isAtFsRoot) {
|
|
101
|
+
const manifestPath = _path.default.join(currentDir, 'package.json');
|
|
102
|
+
|
|
103
|
+
try {
|
|
104
|
+
if (await _support.fs.exists(manifestPath)) {
|
|
105
|
+
const manifestPayload = JSON.parse(await _support.fs.readFile(manifestPath, 'utf8'));
|
|
106
|
+
|
|
107
|
+
if (manifestPayload.name === MODULE_NAME) {
|
|
108
|
+
PACKAGE_INFO = {
|
|
109
|
+
manifestPath,
|
|
110
|
+
manifestPayload
|
|
111
|
+
};
|
|
112
|
+
return PACKAGE_INFO;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
} catch (ign) {}
|
|
116
|
+
|
|
117
|
+
currentDir = _path.default.dirname(currentDir);
|
|
118
|
+
isAtFsRoot = currentDir.length <= _path.default.dirname(currentDir).length;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
throw new Error(`Cannot find the root folder of the ${MODULE_NAME} Node.js module`);
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
function getPackageInfoSync() {
|
|
125
|
+
if (PACKAGE_INFO) {
|
|
126
|
+
return PACKAGE_INFO;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
let currentDir = _path.default.dirname(_path.default.resolve(__filename));
|
|
130
|
+
|
|
131
|
+
let isAtFsRoot = false;
|
|
132
|
+
|
|
133
|
+
while (!isAtFsRoot) {
|
|
134
|
+
const manifestPath = _path.default.join(currentDir, 'package.json');
|
|
135
|
+
|
|
136
|
+
try {
|
|
137
|
+
if (_fs2.default.existsSync(manifestPath)) {
|
|
138
|
+
const manifestPayload = JSON.parse(_fs2.default.readFileSync(manifestPath, 'utf8'));
|
|
139
|
+
|
|
140
|
+
if (manifestPayload.name === MODULE_NAME) {
|
|
141
|
+
PACKAGE_INFO = {
|
|
142
|
+
manifestPath,
|
|
143
|
+
manifestPayload
|
|
144
|
+
};
|
|
145
|
+
return PACKAGE_INFO;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
} catch (ign) {}
|
|
149
|
+
|
|
150
|
+
currentDir = _path.default.dirname(currentDir);
|
|
151
|
+
isAtFsRoot = currentDir.length <= _path.default.dirname(currentDir).length;
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
throw new Error(`Cannot find the root folder of the ${MODULE_NAME} Node.js module`);
|
|
155
|
+
}
|
|
156
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["PACKAGE_INFO","MODULE_NAME","qualifyActivityName","activityName","packageName","some","name","_","includes","dotPos","indexOf","copyGradleProjectRecursively","sourceBaseDir","targetBaseDir","fs","walkDir","itemPath","isDirectory","relativePath","path","relative","targetPath","resolve","isInGradleBuildDir","sep","mkdirp","copyFile","requireOptions","opts","requiredKeys","missingKeys","difference","keys","isEmpty","Error","updateDependencyLines","originalContent","dependencyPlaceholder","dependencyLines","configurationLines","split","searchRe","RegExp","escapeRegExp","placeholderIndex","findIndex","line","test","placeholderLine","indentLen","length","trimStart","splice","map","repeat","join","getPackageInfo","currentDir","dirname","__filename","isAtFsRoot","manifestPath","exists","manifestPayload","JSON","parse","readFile","ign","getPackageInfoSync","_fs","existsSync","readFileSync"],"sources":["../../lib/utils.js"],"sourcesContent":["import { fs, mkdirp } from 'appium/support';\nimport _ from 'lodash';\nimport path from 'path';\nimport _fs from 'fs';\n\nlet PACKAGE_INFO = null;\nconst MODULE_NAME = 'appium-espresso-driver';\n\n/**\n * https://android.googlesource.com/platform/frameworks/base/+/master/tools/aapt/Resource.cpp#755\n *\n * @param {string} activityName\n * @param {string} packageName\n * @returns {string} The qualified activity name\n */\nfunction qualifyActivityName (activityName, packageName) {\n  // if either activity or package name is not set\n  // or any of these contain wildcards then there is\n  // no point in qualifying the activity name\n  if ([activityName, packageName].some((name) => !name || _.includes(name, '*'))) {\n    return activityName;\n  }\n\n  const dotPos = activityName.indexOf('.');\n  if (dotPos > 0) {\n    return activityName;\n  }\n  return `${packageName}${dotPos === 0 ? '' : '.'}${activityName}`;\n}\n\n/**\n * Recursively copy all files except build directories contents\n * @param sourceBaseDir {string} directory to copy files from\n * @param targetBaseDir {string} directory to copy files to\n */\nasync function copyGradleProjectRecursively (sourceBaseDir, targetBaseDir) {\n  await fs.walkDir(sourceBaseDir, true, async (itemPath, isDirectory) => {\n    const relativePath = path.relative(sourceBaseDir, itemPath);\n    const targetPath = path.resolve(targetBaseDir, relativePath);\n\n    const isInGradleBuildDir = `${path.sep}${itemPath}`.includes(`${path.sep}build${path.sep}`);\n    if (isInGradleBuildDir) {\n      return false;\n    }\n\n    if (isDirectory) {\n      await mkdirp(targetPath);\n    } else {\n      await fs.copyFile(itemPath, targetPath);\n    }\n    return false;\n  });\n}\n\nfunction requireOptions (opts, requiredKeys = []) {\n  const missingKeys = _.difference(requiredKeys, _.keys(opts));\n  if (!_.isEmpty(missingKeys)) {\n    throw new Error(`The following options are required: ${missingKeys}`);\n  }\n  return opts;\n}\n\nfunction updateDependencyLines (originalContent, dependencyPlaceholder, dependencyLines) {\n  const configurationLines = originalContent.split('\\n');\n  const searchRe = new RegExp(`^\\\\s*//\\\\s*\\\\b${_.escapeRegExp(dependencyPlaceholder)}\\\\b`, 'm');\n  const placeholderIndex = configurationLines.findIndex((line) => searchRe.test(line));\n  if (placeholderIndex < 0) {\n    return originalContent;\n  }\n\n  const placeholderLine = configurationLines[placeholderIndex];\n  const indentLen = placeholderLine.length - _.trimStart(placeholderLine).length;\n  configurationLines.splice(placeholderIndex + 1, 0, ...(dependencyLines\n    .map((line) => `${' '.repeat(indentLen)}${line}`)));\n  return configurationLines.join('\\n');\n}\n\n/**\n * Fetches the module info from package.json\n *\n * @returns {object} The full path to module's package.json and its payload\n * @throws {Error} If package.json cannot be found\n */\nasync function getPackageInfo () {\n  if (PACKAGE_INFO) {\n    return PACKAGE_INFO;\n  }\n\n  let currentDir = path.dirname(path.resolve(__filename));\n  let isAtFsRoot = false;\n  while (!isAtFsRoot) {\n    const manifestPath = path.join(currentDir, 'package.json');\n    try {\n      if (await fs.exists(manifestPath)) {\n        const manifestPayload = JSON.parse(await fs.readFile(manifestPath, 'utf8'));\n        if (manifestPayload.name === MODULE_NAME) {\n          PACKAGE_INFO = {\n            manifestPath,\n            manifestPayload\n          };\n          return PACKAGE_INFO;\n        }\n      }\n    } catch (ign) {}\n    currentDir = path.dirname(currentDir);\n    isAtFsRoot = currentDir.length <= path.dirname(currentDir).length;\n  }\n  throw new Error(`Cannot find the root folder of the ${MODULE_NAME} Node.js module`);\n}\n\n/**\n * Fetches the module info from package.json synchronously\n *\n * @returns {object} The full path to module's package.json and its payload\n * @throws {Error} If package.json cannot be found\n */\nfunction getPackageInfoSync () {\n  if (PACKAGE_INFO) {\n    return PACKAGE_INFO;\n  }\n\n  let currentDir = path.dirname(path.resolve(__filename));\n  let isAtFsRoot = false;\n  while (!isAtFsRoot) {\n    const manifestPath = path.join(currentDir, 'package.json');\n    try {\n      if (_fs.existsSync(manifestPath)) {\n        const manifestPayload = JSON.parse(_fs.readFileSync(manifestPath, 'utf8'));\n        if (manifestPayload.name === MODULE_NAME) {\n          PACKAGE_INFO = {\n            manifestPath,\n            manifestPayload\n          };\n          return PACKAGE_INFO;\n        }\n      }\n    } catch (ign) {}\n    currentDir = path.dirname(currentDir);\n    isAtFsRoot = currentDir.length <= path.dirname(currentDir).length;\n  }\n  throw new Error(`Cannot find the root folder of the ${MODULE_NAME} Node.js module`);\n}\n\nexport {\n  qualifyActivityName, copyGradleProjectRecursively, requireOptions,\n  updateDependencyLines, getPackageInfo, getPackageInfoSync\n};\n"],"mappings":"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"}
|
|
Binary file
|
|
@@ -27,6 +27,7 @@ import io.appium.espressoserver.lib.helpers.w3c.models.InputSource.InputSourceTy
|
|
|
27
27
|
import io.appium.espressoserver.lib.helpers.w3c.models.InputSource.InputSourceType.POINTER
|
|
28
28
|
import io.appium.espressoserver.test.assets.readAssetFile
|
|
29
29
|
import org.junit.Assert.*
|
|
30
|
+
import org.junit.Ignore
|
|
30
31
|
|
|
31
32
|
class ActionSequenceTest {
|
|
32
33
|
|
|
@@ -204,6 +205,7 @@ class ActionSequenceTest {
|
|
|
204
205
|
}
|
|
205
206
|
|
|
206
207
|
@Test
|
|
208
|
+
@Ignore("The test is unstable in CI env")
|
|
207
209
|
@Throws(IOException::class, AppiumException::class, InterruptedException::class, ExecutionException::class)
|
|
208
210
|
fun shouldDispatchW3CKeyActions() {
|
|
209
211
|
val inputStateTable = InputStateTable()
|
package/lib/driver.js
CHANGED
|
@@ -8,10 +8,9 @@ import commands from './commands';
|
|
|
8
8
|
import { DEFAULT_ADB_PORT } from 'appium-adb';
|
|
9
9
|
import { androidHelpers, androidCommands, SETTINGS_HELPER_PKG_ID } from 'appium-android-driver';
|
|
10
10
|
import desiredCapConstraints from './desired-caps';
|
|
11
|
-
import { version } from '../../package.json'; // eslint-disable-line import/no-unresolved
|
|
12
11
|
import { findAPortNotInUse } from 'portscanner';
|
|
13
12
|
import { retryInterval } from 'asyncbox';
|
|
14
|
-
import { qualifyActivityName } from './utils';
|
|
13
|
+
import { qualifyActivityName, getPackageInfo } from './utils';
|
|
15
14
|
|
|
16
15
|
|
|
17
16
|
// TODO merge our own helpers onto this later
|
|
@@ -370,7 +369,8 @@ class EspressoDriver extends BaseDriver {
|
|
|
370
369
|
|
|
371
370
|
// TODO much of this logic is duplicated from uiautomator2
|
|
372
371
|
async startEspressoSession () {
|
|
373
|
-
|
|
372
|
+
const {manifestPayload} = await getPackageInfo();
|
|
373
|
+
this.log.info(`EspressoDriver version: ${manifestPayload.version}`);
|
|
374
374
|
|
|
375
375
|
// Read https://github.com/appium/appium-android-driver/pull/461 what happens if ther is no setHiddenApiPolicy for Android P+
|
|
376
376
|
if (await this.adb.getApiLevel() >= 28) { // Android P
|
package/lib/espresso-runner.js
CHANGED
|
@@ -3,10 +3,9 @@ import { waitForCondition } from 'asyncbox';
|
|
|
3
3
|
import { ServerBuilder, buildServerSigningConfig } from './server-builder';
|
|
4
4
|
import path from 'path';
|
|
5
5
|
import { fs, util, mkdirp, timing } from 'appium/support';
|
|
6
|
-
import { version } from '../../package.json'; // eslint-disable-line import/no-unresolved
|
|
7
6
|
import B from 'bluebird';
|
|
8
7
|
import _ from 'lodash';
|
|
9
|
-
import { copyGradleProjectRecursively } from './utils';
|
|
8
|
+
import { copyGradleProjectRecursively, getPackageInfoSync, getPackageInfo } from './utils';
|
|
10
9
|
import axios from 'axios';
|
|
11
10
|
|
|
12
11
|
|
|
@@ -59,9 +58,11 @@ class EspressoRunner {
|
|
|
59
58
|
crashed: false,
|
|
60
59
|
};
|
|
61
60
|
|
|
62
|
-
const
|
|
63
|
-
|
|
64
|
-
|
|
61
|
+
const { manifestPayload } = getPackageInfoSync();
|
|
62
|
+
const modServerName = fs.sanitizeName(
|
|
63
|
+
`${TEST_APK_PKG}_${manifestPayload.version}_${this.appPackage}_${this.adb.curDeviceId}.apk`,
|
|
64
|
+
{replacement: '-'}
|
|
65
|
+
);
|
|
65
66
|
this.modServerPath = path.resolve(this.tmpDir, modServerName);
|
|
66
67
|
this.showGradleLog = opts.showGradleLog;
|
|
67
68
|
this.espressoBuildConfig = opts.espressoBuildConfig;
|
|
@@ -242,7 +243,8 @@ class EspressoRunner {
|
|
|
242
243
|
|
|
243
244
|
cmd.push(`${TEST_APK_PKG}/androidx.test.runner.AndroidJUnitRunner`);
|
|
244
245
|
|
|
245
|
-
|
|
246
|
+
const {manifestPayload} = await getPackageInfo();
|
|
247
|
+
this.log.info(`Starting Espresso Server v${manifestPayload.version} with cmd: adb ${cmd.join(' ')}`);
|
|
246
248
|
|
|
247
249
|
let hasSocketError = false;
|
|
248
250
|
// start the instrumentation process
|
package/lib/utils.js
CHANGED
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
import { fs, mkdirp } from 'appium/support';
|
|
2
2
|
import _ from 'lodash';
|
|
3
3
|
import path from 'path';
|
|
4
|
+
import _fs from 'fs';
|
|
5
|
+
|
|
6
|
+
let PACKAGE_INFO = null;
|
|
7
|
+
const MODULE_NAME = 'appium-espresso-driver';
|
|
4
8
|
|
|
5
9
|
/**
|
|
6
10
|
* https://android.googlesource.com/platform/frameworks/base/+/master/tools/aapt/Resource.cpp#755
|
|
@@ -71,4 +75,73 @@ function updateDependencyLines (originalContent, dependencyPlaceholder, dependen
|
|
|
71
75
|
return configurationLines.join('\n');
|
|
72
76
|
}
|
|
73
77
|
|
|
74
|
-
|
|
78
|
+
/**
|
|
79
|
+
* Fetches the module info from package.json
|
|
80
|
+
*
|
|
81
|
+
* @returns {object} The full path to module's package.json and its payload
|
|
82
|
+
* @throws {Error} If package.json cannot be found
|
|
83
|
+
*/
|
|
84
|
+
async function getPackageInfo () {
|
|
85
|
+
if (PACKAGE_INFO) {
|
|
86
|
+
return PACKAGE_INFO;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
let currentDir = path.dirname(path.resolve(__filename));
|
|
90
|
+
let isAtFsRoot = false;
|
|
91
|
+
while (!isAtFsRoot) {
|
|
92
|
+
const manifestPath = path.join(currentDir, 'package.json');
|
|
93
|
+
try {
|
|
94
|
+
if (await fs.exists(manifestPath)) {
|
|
95
|
+
const manifestPayload = JSON.parse(await fs.readFile(manifestPath, 'utf8'));
|
|
96
|
+
if (manifestPayload.name === MODULE_NAME) {
|
|
97
|
+
PACKAGE_INFO = {
|
|
98
|
+
manifestPath,
|
|
99
|
+
manifestPayload
|
|
100
|
+
};
|
|
101
|
+
return PACKAGE_INFO;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
} catch (ign) {}
|
|
105
|
+
currentDir = path.dirname(currentDir);
|
|
106
|
+
isAtFsRoot = currentDir.length <= path.dirname(currentDir).length;
|
|
107
|
+
}
|
|
108
|
+
throw new Error(`Cannot find the root folder of the ${MODULE_NAME} Node.js module`);
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
/**
|
|
112
|
+
* Fetches the module info from package.json synchronously
|
|
113
|
+
*
|
|
114
|
+
* @returns {object} The full path to module's package.json and its payload
|
|
115
|
+
* @throws {Error} If package.json cannot be found
|
|
116
|
+
*/
|
|
117
|
+
function getPackageInfoSync () {
|
|
118
|
+
if (PACKAGE_INFO) {
|
|
119
|
+
return PACKAGE_INFO;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
let currentDir = path.dirname(path.resolve(__filename));
|
|
123
|
+
let isAtFsRoot = false;
|
|
124
|
+
while (!isAtFsRoot) {
|
|
125
|
+
const manifestPath = path.join(currentDir, 'package.json');
|
|
126
|
+
try {
|
|
127
|
+
if (_fs.existsSync(manifestPath)) {
|
|
128
|
+
const manifestPayload = JSON.parse(_fs.readFileSync(manifestPath, 'utf8'));
|
|
129
|
+
if (manifestPayload.name === MODULE_NAME) {
|
|
130
|
+
PACKAGE_INFO = {
|
|
131
|
+
manifestPath,
|
|
132
|
+
manifestPayload
|
|
133
|
+
};
|
|
134
|
+
return PACKAGE_INFO;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
} catch (ign) {}
|
|
138
|
+
currentDir = path.dirname(currentDir);
|
|
139
|
+
isAtFsRoot = currentDir.length <= path.dirname(currentDir).length;
|
|
140
|
+
}
|
|
141
|
+
throw new Error(`Cannot find the root folder of the ${MODULE_NAME} Node.js module`);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
export {
|
|
145
|
+
qualifyActivityName, copyGradleProjectRecursively, requireOptions,
|
|
146
|
+
updateDependencyLines, getPackageInfo, getPackageInfoSync
|
|
147
|
+
};
|