appium-mac2-driver 0.12.0 → 0.13.0
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/WebDriverAgentMac/WebDriverAgentLib/Routing/FBWebServer.m +7 -3
- package/WebDriverAgentMac/WebDriverAgentMac.xcodeproj/project.xcworkspace/xcuserdata/elf.xcuserdatad/UserInterfaceState.xcuserstate +0 -0
- package/WebDriverAgentMac/WebDriverAgentRunner/WebDriverAgentRunner.m +8 -0
- package/build/lib/wda-mac.js +26 -4
- package/lib/wda-mac.js +27 -5
- package/package.json +3 -2
|
@@ -190,9 +190,13 @@ static NSString *const FBServerURLEndMarker = @"<-ServerURLHere";
|
|
|
190
190
|
[response respondWithString:@"I-AM-ALIVE"];
|
|
191
191
|
}];
|
|
192
192
|
|
|
193
|
-
[self.server
|
|
194
|
-
|
|
195
|
-
|
|
193
|
+
[self.server delete:@"/" withBlock:^(RouteRequest *request, RouteResponse *response) {
|
|
194
|
+
@try {
|
|
195
|
+
[FBSession.activeSession kill];
|
|
196
|
+
} @finally {
|
|
197
|
+
[response respondWithString:@"Shutting down"];
|
|
198
|
+
[self.delegate webServerDidRequestShutdown:self];
|
|
199
|
+
}
|
|
196
200
|
}];
|
|
197
201
|
|
|
198
202
|
[self registerRouteHandlers:@[FBUnknownCommands.class]];
|
|
Binary file
|
|
@@ -30,6 +30,14 @@
|
|
|
30
30
|
[super setUp];
|
|
31
31
|
}
|
|
32
32
|
|
|
33
|
+
- (void)setUp
|
|
34
|
+
{
|
|
35
|
+
[super setUp];
|
|
36
|
+
self.continueAfterFailure = YES;
|
|
37
|
+
[self setValue:@(NO) forKey:@"_shouldSetShouldHaltWhenReceivesControl"];
|
|
38
|
+
[self setValue:@(NO) forKey:@"_shouldHaltWhenReceivesControl"];
|
|
39
|
+
}
|
|
40
|
+
|
|
33
41
|
/**
|
|
34
42
|
Never ending test used to start WebDriverAgent
|
|
35
43
|
*/
|
package/build/lib/wda-mac.js
CHANGED
|
@@ -15,6 +15,10 @@ var _path = _interopRequireDefault(require("path"));
|
|
|
15
15
|
|
|
16
16
|
var _url = _interopRequireDefault(require("url"));
|
|
17
17
|
|
|
18
|
+
var _axios = _interopRequireDefault(require("axios"));
|
|
19
|
+
|
|
20
|
+
var _bluebird = _interopRequireDefault(require("bluebird"));
|
|
21
|
+
|
|
18
22
|
var _appiumBaseDriver = require("appium-base-driver");
|
|
19
23
|
|
|
20
24
|
var _appiumSupport = require("appium-support");
|
|
@@ -239,10 +243,28 @@ class WDAMacProcess {
|
|
|
239
243
|
|
|
240
244
|
log.debug(`Using ${this.host} as server host`);
|
|
241
245
|
log.debug(`Using port ${this.port}`);
|
|
242
|
-
const isPortBusy = (await (0, _portscanner.checkPortStatus)(this.port, this.host)) === 'open';
|
|
243
246
|
|
|
244
|
-
|
|
245
|
-
|
|
247
|
+
const isPortBusy = async () => (await (0, _portscanner.checkPortStatus)(this.port, this.host)) === 'open';
|
|
248
|
+
|
|
249
|
+
if (await isPortBusy()) {
|
|
250
|
+
log.warn(`The port #${this.port} at ${this.host} is busy. ` + `Assuming it is an obsolete WDA server instance and ` + `trying to terminate it in order to start a new one`);
|
|
251
|
+
const timer = new _appiumSupport.timing.Timer().start();
|
|
252
|
+
|
|
253
|
+
try {
|
|
254
|
+
await _axios.default.delete(`http://${this.host}:${this.port}/`, {
|
|
255
|
+
timeout: 5000
|
|
256
|
+
});
|
|
257
|
+
await _bluebird.default.delay(500);
|
|
258
|
+
await (0, _asyncbox.waitForCondition)(async () => !(await isPortBusy()), {
|
|
259
|
+
waitMs: 3000,
|
|
260
|
+
intervalMs: 100
|
|
261
|
+
});
|
|
262
|
+
} catch (e) {
|
|
263
|
+
log.warn(`Did not know how to terminate the process at ${this.host}:${this.port}: ${e.message}. ` + `Perhaps, it is not a WDA server, which is hogging the port?`);
|
|
264
|
+
throw new Error(`The port #${this.port} at ${this.host} is busy. ` + `Consider setting 'systemPort' capability to another free port number and/or ` + `make sure previous driver sessions have been closed properly.`);
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
log.info(`The previously running WDA server has been successfully terminated after ` + `${Math.round(timer.getDuration().asMilliSeconds)}ms`);
|
|
246
268
|
}
|
|
247
269
|
|
|
248
270
|
const args = ['build-for-testing', 'test-without-building', '-project', WDA_PROJECT(this.bootstrapRoot), '-scheme', RUNNER_SCHEME, DISABLE_STORE_ARG];
|
|
@@ -490,4 +512,4 @@ var _default = WDA_MAC_SERVER;
|
|
|
490
512
|
exports.default = _default;require('source-map-support').install();
|
|
491
513
|
|
|
492
514
|
|
|
493
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/wda-mac.js"],"names":["log","logger","getLogger","ROOT_DIR","path","basename","__dirname","resolve","process","env","NO_PRECOMPILE","DEFAULT_WDA_ROOT","WDA_PROJECT_NAME","WDA_PROJECT","wdaRoot","RUNNER_SCHEME","DISABLE_STORE_ARG","XCODEBUILD","STARTUP_TIMEOUT_MS","DEFAULT_SYSTEM_PORT","DEFAULT_SYSTEM_HOST","DEFAULT_SHOW_SERVER_LOGS","RUNNING_PROCESS_IDS","RECENT_UPGRADE_TIMESTAMP_PATH","join","getUpgradeTimestamp","packageManifest","fs","exists","mtime","stat","getTime","cleanupObsoleteProcesses","_","isEmpty","debug","length","util","pluralize","ign","pullAll","once","WDAMacProxy","JWProxy","proxyCommand","url","method","body","didProcessExit","errors","InvalidContextError","WDAMacProcess","constructor","showServerLogs","port","host","bootstrapRoot","proc","isRunning","pid","listChildrenPids","isFreshUpgrade","homeFolder","HOME","info","currentUpgradeTimestamp","isInteger","timestampPath","access","W_OK","recentUpgradeTimestamp","parseInt","readFile","warn","dirname","writeFile","e","message","hasSameOpts","systemPort","systemHost","isBoolean","isNil","init","opts","Error","kill","xcodebuild","which","args","cwd","stderr","isPortBusy","Object","assign","USE_PORT","USE_HOST","SubProcess","on","stdout","line","trim","code","signal","quote","start","stop","childrenPids","WDAMacServer","serverStartupTimeoutMs","proxy","isProxyingToRemoteServer","isProxyReady","throwOnExit","command","err","parseProxyProperties","caps","scheme","webDriverAgentMacUrl","server","parsedUrl","URL","protocol","hostname","pathname","isString","split","startSession","serverStartupTimeout","wasProcessInitNecessary","base","keepAlive","timer","timing","Timer","waitMs","intervalMs","test","msg","push","pull","getDuration","asMilliSeconds","toFixed","capabilities","firstMatch","alwaysMatch","stopSession","sessionId","WDA_MAC_SERVER"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport path from 'path';\nimport url from 'url';\nimport { JWProxy, errors } from 'appium-base-driver';\nimport { fs, logger, util, timing, mkdirp } from 'appium-support';\nimport { SubProcess, exec } from 'teen_process';\nimport { waitForCondition } from 'asyncbox';\nimport { checkPortStatus } from 'portscanner';\nimport { execSync } from 'child_process';\nimport { listChildrenProcessIds } from './utils';\n\nconst log = logger.getLogger('WebDriverAgentMac');\n\nconst ROOT_DIR = path.basename(__dirname) === 'lib'\n  ? path.resolve(__dirname, process.env.NO_PRECOMPILE ? '..' : '../..')\n  : __dirname;\nconst DEFAULT_WDA_ROOT = path.resolve(ROOT_DIR, 'WebDriverAgentMac');\nconst WDA_PROJECT_NAME = 'WebDriverAgentMac.xcodeproj';\nconst WDA_PROJECT = (wdaRoot = DEFAULT_WDA_ROOT) => path.resolve(wdaRoot, WDA_PROJECT_NAME);\nconst RUNNER_SCHEME = 'WebDriverAgentRunner';\nconst DISABLE_STORE_ARG = 'COMPILER_INDEX_STORE_ENABLE=NO';\nconst XCODEBUILD = 'xcodebuild';\nconst STARTUP_TIMEOUT_MS = 120000;\nconst DEFAULT_SYSTEM_PORT = 10100;\nconst DEFAULT_SYSTEM_HOST = '127.0.0.1';\nconst DEFAULT_SHOW_SERVER_LOGS = false;\nconst RUNNING_PROCESS_IDS = [];\nconst RECENT_UPGRADE_TIMESTAMP_PATH = path.join('.appium',\n  'webdriveragent_mac', 'upgrade.time');\n\n\nasync function getUpgradeTimestamp () {\n  const packageManifest = path.resolve(ROOT_DIR, 'package.json');\n  if (!await fs.exists(packageManifest)) {\n    return null;\n  }\n  const {mtime} = await fs.stat(packageManifest);\n  return mtime.getTime();\n}\n\nasync function cleanupObsoleteProcesses () {\n  if (!_.isEmpty(RUNNING_PROCESS_IDS)) {\n    log.debug(`Cleaning up ${RUNNING_PROCESS_IDS.length} obsolete ` +\n      util.pluralize('process', RUNNING_PROCESS_IDS.length, false));\n    try {\n      await exec('kill', ['-9', ...RUNNING_PROCESS_IDS]);\n    } catch (ign) {}\n    _.pullAll(RUNNING_PROCESS_IDS, RUNNING_PROCESS_IDS);\n  }\n}\n\nprocess.once('exit', () => {\n  if (!_.isEmpty(RUNNING_PROCESS_IDS)) {\n    try {\n      execSync(`kill -9 ${RUNNING_PROCESS_IDS.join(' ')}`);\n    } catch (ign) {}\n    _.pullAll(RUNNING_PROCESS_IDS, RUNNING_PROCESS_IDS);\n  }\n});\n\n\nclass WDAMacProxy extends JWProxy {\n  async proxyCommand (url, method, body = null) {\n    if (this.didProcessExit) {\n      throw new errors.InvalidContextError(\n        `'${method} ${url}' cannot be proxied to Mac2 Driver server because ` +\n        'its process is not running (probably crashed). Check the Appium log for more details');\n    }\n    return await super.proxyCommand(url, method, body);\n  }\n}\n\nclass WDAMacProcess {\n  constructor () {\n    this.showServerLogs = DEFAULT_SHOW_SERVER_LOGS;\n    this.port = DEFAULT_SYSTEM_PORT;\n    this.host = DEFAULT_SYSTEM_HOST;\n    this.bootstrapRoot = DEFAULT_WDA_ROOT;\n    this.proc = null;\n  }\n\n  get isRunning () {\n    return !!(this.proc?.isRunning);\n  }\n\n  get pid () {\n    return this.isRunning ? this.proc.pid : null;\n  }\n\n  async listChildrenPids () {\n    return this.pid ? (await listChildrenProcessIds(this.pid)) : [];\n  }\n\n  async isFreshUpgrade () {\n    const homeFolder = process.env.HOME;\n    if (!homeFolder) {\n      log.info('The HOME folder path cannot be determined');\n      return false;\n    }\n\n    const currentUpgradeTimestamp = await getUpgradeTimestamp();\n    if (!_.isInteger(currentUpgradeTimestamp)) {\n      log.info('It is impossible to determine the timestamp of the package');\n      return false;\n    }\n\n    const timestampPath = path.resolve(homeFolder, RECENT_UPGRADE_TIMESTAMP_PATH);\n    if (await fs.exists(timestampPath)) {\n      try {\n        await fs.access(timestampPath, fs.W_OK);\n      } catch (ign) {\n        log.info(`WebDriverAgent upgrade timestamp at '${timestampPath}' is not writeable`);\n        return false;\n      }\n      const recentUpgradeTimestamp = parseInt(await fs.readFile(timestampPath, 'utf8'), 10);\n      if (_.isInteger(recentUpgradeTimestamp)) {\n        if (recentUpgradeTimestamp >= currentUpgradeTimestamp) {\n          log.info(`WebDriverAgent sources are up to date ` +\n            `(${recentUpgradeTimestamp} >= ${currentUpgradeTimestamp})`);\n          return false;\n        }\n        log.info(`WebDriverAgent sources have been upgraded ` +\n          `(${recentUpgradeTimestamp} < ${currentUpgradeTimestamp})`);\n      } else {\n        log.warn(`The recent upgrade timestamp at '${timestampPath}' is corrupted. Trying to fix it`);\n      }\n    }\n\n    try {\n      await mkdirp(path.dirname(timestampPath));\n      await fs.writeFile(timestampPath, `${currentUpgradeTimestamp}`, 'utf8');\n      log.debug(`Stored the recent WebDriverAgent upgrade timestamp ${currentUpgradeTimestamp} ` +\n        `at '${timestampPath}'`);\n    } catch (e) {\n      log.info(`Unable to create the recent WebDriverAgent upgrade timestamp at '${timestampPath}'. ` +\n        `Original error: ${e.message}`);\n      return false;\n    }\n\n    return true;\n  }\n\n  hasSameOpts ({ showServerLogs, systemPort, systemHost, bootstrapRoot }) {\n    if (_.isBoolean(showServerLogs) && this.showServerLogs !== showServerLogs\n      || _.isNil(showServerLogs) && this.showServerLogs !== DEFAULT_SHOW_SERVER_LOGS) {\n      return false;\n    }\n    if (systemPort && this.port !== systemPort\n      || !systemPort && this.port !== DEFAULT_SYSTEM_PORT) {\n      return false;\n    }\n    if (systemHost && this.host !== systemHost\n      || !systemHost && this.host !== DEFAULT_SYSTEM_HOST) {\n      return false;\n    }\n    if (bootstrapRoot && this.bootstrapRoot !== bootstrapRoot\n      || !bootstrapRoot && this.bootstrapRoot !== DEFAULT_WDA_ROOT) {\n      return false;\n    }\n\n    return true;\n  }\n\n  async init (opts = {}) {\n    if (this.isRunning && this.hasSameOpts(opts)) {\n      return false;\n    }\n\n    this.showServerLogs = opts.showServerLogs ?? this.showServerLogs;\n    this.port = opts.systemPort ?? this.port;\n    this.host = opts.systemHost ?? this.host;\n    this.bootstrapRoot = opts.bootstrapRoot ?? this.bootstrapRoot;\n\n    log.debug(`Using bootstrap root: ${this.bootstrapRoot}`);\n    if (!await fs.exists(WDA_PROJECT(this.bootstrapRoot))) {\n      throw new Error(`${WDA_PROJECT_NAME} does not exist at '${WDA_PROJECT(this.bootstrapRoot)}'. ` +\n        `Was 'bootstrapRoot' set to a proper value?`);\n    }\n\n    await this.kill();\n    await cleanupObsoleteProcesses();\n\n    let xcodebuild;\n    try {\n      xcodebuild = await fs.which(XCODEBUILD);\n    } catch (e) {\n      throw new Error(`${XCODEBUILD} binary cannot be found in PATH. ` +\n        `Please make sure that Xcode is installed on your system`);\n    }\n    log.debug(`Using ${XCODEBUILD} binary at '${xcodebuild}'`);\n\n    if (await this.isFreshUpgrade()) {\n      log.info('Performing project cleanup');\n      const args = [\n        'clean',\n        '-project', WDA_PROJECT(this.bootstrapRoot),\n        '-scheme', RUNNER_SCHEME,\n      ];\n      try {\n        await exec(XCODEBUILD, args, {\n          cwd: this.bootstrapRoot,\n        });\n      } catch (e) {\n        log.warn(`Cannot perform project cleanup. ` +\n          `Original error: ${e.stderr || e.message}`);\n      }\n    }\n\n    log.debug(`Using ${this.host} as server host`);\n    log.debug(`Using port ${this.port}`);\n    const isPortBusy = (await checkPortStatus(this.port, this.host)) === 'open';\n    if (isPortBusy) {\n      throw new Error(`The port #${this.port} at ${this.host} is busy. ` +\n        `Consider setting 'systemPort' capability to another free port number and/or ` +\n        `make sure the previous driver session(s) have been closed properly.`);\n    }\n\n    const args = [\n      'build-for-testing', 'test-without-building',\n      '-project', WDA_PROJECT(this.bootstrapRoot),\n      '-scheme', RUNNER_SCHEME,\n      DISABLE_STORE_ARG,\n    ];\n    const env = Object.assign({}, process.env, {\n      USE_PORT: `${this.port}`,\n      USE_HOST: this.host,\n    });\n    this.proc = new SubProcess(xcodebuild, args, {\n      cwd: this.bootstrapRoot,\n      env,\n    });\n    if (!this.showServerLogs) {\n      log.info(`Mac2Driver host process logging is disabled. ` +\n        `All the ${XCODEBUILD} output is going to be suppressed. ` +\n        `Set the 'showServerLogs' capability to 'true' if this is an undesired behavior`);\n    }\n    this.proc.on('output', (stdout, stderr) => {\n      if (!this.showServerLogs) {\n        return;\n      }\n\n      const line = _.trim(stdout || stderr);\n      if (line) {\n        log.debug(`[${XCODEBUILD}] ${line}`);\n      }\n    });\n    this.proc.on('exit', (code, signal) => {\n      log.info(`Mac2Driver host process has exited with code ${code}, signal ${signal}`);\n    });\n    log.info(`Starting Mac2Driver host process: ${XCODEBUILD} ${util.quote(args)}`);\n    await this.proc.start(0);\n    return true;\n  }\n\n  async stop () {\n    if (!this.isRunning) {\n      return;\n    }\n\n    const childrenPids = await this.listChildrenPids();\n    if (!_.isEmpty(childrenPids)) {\n      try {\n        await exec('kill', childrenPids);\n      } catch (ign) {}\n    }\n    await this.proc.stop('SIGTERM', 3000);\n  }\n\n  async kill () {\n    if (!this.isRunning) {\n      return;\n    }\n\n    const childrenPids = await this.listChildrenPids();\n    if (!_.isEmpty(childrenPids)) {\n      try {\n        await exec('kill', ['-9', ...childrenPids]);\n      } catch (ign) {}\n    }\n    try {\n      await this.proc.stop('SIGKILL');\n    } catch (ign) {}\n  }\n}\n\nclass WDAMacServer {\n  constructor () {\n    this.process = null;\n    this.serverStartupTimeoutMs = STARTUP_TIMEOUT_MS;\n    this.proxy = null;\n\n    // To handle if the WDAMac server is proxying requests to a remote WDAMac app instance\n    this.isProxyingToRemoteServer = false;\n  }\n\n  async isProxyReady (throwOnExit = true) {\n    if (!this.proxy) {\n      return false;\n    }\n\n    try {\n      await this.proxy.command('/status', 'GET');\n      return true;\n    } catch (err) {\n      if (throwOnExit && this.proxy.didProcessExit) {\n        throw new Error(err.message);\n      }\n      return false;\n    }\n  }\n\n\n  /**\n   * @typedef {Object} ProxyProperties\n   *\n   * @property {string} scheme - The scheme proxy to.\n   * @property {string} host - The host name proxy to.\n   * @property {number} port - The port number proxy to.\n   * @property {string} path - The path proxy to.\n   */\n\n  /**\n   * Returns proxy information where WDAMacServer proxy to.\n   *\n   * @param {Object} caps - The capabilities in the session.\n   * @return {ProxyProperties}\n   * @throws Error if 'webDriverAgentMacUrl' had invalid URL\n   */\n  parseProxyProperties (caps) {\n    let scheme = 'http';\n    if (!caps.webDriverAgentMacUrl) {\n      return {\n        scheme,\n        server: (this.process?.host ?? caps.systemHost) ?? DEFAULT_SYSTEM_HOST,\n        port: (this.process?.port ?? caps.systemPort) ?? DEFAULT_SYSTEM_PORT,\n        path: ''\n      };\n    }\n\n    let parsedUrl;\n    try {\n      parsedUrl = new url.URL(caps.webDriverAgentMacUrl);\n    } catch (e) {\n      throw new Error(`webDriverAgentMacUrl, '${caps.webDriverAgentMacUrl}', ` +\n        `in the capabilities is invalid. ${e.message}`);\n    }\n\n    const { protocol, hostname, port, pathname } = parsedUrl;\n    if (_.isString(protocol)) {\n      scheme = protocol.split(':')[0];\n    }\n    return {\n      scheme,\n      server: hostname ?? DEFAULT_SYSTEM_HOST,\n      port: _.isEmpty(port) ? DEFAULT_SYSTEM_PORT : _.parseInt(port),\n      path: pathname === '/' ? '' : pathname\n    };\n  }\n\n  async startSession (caps) {\n    this.serverStartupTimeoutMs = caps.serverStartupTimeout ?? this.serverStartupTimeoutMs;\n\n    this.isProxyingToRemoteServer = !!caps.webDriverAgentMacUrl;\n\n    let wasProcessInitNecessary;\n    if (this.isProxyingToRemoteServer) {\n      if (this.process) {\n        await this.process.kill();\n        await cleanupObsoleteProcesses();\n        this.process = null;\n      }\n\n      wasProcessInitNecessary = false;\n    } else {\n      if (!this.process) {\n        this.process = new WDAMacProcess();\n      }\n      wasProcessInitNecessary = await this.process.init(caps);\n    }\n\n    if (wasProcessInitNecessary || this.isProxyingToRemoteServer || !this.proxy) {\n      const {scheme, server, port, path} = this.parseProxyProperties(caps);\n      this.proxy = new WDAMacProxy({\n        scheme,\n        server,\n        port,\n        base: path,\n        keepAlive: true,\n      });\n      this.proxy.didProcessExit = false;\n\n      if (this.process) {\n        this.process.proc.on('exit', () => {\n          this.proxy.didProcessExit = true;\n        });\n      }\n\n      const timer = new timing.Timer().start();\n      try {\n        await waitForCondition(async () => await this.isProxyReady(), {\n          waitMs: this.serverStartupTimeoutMs,\n          intervalMs: 1000,\n        });\n      } catch (e) {\n        if (this.process?.isRunning) {\n          // avoid \"frozen\" processes,\n          await this.process.kill();\n        }\n        if (/Condition unmet/.test(e.message)) {\n          const msg = this.isProxyingToRemoteServer\n            ? `No response from '${scheme}://${server}:${port}${path}' within ${this.serverStartupTimeoutMs}ms timeout.` +\n            `Please make sure the remote server is running and accessible by Appium`\n            : `Mac2Driver server is not listening within ${this.serverStartupTimeoutMs}ms timeout. ` +\n            `Try to increase the value of 'serverStartupTimeout' capability, check the server logs ` +\n            `and make sure the ${XCODEBUILD} host process could be started manually from a terminal`;\n          throw new Error(msg);\n        }\n        throw e;\n      }\n\n      if (this.process) {\n        const pid = this.process.pid;\n        const childrenPids = await this.process.listChildrenPids();\n        RUNNING_PROCESS_IDS.push(...childrenPids, pid);\n        this.process.proc.on('exit', () => void _.pull(RUNNING_PROCESS_IDS, pid));\n        log.info(`The host process is ready within ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n      }\n    } else {\n      log.info('The host process has already been listening. Proceeding with session creation');\n    }\n\n    await this.proxy.command('/session', 'POST', {\n      capabilities: {\n        firstMatch: [{}],\n        alwaysMatch: caps,\n      }\n    });\n  }\n\n  async stopSession () {\n    if (!this.isProxyingToRemoteServer && !(this.process?.isRunning)) {\n      log.info(`Mac2Driver session cannot be stopped, because the server is not running`);\n      return;\n    }\n\n    if (this.proxy?.sessionId) {\n      try {\n        await this.proxy.command(`/session/${this.proxy.sessionId}`, 'DELETE');\n      } catch (e) {\n        log.info(`Mac2Driver session cannot be deleted. Original error: ${e.message}`);\n      }\n    }\n  }\n}\n\nconst WDA_MAC_SERVER = new WDAMacServer();\n\nexport default WDA_MAC_SERVER;\n"],"file":"lib/wda-mac.js","sourceRoot":"../.."}
|
|
515
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/wda-mac.js"],"names":["log","logger","getLogger","ROOT_DIR","path","basename","__dirname","resolve","process","env","NO_PRECOMPILE","DEFAULT_WDA_ROOT","WDA_PROJECT_NAME","WDA_PROJECT","wdaRoot","RUNNER_SCHEME","DISABLE_STORE_ARG","XCODEBUILD","STARTUP_TIMEOUT_MS","DEFAULT_SYSTEM_PORT","DEFAULT_SYSTEM_HOST","DEFAULT_SHOW_SERVER_LOGS","RUNNING_PROCESS_IDS","RECENT_UPGRADE_TIMESTAMP_PATH","join","getUpgradeTimestamp","packageManifest","fs","exists","mtime","stat","getTime","cleanupObsoleteProcesses","_","isEmpty","debug","length","util","pluralize","ign","pullAll","once","WDAMacProxy","JWProxy","proxyCommand","url","method","body","didProcessExit","errors","InvalidContextError","WDAMacProcess","constructor","showServerLogs","port","host","bootstrapRoot","proc","isRunning","pid","listChildrenPids","isFreshUpgrade","homeFolder","HOME","info","currentUpgradeTimestamp","isInteger","timestampPath","access","W_OK","recentUpgradeTimestamp","parseInt","readFile","warn","dirname","writeFile","e","message","hasSameOpts","systemPort","systemHost","isBoolean","isNil","init","opts","Error","kill","xcodebuild","which","args","cwd","stderr","isPortBusy","timer","timing","Timer","start","axios","delete","timeout","B","delay","waitMs","intervalMs","Math","round","getDuration","asMilliSeconds","Object","assign","USE_PORT","USE_HOST","SubProcess","on","stdout","line","trim","code","signal","quote","stop","childrenPids","WDAMacServer","serverStartupTimeoutMs","proxy","isProxyingToRemoteServer","isProxyReady","throwOnExit","command","err","parseProxyProperties","caps","scheme","webDriverAgentMacUrl","server","parsedUrl","URL","protocol","hostname","pathname","isString","split","startSession","serverStartupTimeout","wasProcessInitNecessary","base","keepAlive","test","msg","push","pull","toFixed","capabilities","firstMatch","alwaysMatch","stopSession","sessionId","WDA_MAC_SERVER"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport path from 'path';\nimport url from 'url';\nimport axios from 'axios';\nimport B from 'bluebird';\nimport { JWProxy, errors } from 'appium-base-driver';\nimport { fs, logger, util, timing, mkdirp } from 'appium-support';\nimport { SubProcess, exec } from 'teen_process';\nimport { waitForCondition } from 'asyncbox';\nimport { checkPortStatus } from 'portscanner';\nimport { execSync } from 'child_process';\nimport { listChildrenProcessIds } from './utils';\n\nconst log = logger.getLogger('WebDriverAgentMac');\n\nconst ROOT_DIR = path.basename(__dirname) === 'lib'\n  ? path.resolve(__dirname, process.env.NO_PRECOMPILE ? '..' : '../..')\n  : __dirname;\nconst DEFAULT_WDA_ROOT = path.resolve(ROOT_DIR, 'WebDriverAgentMac');\nconst WDA_PROJECT_NAME = 'WebDriverAgentMac.xcodeproj';\nconst WDA_PROJECT = (wdaRoot = DEFAULT_WDA_ROOT) => path.resolve(wdaRoot, WDA_PROJECT_NAME);\nconst RUNNER_SCHEME = 'WebDriverAgentRunner';\nconst DISABLE_STORE_ARG = 'COMPILER_INDEX_STORE_ENABLE=NO';\nconst XCODEBUILD = 'xcodebuild';\nconst STARTUP_TIMEOUT_MS = 120000;\nconst DEFAULT_SYSTEM_PORT = 10100;\nconst DEFAULT_SYSTEM_HOST = '127.0.0.1';\nconst DEFAULT_SHOW_SERVER_LOGS = false;\nconst RUNNING_PROCESS_IDS = [];\nconst RECENT_UPGRADE_TIMESTAMP_PATH = path.join('.appium',\n  'webdriveragent_mac', 'upgrade.time');\n\n\nasync function getUpgradeTimestamp () {\n  const packageManifest = path.resolve(ROOT_DIR, 'package.json');\n  if (!await fs.exists(packageManifest)) {\n    return null;\n  }\n  const {mtime} = await fs.stat(packageManifest);\n  return mtime.getTime();\n}\n\nasync function cleanupObsoleteProcesses () {\n  if (!_.isEmpty(RUNNING_PROCESS_IDS)) {\n    log.debug(`Cleaning up ${RUNNING_PROCESS_IDS.length} obsolete ` +\n      util.pluralize('process', RUNNING_PROCESS_IDS.length, false));\n    try {\n      await exec('kill', ['-9', ...RUNNING_PROCESS_IDS]);\n    } catch (ign) {}\n    _.pullAll(RUNNING_PROCESS_IDS, RUNNING_PROCESS_IDS);\n  }\n}\n\nprocess.once('exit', () => {\n  if (!_.isEmpty(RUNNING_PROCESS_IDS)) {\n    try {\n      execSync(`kill -9 ${RUNNING_PROCESS_IDS.join(' ')}`);\n    } catch (ign) {}\n    _.pullAll(RUNNING_PROCESS_IDS, RUNNING_PROCESS_IDS);\n  }\n});\n\n\nclass WDAMacProxy extends JWProxy {\n  async proxyCommand (url, method, body = null) {\n    if (this.didProcessExit) {\n      throw new errors.InvalidContextError(\n        `'${method} ${url}' cannot be proxied to Mac2 Driver server because ` +\n        'its process is not running (probably crashed). Check the Appium log for more details');\n    }\n    return await super.proxyCommand(url, method, body);\n  }\n}\n\nclass WDAMacProcess {\n  constructor () {\n    this.showServerLogs = DEFAULT_SHOW_SERVER_LOGS;\n    this.port = DEFAULT_SYSTEM_PORT;\n    this.host = DEFAULT_SYSTEM_HOST;\n    this.bootstrapRoot = DEFAULT_WDA_ROOT;\n    this.proc = null;\n  }\n\n  get isRunning () {\n    return !!(this.proc?.isRunning);\n  }\n\n  get pid () {\n    return this.isRunning ? this.proc.pid : null;\n  }\n\n  async listChildrenPids () {\n    return this.pid ? (await listChildrenProcessIds(this.pid)) : [];\n  }\n\n  async isFreshUpgrade () {\n    const homeFolder = process.env.HOME;\n    if (!homeFolder) {\n      log.info('The HOME folder path cannot be determined');\n      return false;\n    }\n\n    const currentUpgradeTimestamp = await getUpgradeTimestamp();\n    if (!_.isInteger(currentUpgradeTimestamp)) {\n      log.info('It is impossible to determine the timestamp of the package');\n      return false;\n    }\n\n    const timestampPath = path.resolve(homeFolder, RECENT_UPGRADE_TIMESTAMP_PATH);\n    if (await fs.exists(timestampPath)) {\n      try {\n        await fs.access(timestampPath, fs.W_OK);\n      } catch (ign) {\n        log.info(`WebDriverAgent upgrade timestamp at '${timestampPath}' is not writeable`);\n        return false;\n      }\n      const recentUpgradeTimestamp = parseInt(await fs.readFile(timestampPath, 'utf8'), 10);\n      if (_.isInteger(recentUpgradeTimestamp)) {\n        if (recentUpgradeTimestamp >= currentUpgradeTimestamp) {\n          log.info(`WebDriverAgent sources are up to date ` +\n            `(${recentUpgradeTimestamp} >= ${currentUpgradeTimestamp})`);\n          return false;\n        }\n        log.info(`WebDriverAgent sources have been upgraded ` +\n          `(${recentUpgradeTimestamp} < ${currentUpgradeTimestamp})`);\n      } else {\n        log.warn(`The recent upgrade timestamp at '${timestampPath}' is corrupted. Trying to fix it`);\n      }\n    }\n\n    try {\n      await mkdirp(path.dirname(timestampPath));\n      await fs.writeFile(timestampPath, `${currentUpgradeTimestamp}`, 'utf8');\n      log.debug(`Stored the recent WebDriverAgent upgrade timestamp ${currentUpgradeTimestamp} ` +\n        `at '${timestampPath}'`);\n    } catch (e) {\n      log.info(`Unable to create the recent WebDriverAgent upgrade timestamp at '${timestampPath}'. ` +\n        `Original error: ${e.message}`);\n      return false;\n    }\n\n    return true;\n  }\n\n  hasSameOpts ({ showServerLogs, systemPort, systemHost, bootstrapRoot }) {\n    if (_.isBoolean(showServerLogs) && this.showServerLogs !== showServerLogs\n      || _.isNil(showServerLogs) && this.showServerLogs !== DEFAULT_SHOW_SERVER_LOGS) {\n      return false;\n    }\n    if (systemPort && this.port !== systemPort\n      || !systemPort && this.port !== DEFAULT_SYSTEM_PORT) {\n      return false;\n    }\n    if (systemHost && this.host !== systemHost\n      || !systemHost && this.host !== DEFAULT_SYSTEM_HOST) {\n      return false;\n    }\n    if (bootstrapRoot && this.bootstrapRoot !== bootstrapRoot\n      || !bootstrapRoot && this.bootstrapRoot !== DEFAULT_WDA_ROOT) {\n      return false;\n    }\n\n    return true;\n  }\n\n  async init (opts = {}) {\n    if (this.isRunning && this.hasSameOpts(opts)) {\n      return false;\n    }\n\n    this.showServerLogs = opts.showServerLogs ?? this.showServerLogs;\n    this.port = opts.systemPort ?? this.port;\n    this.host = opts.systemHost ?? this.host;\n    this.bootstrapRoot = opts.bootstrapRoot ?? this.bootstrapRoot;\n\n    log.debug(`Using bootstrap root: ${this.bootstrapRoot}`);\n    if (!await fs.exists(WDA_PROJECT(this.bootstrapRoot))) {\n      throw new Error(`${WDA_PROJECT_NAME} does not exist at '${WDA_PROJECT(this.bootstrapRoot)}'. ` +\n        `Was 'bootstrapRoot' set to a proper value?`);\n    }\n\n    await this.kill();\n    await cleanupObsoleteProcesses();\n\n    let xcodebuild;\n    try {\n      xcodebuild = await fs.which(XCODEBUILD);\n    } catch (e) {\n      throw new Error(`${XCODEBUILD} binary cannot be found in PATH. ` +\n        `Please make sure that Xcode is installed on your system`);\n    }\n    log.debug(`Using ${XCODEBUILD} binary at '${xcodebuild}'`);\n\n    if (await this.isFreshUpgrade()) {\n      log.info('Performing project cleanup');\n      const args = [\n        'clean',\n        '-project', WDA_PROJECT(this.bootstrapRoot),\n        '-scheme', RUNNER_SCHEME,\n      ];\n      try {\n        await exec(XCODEBUILD, args, {\n          cwd: this.bootstrapRoot,\n        });\n      } catch (e) {\n        log.warn(`Cannot perform project cleanup. ` +\n          `Original error: ${e.stderr || e.message}`);\n      }\n    }\n\n    log.debug(`Using ${this.host} as server host`);\n    log.debug(`Using port ${this.port}`);\n    const isPortBusy = async () => (await checkPortStatus(this.port, this.host)) === 'open';\n    if (await isPortBusy()) {\n      log.warn(`The port #${this.port} at ${this.host} is busy. ` +\n        `Assuming it is an obsolete WDA server instance and ` +\n        `trying to terminate it in order to start a new one`);\n      const timer = new timing.Timer().start();\n      try {\n        await axios.delete(`http://${this.host}:${this.port}/`, {\n          timeout: 5000,\n        });\n        // Give the server some time to finish and stop listening\n        await B.delay(500);\n        await waitForCondition(async () => !(await isPortBusy()), {\n          waitMs: 3000,\n          intervalMs: 100,\n        });\n      } catch (e) {\n        log.warn(`Did not know how to terminate the process at ${this.host}:${this.port}: ${e.message}. ` +\n          `Perhaps, it is not a WDA server, which is hogging the port?`);\n        throw new Error(`The port #${this.port} at ${this.host} is busy. ` +\n          `Consider setting 'systemPort' capability to another free port number and/or ` +\n          `make sure previous driver sessions have been closed properly.`);\n      }\n      log.info(`The previously running WDA server has been successfully terminated after ` +\n        `${Math.round(timer.getDuration().asMilliSeconds)}ms`);\n    }\n\n    const args = [\n      'build-for-testing', 'test-without-building',\n      '-project', WDA_PROJECT(this.bootstrapRoot),\n      '-scheme', RUNNER_SCHEME,\n      DISABLE_STORE_ARG,\n    ];\n    const env = Object.assign({}, process.env, {\n      USE_PORT: `${this.port}`,\n      USE_HOST: this.host,\n    });\n    this.proc = new SubProcess(xcodebuild, args, {\n      cwd: this.bootstrapRoot,\n      env,\n    });\n    if (!this.showServerLogs) {\n      log.info(`Mac2Driver host process logging is disabled. ` +\n        `All the ${XCODEBUILD} output is going to be suppressed. ` +\n        `Set the 'showServerLogs' capability to 'true' if this is an undesired behavior`);\n    }\n    this.proc.on('output', (stdout, stderr) => {\n      if (!this.showServerLogs) {\n        return;\n      }\n\n      const line = _.trim(stdout || stderr);\n      if (line) {\n        log.debug(`[${XCODEBUILD}] ${line}`);\n      }\n    });\n    this.proc.on('exit', (code, signal) => {\n      log.info(`Mac2Driver host process has exited with code ${code}, signal ${signal}`);\n    });\n    log.info(`Starting Mac2Driver host process: ${XCODEBUILD} ${util.quote(args)}`);\n    await this.proc.start(0);\n    return true;\n  }\n\n  async stop () {\n    if (!this.isRunning) {\n      return;\n    }\n\n    const childrenPids = await this.listChildrenPids();\n    if (!_.isEmpty(childrenPids)) {\n      try {\n        await exec('kill', childrenPids);\n      } catch (ign) {}\n    }\n    await this.proc.stop('SIGTERM', 3000);\n  }\n\n  async kill () {\n    if (!this.isRunning) {\n      return;\n    }\n\n    const childrenPids = await this.listChildrenPids();\n    if (!_.isEmpty(childrenPids)) {\n      try {\n        await exec('kill', ['-9', ...childrenPids]);\n      } catch (ign) {}\n    }\n    try {\n      await this.proc.stop('SIGKILL');\n    } catch (ign) {}\n  }\n}\n\nclass WDAMacServer {\n  constructor () {\n    this.process = null;\n    this.serverStartupTimeoutMs = STARTUP_TIMEOUT_MS;\n    this.proxy = null;\n\n    // To handle if the WDAMac server is proxying requests to a remote WDAMac app instance\n    this.isProxyingToRemoteServer = false;\n  }\n\n  async isProxyReady (throwOnExit = true) {\n    if (!this.proxy) {\n      return false;\n    }\n\n    try {\n      await this.proxy.command('/status', 'GET');\n      return true;\n    } catch (err) {\n      if (throwOnExit && this.proxy.didProcessExit) {\n        throw new Error(err.message);\n      }\n      return false;\n    }\n  }\n\n\n  /**\n   * @typedef {Object} ProxyProperties\n   *\n   * @property {string} scheme - The scheme proxy to.\n   * @property {string} host - The host name proxy to.\n   * @property {number} port - The port number proxy to.\n   * @property {string} path - The path proxy to.\n   */\n\n  /**\n   * Returns proxy information where WDAMacServer proxy to.\n   *\n   * @param {Object} caps - The capabilities in the session.\n   * @return {ProxyProperties}\n   * @throws Error if 'webDriverAgentMacUrl' had invalid URL\n   */\n  parseProxyProperties (caps) {\n    let scheme = 'http';\n    if (!caps.webDriverAgentMacUrl) {\n      return {\n        scheme,\n        server: (this.process?.host ?? caps.systemHost) ?? DEFAULT_SYSTEM_HOST,\n        port: (this.process?.port ?? caps.systemPort) ?? DEFAULT_SYSTEM_PORT,\n        path: ''\n      };\n    }\n\n    let parsedUrl;\n    try {\n      parsedUrl = new url.URL(caps.webDriverAgentMacUrl);\n    } catch (e) {\n      throw new Error(`webDriverAgentMacUrl, '${caps.webDriverAgentMacUrl}', ` +\n        `in the capabilities is invalid. ${e.message}`);\n    }\n\n    const { protocol, hostname, port, pathname } = parsedUrl;\n    if (_.isString(protocol)) {\n      scheme = protocol.split(':')[0];\n    }\n    return {\n      scheme,\n      server: hostname ?? DEFAULT_SYSTEM_HOST,\n      port: _.isEmpty(port) ? DEFAULT_SYSTEM_PORT : _.parseInt(port),\n      path: pathname === '/' ? '' : pathname\n    };\n  }\n\n  async startSession (caps) {\n    this.serverStartupTimeoutMs = caps.serverStartupTimeout ?? this.serverStartupTimeoutMs;\n\n    this.isProxyingToRemoteServer = !!caps.webDriverAgentMacUrl;\n\n    let wasProcessInitNecessary;\n    if (this.isProxyingToRemoteServer) {\n      if (this.process) {\n        await this.process.kill();\n        await cleanupObsoleteProcesses();\n        this.process = null;\n      }\n\n      wasProcessInitNecessary = false;\n    } else {\n      if (!this.process) {\n        this.process = new WDAMacProcess();\n      }\n      wasProcessInitNecessary = await this.process.init(caps);\n    }\n\n    if (wasProcessInitNecessary || this.isProxyingToRemoteServer || !this.proxy) {\n      const {scheme, server, port, path} = this.parseProxyProperties(caps);\n      this.proxy = new WDAMacProxy({\n        scheme,\n        server,\n        port,\n        base: path,\n        keepAlive: true,\n      });\n      this.proxy.didProcessExit = false;\n\n      if (this.process) {\n        this.process.proc.on('exit', () => {\n          this.proxy.didProcessExit = true;\n        });\n      }\n\n      const timer = new timing.Timer().start();\n      try {\n        await waitForCondition(async () => await this.isProxyReady(), {\n          waitMs: this.serverStartupTimeoutMs,\n          intervalMs: 1000,\n        });\n      } catch (e) {\n        if (this.process?.isRunning) {\n          // avoid \"frozen\" processes,\n          await this.process.kill();\n        }\n        if (/Condition unmet/.test(e.message)) {\n          const msg = this.isProxyingToRemoteServer\n            ? `No response from '${scheme}://${server}:${port}${path}' within ${this.serverStartupTimeoutMs}ms timeout.` +\n            `Please make sure the remote server is running and accessible by Appium`\n            : `Mac2Driver server is not listening within ${this.serverStartupTimeoutMs}ms timeout. ` +\n            `Try to increase the value of 'serverStartupTimeout' capability, check the server logs ` +\n            `and make sure the ${XCODEBUILD} host process could be started manually from a terminal`;\n          throw new Error(msg);\n        }\n        throw e;\n      }\n\n      if (this.process) {\n        const pid = this.process.pid;\n        const childrenPids = await this.process.listChildrenPids();\n        RUNNING_PROCESS_IDS.push(...childrenPids, pid);\n        this.process.proc.on('exit', () => void _.pull(RUNNING_PROCESS_IDS, pid));\n        log.info(`The host process is ready within ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n      }\n    } else {\n      log.info('The host process has already been listening. Proceeding with session creation');\n    }\n\n    await this.proxy.command('/session', 'POST', {\n      capabilities: {\n        firstMatch: [{}],\n        alwaysMatch: caps,\n      }\n    });\n  }\n\n  async stopSession () {\n    if (!this.isProxyingToRemoteServer && !(this.process?.isRunning)) {\n      log.info(`Mac2Driver session cannot be stopped, because the server is not running`);\n      return;\n    }\n\n    if (this.proxy?.sessionId) {\n      try {\n        await this.proxy.command(`/session/${this.proxy.sessionId}`, 'DELETE');\n      } catch (e) {\n        log.info(`Mac2Driver session cannot be deleted. Original error: ${e.message}`);\n      }\n    }\n  }\n}\n\nconst WDA_MAC_SERVER = new WDAMacServer();\n\nexport default WDA_MAC_SERVER;\n"],"file":"lib/wda-mac.js","sourceRoot":"../.."}
|
package/lib/wda-mac.js
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import _ from 'lodash';
|
|
2
2
|
import path from 'path';
|
|
3
3
|
import url from 'url';
|
|
4
|
+
import axios from 'axios';
|
|
5
|
+
import B from 'bluebird';
|
|
4
6
|
import { JWProxy, errors } from 'appium-base-driver';
|
|
5
7
|
import { fs, logger, util, timing, mkdirp } from 'appium-support';
|
|
6
8
|
import { SubProcess, exec } from 'teen_process';
|
|
@@ -208,11 +210,31 @@ class WDAMacProcess {
|
|
|
208
210
|
|
|
209
211
|
log.debug(`Using ${this.host} as server host`);
|
|
210
212
|
log.debug(`Using port ${this.port}`);
|
|
211
|
-
const isPortBusy = (await checkPortStatus(this.port, this.host)) === 'open';
|
|
212
|
-
if (isPortBusy) {
|
|
213
|
-
|
|
214
|
-
`
|
|
215
|
-
`
|
|
213
|
+
const isPortBusy = async () => (await checkPortStatus(this.port, this.host)) === 'open';
|
|
214
|
+
if (await isPortBusy()) {
|
|
215
|
+
log.warn(`The port #${this.port} at ${this.host} is busy. ` +
|
|
216
|
+
`Assuming it is an obsolete WDA server instance and ` +
|
|
217
|
+
`trying to terminate it in order to start a new one`);
|
|
218
|
+
const timer = new timing.Timer().start();
|
|
219
|
+
try {
|
|
220
|
+
await axios.delete(`http://${this.host}:${this.port}/`, {
|
|
221
|
+
timeout: 5000,
|
|
222
|
+
});
|
|
223
|
+
// Give the server some time to finish and stop listening
|
|
224
|
+
await B.delay(500);
|
|
225
|
+
await waitForCondition(async () => !(await isPortBusy()), {
|
|
226
|
+
waitMs: 3000,
|
|
227
|
+
intervalMs: 100,
|
|
228
|
+
});
|
|
229
|
+
} catch (e) {
|
|
230
|
+
log.warn(`Did not know how to terminate the process at ${this.host}:${this.port}: ${e.message}. ` +
|
|
231
|
+
`Perhaps, it is not a WDA server, which is hogging the port?`);
|
|
232
|
+
throw new Error(`The port #${this.port} at ${this.host} is busy. ` +
|
|
233
|
+
`Consider setting 'systemPort' capability to another free port number and/or ` +
|
|
234
|
+
`make sure previous driver sessions have been closed properly.`);
|
|
235
|
+
}
|
|
236
|
+
log.info(`The previously running WDA server has been successfully terminated after ` +
|
|
237
|
+
`${Math.round(timer.getDuration().asMilliSeconds)}ms`);
|
|
216
238
|
}
|
|
217
239
|
|
|
218
240
|
const args = [
|
package/package.json
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
"mac",
|
|
7
7
|
"XCTest"
|
|
8
8
|
],
|
|
9
|
-
"version": "0.
|
|
9
|
+
"version": "0.13.0",
|
|
10
10
|
"author": "appium",
|
|
11
11
|
"license": "Apache-2.0",
|
|
12
12
|
"repository": {
|
|
@@ -34,6 +34,7 @@
|
|
|
34
34
|
"appium-base-driver": "^7.1.0",
|
|
35
35
|
"appium-support": "^2.46.0",
|
|
36
36
|
"asyncbox": "^2.0.2",
|
|
37
|
+
"axios": "^0.x",
|
|
37
38
|
"bluebird": "^3.5.1",
|
|
38
39
|
"lodash": "^4.17.4",
|
|
39
40
|
"portscanner": "2.2.0",
|
|
@@ -65,7 +66,7 @@
|
|
|
65
66
|
"gulp": "^4.0.0",
|
|
66
67
|
"mocha": "^8.0.1",
|
|
67
68
|
"pre-commit": "^1.1.3",
|
|
68
|
-
"sinon": "^
|
|
69
|
+
"sinon": "^10.0.0",
|
|
69
70
|
"wd": "^1.5.0"
|
|
70
71
|
},
|
|
71
72
|
"files": [
|