appium-xcode
Advanced tools
Comparing version 1.0.2 to 2.0.0
"use strict"; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbImluZGV4LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBO0FBQUEiLCJzb3VyY2VSb290IjoiL1VzZXJzL2pvbmFoc3MvV29ya3NwYWNlL2FwcGl1bS14Y29kZS8iLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUaGlzIGZpbGUgc2hvdWxkIHJlYWQ6XG4vLyBleHBvcnQgKiBmcm9tICdsaWIveGNvZGUuanMnXG5cbi8vIGJ1dCB0aGlzIHN5bnRheCBpcyBicm9rZW4gaW4gdHJhY2V1cjogaHR0cHM6Ly9naXRodWIuY29tL2dvb2dsZS90cmFjZXVyLWNvbXBpbGVyL2lzc3Vlcy8xMDQyXG4iXX0= | ||
//# sourceURL=index.js | ||
// This file should read: | ||
// export * from 'lib/xcode.js' | ||
// but this syntax is broken in traceur: https://github.com/google/traceur-compiler/issues/1042 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJpbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbXX0= |
@@ -1,537 +0,396 @@ | ||
"use strict"; | ||
Object.defineProperties(exports, { | ||
getPath: {get: function() { | ||
return getPath; | ||
}}, | ||
getVersion: {get: function() { | ||
return getVersion; | ||
}}, | ||
getAutomationTraceTemplatePath: {get: function() { | ||
return getAutomationTraceTemplatePath; | ||
}}, | ||
getMaxIOSSDK: {get: function() { | ||
return getMaxIOSSDK; | ||
}}, | ||
getAutomationTraceTemplatePathWithoutRetry: {get: function() { | ||
return getAutomationTraceTemplatePathWithoutRetry; | ||
}}, | ||
getMaxIOSSDKWithoutRetry: {get: function() { | ||
return getMaxIOSSDKWithoutRetry; | ||
}}, | ||
clearInternalCache: {get: function() { | ||
return clearInternalCache; | ||
}}, | ||
__esModule: {value: true} | ||
'use strict'; | ||
var _slicedToArray = require('babel-runtime/helpers/sliced-to-array')['default']; | ||
var _core = require('babel-runtime/core-js')['default']; | ||
var _regeneratorRuntime = require('babel-runtime/regenerator')['default']; | ||
var _interopRequireWildcard = require('babel-runtime/helpers/interop-require-wildcard')['default']; | ||
_core.Object.defineProperty(exports, '__esModule', { | ||
value: true | ||
}); | ||
var $__npmlog__, | ||
$__appium_45_support__, | ||
$__fs__, | ||
$__denodeify__, | ||
$__path__, | ||
$__asyncbox__, | ||
$__lodash__; | ||
var npmlog = ($__npmlog__ = require("npmlog"), $__npmlog__ && $__npmlog__.__esModule && $__npmlog__ || {default: $__npmlog__}).default; | ||
var support = ($__appium_45_support__ = require("appium-support"), $__appium_45_support__ && $__appium_45_support__.__esModule && $__appium_45_support__ || {default: $__appium_45_support__}).default; | ||
var fs = ($__fs__ = require("fs"), $__fs__ && $__fs__.__esModule && $__fs__ || {default: $__fs__}).default; | ||
var denodeify = ($__denodeify__ = require("denodeify"), $__denodeify__ && $__denodeify__.__esModule && $__denodeify__ || {default: $__denodeify__}).default; | ||
var path = ($__path__ = require("path"), $__path__ && $__path__.__esModule && $__path__ || {default: $__path__}).default; | ||
var retry = ($__asyncbox__ = require("asyncbox"), $__asyncbox__ && $__asyncbox__.__esModule && $__asyncbox__ || {default: $__asyncbox__}).retry; | ||
var _ = ($__lodash__ = require("lodash"), $__lodash__ && $__lodash__.__esModule && $__lodash__ || {default: $__lodash__}).default; | ||
var exec = support.core.exec; | ||
var util = support.util; | ||
var fileExists = support.util.fileExists; | ||
var escapeSpace = support.util.escapeSpace; | ||
var readSymlink = denodeify(fs.readlink); | ||
var _npmlog = require('npmlog'); | ||
var _npmlog2 = _interopRequireWildcard(_npmlog); | ||
var _support = require('appium-support'); | ||
var _support2 = _interopRequireWildcard(_support); | ||
var _fs = require('fs'); | ||
var _fs2 = _interopRequireWildcard(_fs); | ||
var _denodeify = require('denodeify'); | ||
var _denodeify2 = _interopRequireWildcard(_denodeify); | ||
var _path = require('path'); | ||
var _path2 = _interopRequireWildcard(_path); | ||
var _retry = require('asyncbox'); | ||
var _import = require('lodash'); | ||
var _import2 = _interopRequireWildcard(_import); | ||
var exec = _support2['default'].core.exec; | ||
var util = _support2['default'].util; | ||
var fileExists = _support2['default'].util.fileExists; | ||
var escapeSpace = _support2['default'].util.escapeSpace; | ||
var readSymlink = _denodeify2['default'](_fs2['default'].readlink); | ||
var env = process.env; | ||
var XCODE_SELECT_TIMEOUT = 3000; | ||
var XCODE_SUBDIR = "/Contents/Developer"; | ||
var XCODE_SUBDIR = '/Contents/Developer'; | ||
var DEFAULT_NUMBER_OF_RETRIES = 3; | ||
var log = process.env.GLOBAL_NPMLOG ? global.log : npmlog; | ||
var log = process.env.GLOBAL_NPMLOG ? global.log : _npmlog2['default']; | ||
function hasExpectedSubDir(path) { | ||
return path.substring(path.length - XCODE_SUBDIR.length) === XCODE_SUBDIR; | ||
} | ||
function getPathFromSymlink(failMessage) { | ||
var symlinkPath, | ||
legacySymlinkPath, | ||
customPath, | ||
mesg, | ||
msg, | ||
$__8, | ||
$__9, | ||
$__10, | ||
$__11, | ||
$__12, | ||
$__13; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
log.warn(("Finding XcodePath by symlink because " + failMessage)); | ||
symlinkPath = "/var/db/xcode_select_link"; | ||
legacySymlinkPath = "/usr/share/xcode-select/xcode_dir_path"; | ||
$ctx.state = 34; | ||
var symlinkPath, legacySymlinkPath, customPath, mesg, msg; | ||
return _regeneratorRuntime.async(function getPathFromSymlink$(context$1$0) { | ||
while (1) switch (context$1$0.prev = context$1$0.next) { | ||
case 0: | ||
// Node's invocation of xcode-select sometimes flakes and returns an empty string. | ||
// Not clear why. As a workaround, Appium can reliably deduce the version in use by checking | ||
// the locations xcode-select uses to store the selected version's path. This should be 100% | ||
// reliable so long as the link locations remain the same. However, since we're relying on | ||
// hardcoded paths, this approach will break the next time Apple changes the symlink location. | ||
log.warn('Finding XcodePath by symlink because ' + failMessage); | ||
symlinkPath = '/var/db/xcode_select_link'; | ||
legacySymlinkPath = '/usr/share/xcode-select/xcode_dir_path'; | ||
if (!util.hasContent(env.DEVELOPER_DIR)) { | ||
context$1$0.next = 14; | ||
break; | ||
case 34: | ||
$ctx.state = (util.hasContent(env.DEVELOPER_DIR)) ? 12 : 8; | ||
} | ||
customPath = hasExpectedSubDir(env.DEVELOPER_DIR) ? env.DEVELOPER_DIR : env.DEVELOPER_DIR + XCODE_SUBDIR; | ||
context$1$0.next = 7; | ||
return fileExists(customPath); | ||
case 7: | ||
if (!context$1$0.sent) { | ||
context$1$0.next = 11; | ||
break; | ||
case 12: | ||
customPath = hasExpectedSubDir(env.DEVELOPER_DIR) ? env.DEVELOPER_DIR : env.DEVELOPER_DIR + XCODE_SUBDIR; | ||
$ctx.state = 13; | ||
} | ||
return context$1$0.abrupt('return', customPath); | ||
case 11: | ||
mesg = 'Could not find path to Xcode, environment variable ' + ('DEVELOPER_DIR set to: ' + env.DEVELOPER_DIR + ' ') + 'but no Xcode found'; | ||
log.warn(mesg); | ||
throw new Error(mesg); | ||
case 14: | ||
context$1$0.next = 16; | ||
return fileExists(symlinkPath); | ||
case 16: | ||
if (!context$1$0.sent) { | ||
context$1$0.next = 18; | ||
break; | ||
case 13: | ||
$__8 = fileExists(customPath); | ||
$ctx.state = 5; | ||
} | ||
return context$1$0.abrupt('return', readSymlink(symlinkPath)); | ||
case 18: | ||
context$1$0.next = 20; | ||
return fileExists(legacySymlinkPath); | ||
case 20: | ||
if (!context$1$0.sent) { | ||
context$1$0.next = 22; | ||
break; | ||
case 5: | ||
Promise.resolve($__8).then($ctx.createCallback(3), $ctx.errback); | ||
return; | ||
case 3: | ||
$__9 = $ctx.value; | ||
$ctx.state = 2; | ||
break; | ||
case 2: | ||
$ctx.state = ($__9) ? 6 : 9; | ||
break; | ||
case 6: | ||
$ctx.returnValue = customPath; | ||
$ctx.state = 7; | ||
break; | ||
case 7: | ||
$ctx.state = -2; | ||
break; | ||
case 9: | ||
mesg = "Could not find path to Xcode, environment variable " + ("DEVELOPER_DIR set to: " + env.DEVELOPER_DIR + " ") + "but no Xcode found"; | ||
log.warn(mesg); | ||
throw new Error(mesg); | ||
$ctx.state = 8; | ||
break; | ||
case 8: | ||
$__10 = fileExists(symlinkPath); | ||
$ctx.state = 19; | ||
break; | ||
case 19: | ||
Promise.resolve($__10).then($ctx.createCallback(17), $ctx.errback); | ||
return; | ||
case 17: | ||
$__11 = $ctx.value; | ||
$ctx.state = 16; | ||
break; | ||
case 16: | ||
$ctx.state = ($__11) ? 20 : 22; | ||
break; | ||
case 20: | ||
$ctx.returnValue = readSymlink(symlinkPath); | ||
$ctx.state = 21; | ||
break; | ||
case 21: | ||
$ctx.state = -2; | ||
break; | ||
case 22: | ||
$__12 = fileExists(legacySymlinkPath); | ||
$ctx.state = 28; | ||
break; | ||
case 28: | ||
Promise.resolve($__12).then($ctx.createCallback(26), $ctx.errback); | ||
return; | ||
case 26: | ||
$__13 = $ctx.value; | ||
$ctx.state = 25; | ||
break; | ||
case 25: | ||
$ctx.state = ($__13) ? 29 : 31; | ||
break; | ||
case 29: | ||
$ctx.returnValue = readSymlink(legacySymlinkPath); | ||
$ctx.state = 30; | ||
break; | ||
case 30: | ||
$ctx.state = -2; | ||
break; | ||
case 31: | ||
msg = ("Could not find path to Xcode by symlinks located in " + symlinkPath + ", or " + legacySymlinkPath); | ||
log.warn(msg); | ||
throw new Error(msg); | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
} | ||
return context$1$0.abrupt('return', readSymlink(legacySymlinkPath)); | ||
case 22: | ||
msg = 'Could not find path to Xcode by symlinks located in ' + symlinkPath + ', or ' + legacySymlinkPath; | ||
log.warn(msg); | ||
throw new Error(msg); | ||
case 25: | ||
case 'end': | ||
return context$1$0.stop(); | ||
} | ||
}, null, this); | ||
} | ||
function getPathFromXcodeSelect() { | ||
var stdout, | ||
xcodeFolderPath, | ||
msg, | ||
$__14, | ||
$__15, | ||
$__16, | ||
$__17, | ||
$__18; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
$__14 = exec('xcode-select --print-path', { | ||
maxBuffer: 524288, | ||
timeout: XCODE_SELECT_TIMEOUT | ||
}); | ||
$ctx.state = 5; | ||
var _ref, _ref2, stdout, xcodeFolderPath, msg; | ||
return _regeneratorRuntime.async(function getPathFromXcodeSelect$(context$1$0) { | ||
while (1) switch (context$1$0.prev = context$1$0.next) { | ||
case 0: | ||
context$1$0.next = 2; | ||
return exec('xcode-select --print-path', { maxBuffer: 524288, timeout: XCODE_SELECT_TIMEOUT }); | ||
case 2: | ||
_ref = context$1$0.sent; | ||
_ref2 = _slicedToArray(_ref, 1); | ||
stdout = _ref2[0]; | ||
xcodeFolderPath = stdout.replace(new RegExp('/$'), '').trim(); | ||
if (util.hasContent(xcodeFolderPath)) { | ||
context$1$0.next = 8; | ||
break; | ||
case 5: | ||
Promise.resolve($__14).then($ctx.createCallback(3), $ctx.errback); | ||
return; | ||
case 3: | ||
$__15 = $ctx.value; | ||
$ctx.state = 2; | ||
} | ||
throw new Error('xcode-select returned an empty string'); | ||
case 8: | ||
context$1$0.next = 10; | ||
return fileExists(xcodeFolderPath); | ||
case 10: | ||
if (!context$1$0.sent) { | ||
context$1$0.next = 14; | ||
break; | ||
case 2: | ||
$__16 = $__15[0]; | ||
stdout = $__16; | ||
$ctx.state = 7; | ||
break; | ||
case 7: | ||
xcodeFolderPath = stdout.replace(new RegExp("/$"), "").trim(); | ||
if (!util.hasContent(xcodeFolderPath)) { | ||
throw new Error("xcode-select returned an empty string"); | ||
} | ||
$ctx.state = 20; | ||
break; | ||
case 20: | ||
$__17 = fileExists(xcodeFolderPath); | ||
$ctx.state = 12; | ||
break; | ||
case 12: | ||
Promise.resolve($__17).then($ctx.createCallback(10), $ctx.errback); | ||
return; | ||
case 10: | ||
$__18 = $ctx.value; | ||
$ctx.state = 9; | ||
break; | ||
case 9: | ||
$ctx.state = ($__18) ? 13 : 16; | ||
break; | ||
case 13: | ||
$ctx.returnValue = xcodeFolderPath; | ||
$ctx.state = 14; | ||
break; | ||
case 14: | ||
$ctx.state = -2; | ||
break; | ||
case 16: | ||
msg = ("xcode-select could not find xcode. Path: " + xcodeFolderPath + " does not exist."); | ||
log.error(msg); | ||
throw new Error(msg); | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
} | ||
return context$1$0.abrupt('return', xcodeFolderPath); | ||
case 14: | ||
msg = 'xcode-select could not find xcode. Path: ' + xcodeFolderPath + ' does not exist.'; | ||
log.error(msg); | ||
throw new Error(msg); | ||
case 17: | ||
case 'end': | ||
return context$1$0.stop(); | ||
} | ||
}, null, this); | ||
} | ||
var getPath = _.memoize(function() { | ||
return getPathFromXcodeSelect().catch(getPathFromSymlink); | ||
var getPath = _import2['default'].memoize(function () { | ||
// first we try using xcode-select to find the path | ||
// then we try using the symlinks that Apple has by default | ||
return getPathFromXcodeSelect()['catch'](getPathFromSymlink); | ||
}); | ||
function getVersionWithoutRetry() { | ||
var xcodePath, | ||
plistPath, | ||
cmd, | ||
stdout, | ||
versionPattern, | ||
match, | ||
$__19, | ||
$__20, | ||
$__21, | ||
$__22, | ||
$__23; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
Promise.resolve(getPath()).then($ctx.createCallback(3), $ctx.errback); | ||
return; | ||
case 3: | ||
xcodePath = $ctx.value; | ||
$ctx.state = 2; | ||
var xcodePath, plistPath, cmd, _ref3, _ref32, stdout, versionPattern, match; | ||
return _regeneratorRuntime.async(function getVersionWithoutRetry$(context$1$0) { | ||
while (1) switch (context$1$0.prev = context$1$0.next) { | ||
case 0: | ||
context$1$0.next = 2; | ||
return getPath(); | ||
case 2: | ||
xcodePath = context$1$0.sent; | ||
plistPath = xcodePath.replace(XCODE_SUBDIR, '/Contents/Info.plist'); | ||
context$1$0.next = 6; | ||
return fileExists(plistPath); | ||
case 6: | ||
if (context$1$0.sent) { | ||
context$1$0.next = 8; | ||
break; | ||
case 2: | ||
plistPath = xcodePath.replace(XCODE_SUBDIR, "/Contents/Info.plist"); | ||
$ctx.state = 23; | ||
} | ||
throw new Error('Could not get Xcode version. ' + plistPath + ' does not exist on disk.'); | ||
case 8: | ||
cmd = '/usr/libexec/PlistBuddy -c \'Print CFBundleShortVersionString\' ' + escapeSpace(plistPath); | ||
context$1$0.next = 11; | ||
return exec(cmd, { maxBuffer: 524288, timeout: XCODE_SELECT_TIMEOUT }); | ||
case 11: | ||
_ref3 = context$1$0.sent; | ||
_ref32 = _slicedToArray(_ref3, 1); | ||
stdout = _ref32[0]; | ||
versionPattern = /\d\.\d\.*\d*/; | ||
match = stdout.match(versionPattern); | ||
if (!(match === null || !util.hasContent(match[0]))) { | ||
context$1$0.next = 18; | ||
break; | ||
case 23: | ||
$__19 = fileExists(plistPath); | ||
$ctx.state = 8; | ||
break; | ||
case 8: | ||
Promise.resolve($__19).then($ctx.createCallback(6), $ctx.errback); | ||
return; | ||
case 6: | ||
$__20 = $ctx.value; | ||
$ctx.state = 5; | ||
break; | ||
case 5: | ||
$ctx.state = (!$__20) ? 9 : 10; | ||
break; | ||
case 9: | ||
throw new Error(("Could not get Xcode version. " + plistPath + " does not exist on disk.")); | ||
$ctx.state = 10; | ||
break; | ||
case 10: | ||
cmd = ("/usr/libexec/PlistBuddy -c 'Print CFBundleShortVersionString' " + escapeSpace(plistPath)); | ||
$ctx.state = 25; | ||
break; | ||
case 25: | ||
$__21 = exec(cmd, { | ||
maxBuffer: 524288, | ||
timeout: XCODE_SELECT_TIMEOUT | ||
}); | ||
$ctx.state = 16; | ||
break; | ||
case 16: | ||
Promise.resolve($__21).then($ctx.createCallback(14), $ctx.errback); | ||
return; | ||
case 14: | ||
$__22 = $ctx.value; | ||
$ctx.state = 13; | ||
break; | ||
case 13: | ||
$__23 = $__22[0]; | ||
stdout = $__23; | ||
$ctx.state = 18; | ||
break; | ||
case 18: | ||
versionPattern = /\d\.\d\.*\d*/; | ||
match = stdout.match(versionPattern); | ||
if (match === null || !util.hasContent(match[0])) { | ||
throw new Error(("Could not parse Xcode version. xcodebuild output was: " + stdout)); | ||
} | ||
$ctx.state = 27; | ||
break; | ||
case 27: | ||
$ctx.returnValue = match[0]; | ||
$ctx.state = 20; | ||
break; | ||
case 20: | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
} | ||
throw new Error('Could not parse Xcode version. xcodebuild output was: ' + stdout); | ||
case 18: | ||
return context$1$0.abrupt('return', match[0]); | ||
case 19: | ||
case 'end': | ||
return context$1$0.stop(); | ||
} | ||
}, null, this); | ||
} | ||
var getVersion = _.memoize(function() { | ||
var retries; | ||
var $arguments = arguments; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
retries = $arguments[0] !== (void 0) ? $arguments[0] : DEFAULT_NUMBER_OF_RETRIES; | ||
$ctx.state = 5; | ||
break; | ||
case 5: | ||
$ctx.returnValue = retry(retries, getVersionWithoutRetry); | ||
$ctx.state = 2; | ||
break; | ||
case 2: | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
var getVersion = _import2['default'].memoize(function () { | ||
var retries = arguments[0] === undefined ? DEFAULT_NUMBER_OF_RETRIES : arguments[0]; | ||
return _retry.retry(retries, getVersionWithoutRetry); | ||
}); | ||
function getAutomationTraceTemplatePathWithoutRetry() { | ||
var xcodePath, | ||
extensions, | ||
pathPrefix, | ||
pathSuffix, | ||
automationTraceTemplatePaths, | ||
msg, | ||
$__24, | ||
$__25, | ||
$__26, | ||
$__27, | ||
$__28, | ||
$__29; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
Promise.resolve(getPath()).then($ctx.createCallback(3), $ctx.errback); | ||
return; | ||
case 3: | ||
xcodePath = $ctx.value; | ||
$ctx.state = 2; | ||
var xcodePath, extensions, pathPrefix, pathSuffix, automationTraceTemplatePaths, msg; | ||
return _regeneratorRuntime.async(function getAutomationTraceTemplatePathWithoutRetry$(context$1$0) { | ||
while (1) switch (context$1$0.prev = context$1$0.next) { | ||
case 0: | ||
context$1$0.next = 2; | ||
return getPath(); | ||
case 2: | ||
xcodePath = context$1$0.sent; | ||
extensions = ['xrplugin', 'bundle']; | ||
pathPrefix = _path2['default'].resolve(xcodePath, '../Applications/Instruments.app/Contents/PlugIns'); | ||
pathSuffix = 'Contents/Resources/Automation.tracetemplate'; | ||
automationTraceTemplatePaths = [_path2['default'].resolve(pathPrefix, 'AutomationInstrument.' + extensions[0], pathSuffix), _path2['default'].resolve(pathPrefix, 'AutomationInstrument.' + extensions[1], pathSuffix)]; | ||
context$1$0.next = 9; | ||
return fileExists(automationTraceTemplatePaths[0]); | ||
case 9: | ||
if (!context$1$0.sent) { | ||
context$1$0.next = 11; | ||
break; | ||
case 2: | ||
extensions = ['xrplugin', 'bundle']; | ||
pathPrefix = path.resolve(xcodePath, "../Applications/Instruments.app/Contents/PlugIns"); | ||
pathSuffix = "Contents/Resources/Automation.tracetemplate"; | ||
automationTraceTemplatePaths = [path.resolve(pathPrefix, "AutomationInstrument." + extensions[0], pathSuffix), path.resolve(pathPrefix, "AutomationInstrument." + extensions[1], pathSuffix)]; | ||
$ctx.state = 23; | ||
} | ||
return context$1$0.abrupt('return', automationTraceTemplatePaths[0]); | ||
case 11: | ||
context$1$0.next = 13; | ||
return fileExists(automationTraceTemplatePaths[1]); | ||
case 13: | ||
if (!context$1$0.sent) { | ||
context$1$0.next = 15; | ||
break; | ||
case 23: | ||
$__24 = automationTraceTemplatePaths[0]; | ||
$__25 = fileExists($__24); | ||
$ctx.state = 8; | ||
break; | ||
case 8: | ||
Promise.resolve($__25).then($ctx.createCallback(6), $ctx.errback); | ||
return; | ||
case 6: | ||
$__26 = $ctx.value; | ||
$ctx.state = 5; | ||
break; | ||
case 5: | ||
$ctx.state = ($__26) ? 9 : 11; | ||
break; | ||
case 9: | ||
$ctx.returnValue = automationTraceTemplatePaths[0]; | ||
$ctx.state = 10; | ||
break; | ||
case 10: | ||
$ctx.state = -2; | ||
break; | ||
case 11: | ||
$__27 = automationTraceTemplatePaths[1]; | ||
$__28 = fileExists($__27); | ||
$ctx.state = 17; | ||
break; | ||
case 17: | ||
Promise.resolve($__28).then($ctx.createCallback(15), $ctx.errback); | ||
return; | ||
case 15: | ||
$__29 = $ctx.value; | ||
$ctx.state = 14; | ||
break; | ||
case 14: | ||
$ctx.state = ($__29) ? 18 : 20; | ||
break; | ||
case 18: | ||
$ctx.returnValue = automationTraceTemplatePaths[1]; | ||
$ctx.state = 19; | ||
break; | ||
case 19: | ||
$ctx.state = -2; | ||
break; | ||
case 20: | ||
msg = "Could not find Automation.tracetemplate in any of the following" + ("locations " + automationTraceTemplatePaths.toString()); | ||
log.error(msg); | ||
throw new Error(msg); | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
} | ||
return context$1$0.abrupt('return', automationTraceTemplatePaths[1]); | ||
case 15: | ||
msg = 'Could not find Automation.tracetemplate in any of the following' + ('locations ' + automationTraceTemplatePaths.toString()); | ||
log.error(msg); | ||
throw new Error(msg); | ||
case 18: | ||
case 'end': | ||
return context$1$0.stop(); | ||
} | ||
}, null, this); | ||
} | ||
var getAutomationTraceTemplatePath = _.memoize(function() { | ||
var retries; | ||
var $arguments = arguments; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
retries = $arguments[0] !== (void 0) ? $arguments[0] : DEFAULT_NUMBER_OF_RETRIES; | ||
$ctx.state = 5; | ||
break; | ||
case 5: | ||
$ctx.returnValue = retry(retries, getAutomationTraceTemplatePathWithoutRetry); | ||
$ctx.state = 2; | ||
break; | ||
case 2: | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
var getAutomationTraceTemplatePath = _import2['default'].memoize(function () { | ||
var retries = arguments[0] === undefined ? DEFAULT_NUMBER_OF_RETRIES : arguments[0]; | ||
return _retry.retry(retries, getAutomationTraceTemplatePathWithoutRetry); | ||
}); | ||
// TODO remove this function. should really just be using 'getVersion()' everywhere. | ||
// This was added for tech-debt backwards compatibility | ||
function getMaxIOSSDKWithoutRetry() { | ||
var version, | ||
cmd, | ||
stdout, | ||
sdkVersion, | ||
match, | ||
$__30, | ||
$__31, | ||
$__32; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
Promise.resolve(getVersion()).then($ctx.createCallback(3), $ctx.errback); | ||
return; | ||
case 3: | ||
version = $ctx.value; | ||
$ctx.state = 2; | ||
var version, cmd, _ref4, _ref42, stdout, sdkVersion, match; | ||
return _regeneratorRuntime.async(function getMaxIOSSDKWithoutRetry$(context$1$0) { | ||
while (1) switch (context$1$0.prev = context$1$0.next) { | ||
case 0: | ||
context$1$0.next = 2; | ||
return getVersion(); | ||
case 2: | ||
version = context$1$0.sent; | ||
if (!(version === '4')) { | ||
context$1$0.next = 5; | ||
break; | ||
case 2: | ||
$ctx.state = (version === '4') ? 4 : 6; | ||
} | ||
return context$1$0.abrupt('return', '6.1'); | ||
case 5: | ||
cmd = 'xcrun --sdk iphonesimulator --show-sdk-version'; | ||
context$1$0.next = 8; | ||
return exec(cmd, { maxBuffer: 524288, timeout: XCODE_SELECT_TIMEOUT }); | ||
case 8: | ||
_ref4 = context$1$0.sent; | ||
_ref42 = _slicedToArray(_ref4, 1); | ||
stdout = _ref42[0]; | ||
sdkVersion = stdout.trim(); | ||
match = /\d.\d/.exec(stdout); | ||
if (match) { | ||
context$1$0.next = 15; | ||
break; | ||
case 4: | ||
$ctx.returnValue = '6.1'; | ||
$ctx.state = 5; | ||
break; | ||
case 5: | ||
$ctx.state = -2; | ||
break; | ||
case 6: | ||
cmd = "xcrun --sdk iphonesimulator --show-sdk-version"; | ||
$ctx.state = 19; | ||
break; | ||
case 19: | ||
$__30 = exec(cmd, { | ||
maxBuffer: 524288, | ||
timeout: XCODE_SELECT_TIMEOUT | ||
}); | ||
$ctx.state = 12; | ||
break; | ||
case 12: | ||
Promise.resolve($__30).then($ctx.createCallback(10), $ctx.errback); | ||
return; | ||
case 10: | ||
$__31 = $ctx.value; | ||
$ctx.state = 9; | ||
break; | ||
case 9: | ||
$__32 = $__31[0]; | ||
stdout = $__32; | ||
$ctx.state = 14; | ||
break; | ||
case 14: | ||
sdkVersion = stdout.trim(); | ||
match = /\d.\d/.exec(stdout); | ||
if (!match) { | ||
throw new Error(("xcrun returned a non-numeric iOS SDK version: " + sdkVersion)); | ||
} | ||
$ctx.state = 21; | ||
break; | ||
case 21: | ||
$ctx.returnValue = sdkVersion; | ||
$ctx.state = 16; | ||
break; | ||
case 16: | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
} | ||
throw new Error('xcrun returned a non-numeric iOS SDK version: ' + sdkVersion); | ||
case 15: | ||
return context$1$0.abrupt('return', sdkVersion); | ||
case 16: | ||
case 'end': | ||
return context$1$0.stop(); | ||
} | ||
}, null, this); | ||
} | ||
var getMaxIOSSDK = _.memoize(function() { | ||
var retries = arguments[0] !== (void 0) ? arguments[0] : DEFAULT_NUMBER_OF_RETRIES; | ||
return retry(retries, getMaxIOSSDKWithoutRetry); | ||
var getMaxIOSSDK = _import2['default'].memoize(function () { | ||
var retries = arguments[0] === undefined ? DEFAULT_NUMBER_OF_RETRIES : arguments[0]; | ||
return _retry.retry(retries, getMaxIOSSDKWithoutRetry); | ||
}); | ||
function clearInternalCache() { | ||
// memoized functions | ||
var memoized = [getPath, getVersion, getAutomationTraceTemplatePath, getMaxIOSSDK]; | ||
memoized.forEach((function(f) { | ||
memoized.forEach(function (f) { | ||
if (f.cache) { | ||
f.cache = new _.memoize.Cache(); | ||
f.cache = new _import2['default'].memoize.Cache(); | ||
} | ||
})); | ||
}); | ||
} | ||
; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xcode.js","sources":["xcode.js","@traceur/generated/TemplateParser/7","@traceur/generated/TemplateParser/5","@traceur/generated/TemplateParser/3","@traceur/generated/TemplateParser/4","@traceur/generated/TemplateParser/6","@traceur/generated/TemplateParser/2","@traceur/generated/TemplateParser/15","@traceur/generated/TemplateParser/8","@traceur/generated/TemplateParser/14","@traceur/generated/TemplateParser/11","@traceur/generated/TemplateParser/12","@traceur/generated/TemplateParser/9","@traceur/generated/TemplateParser/10","@traceur/generated/TemplateParser/13","@traceur/generated/TemplateParser/16"],"names":[],"mappings":"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","sourceRoot":"/Users/jonahss/Workspace/appium-xcode/lib/","sourcesContent":["import npmlog from 'npmlog';\nimport support from 'appium-support';\nimport fs from 'fs';\nimport denodeify from 'denodeify';\nimport path from 'path';\nimport { retry } from 'asyncbox';\nimport _ from 'lodash';\n\nconst exec = support.core.exec;\nconst util = support.util;\nconst fileExists = support.util.fileExists;\nconst escapeSpace = support.util.escapeSpace;\nconst readSymlink = denodeify(fs.readlink);\nconst env = process.env;\n\nconst XCODE_SELECT_TIMEOUT = 3000;\nconst XCODE_SUBDIR = \"/Contents/Developer\";\nconst DEFAULT_NUMBER_OF_RETRIES = 3;\n\nconst log = process.env.GLOBAL_NPMLOG ? global.log : npmlog;\n\n\nfunction hasExpectedSubDir (path) {\n  return path.substring(path.length - XCODE_SUBDIR.length) === XCODE_SUBDIR;\n}\n\nasync function getPathFromSymlink (failMessage) {\n  // Node's invocation of xcode-select sometimes flakes and returns an empty string.\n  // Not clear why. As a workaround, Appium can reliably deduce the version in use by checking\n  // the locations xcode-select uses to store the selected version's path. This should be 100%\n  // reliable so long as the link locations remain the same. However, since we're relying on\n  // hardcoded paths, this approach will break the next time Apple changes the symlink location.\n  log.warn(`Finding XcodePath by symlink because ${failMessage}`);\n\n  const symlinkPath = \"/var/db/xcode_select_link\";\n  const legacySymlinkPath = \"/usr/share/xcode-select/xcode_dir_path\"; //  Xcode < 5.x (?)\n\n  // xcode-select allows users to override its settings with the DEVELOPER_DIR env var,\n  // so check that first\n  if (util.hasContent(env.DEVELOPER_DIR)) {\n    const customPath = hasExpectedSubDir(env.DEVELOPER_DIR) ?\n                                         env.DEVELOPER_DIR  :\n                                         env.DEVELOPER_DIR + XCODE_SUBDIR;\n\n    if (await fileExists(customPath)) {\n      return customPath;\n    } else {\n      let mesg = `Could not find path to Xcode, environment variable ` +\n                 `DEVELOPER_DIR set to: ${env.DEVELOPER_DIR} ` +\n                 `but no Xcode found`;\n      log.warn(mesg);\n      throw new Error(mesg);\n    }\n  }\n\n\n  if (await fileExists(symlinkPath)) {\n    return readSymlink(symlinkPath);\n  }\n\n  if (await fileExists(legacySymlinkPath)) {\n    return readSymlink(legacySymlinkPath);\n  }\n\n  // We should only get here is we failed to capture xcode-select's stdout and our\n  // other checks failed. Either Apple has moved the symlink to a new location or the user\n  // is not using the default install. 99.999% chance it's the latter, so issue a warning\n  // should we ever hit the edge case.\n  let msg = `Could not find path to Xcode by symlinks located in ${symlinkPath}, or ${legacySymlinkPath}`;\n  log.warn(msg);\n  throw new Error(msg);\n\n}\n\nasync function getPathFromXcodeSelect () {\n\n  let [stdout] = await exec('xcode-select --print-path', {maxBuffer: 524288, timeout: XCODE_SELECT_TIMEOUT});\n\n  // trim and remove trailing slash\n  const xcodeFolderPath = stdout.replace(new RegExp(\"/$\"), \"\").trim();\n\n  if (!util.hasContent(xcodeFolderPath)) {\n    throw new Error(\"xcode-select returned an empty string\");\n  }\n\n  if (await fileExists(xcodeFolderPath)) {\n    return xcodeFolderPath;\n  } else {\n    const msg = `xcode-select could not find xcode. Path: ${xcodeFolderPath} does not exist.`;\n    log.error(msg);\n    throw new Error(msg);\n  }\n}\n\nconst getPath = _.memoize(function () {\n\n  // first we try using xcode-select to find the path\n  // then we try using the symlinks that Apple has by default\n\n  return getPathFromXcodeSelect().catch(getPathFromSymlink);\n});\n\n\n\nasync function getVersionWithoutRetry () {\n\n  let xcodePath = await getPath();\n\n  // we want to read the CFBundleShortVersionString from Xcode's plist.\n  // It should be in /[root]/XCode.app/Contents/\n  const plistPath = xcodePath.replace(XCODE_SUBDIR, \"/Contents/Info.plist\");\n\n  if (!await fileExists(plistPath)) {\n    throw new Error(`Could not get Xcode version. ${plistPath} does not exist on disk.`);\n  }\n\n  const cmd = `/usr/libexec/PlistBuddy -c 'Print CFBundleShortVersionString' ${escapeSpace(plistPath)}`;\n  let [stdout] = await exec(cmd, {maxBuffer: 524288, timeout: XCODE_SELECT_TIMEOUT});\n\n  let versionPattern = /\\d\\.\\d\\.*\\d*/;\n  // need to use string#match here; previous code used regexp#exec, which does not return null\n  let match = stdout.match(versionPattern);\n  if (match === null || !util.hasContent(match[0])) {\n    throw new Error(`Could not parse Xcode version. xcodebuild output was: ${stdout}`);\n  }\n\n  return match[0];\n}\n\n\nconst getVersion = _.memoize(\n  async function (retries = DEFAULT_NUMBER_OF_RETRIES) {\n    return retry(retries, getVersionWithoutRetry);\n  }\n);\n\nasync function getAutomationTraceTemplatePathWithoutRetry () {\n\n  const xcodePath = await getPath();\n\n  // for ios 8 and up, the file extension for AutiomationInstrument changed.\n  // rather than waste time getting the iOSSDKVersion, just get both paths and see which one exists\n  const extensions = ['xrplugin', 'bundle'];\n  const pathPrefix = path.resolve(xcodePath, \"../Applications/Instruments.app/Contents/PlugIns\");\n  const pathSuffix = \"Contents/Resources/Automation.tracetemplate\";\n  let automationTraceTemplatePaths = [\n    path.resolve(pathPrefix, \"AutomationInstrument.\" + extensions[0], pathSuffix),\n    path.resolve(pathPrefix, \"AutomationInstrument.\" + extensions[1], pathSuffix)\n  ];\n\n  if (await fileExists(automationTraceTemplatePaths[0])) {\n    return automationTraceTemplatePaths[0];\n  }\n\n  if (await fileExists(automationTraceTemplatePaths[1])) {\n    return automationTraceTemplatePaths[1];\n  }\n\n  const msg = \"Could not find Automation.tracetemplate in any of the following\" +\n              `locations ${automationTraceTemplatePaths.toString()}`;\n  log.error(msg);\n  throw new Error(msg);\n\n}\n\nconst getAutomationTraceTemplatePath = _.memoize(\n  async function (retries = DEFAULT_NUMBER_OF_RETRIES) {\n    return retry(retries, getAutomationTraceTemplatePathWithoutRetry);\n  }\n);\n\n// TODO remove this function. should really just be using 'getVersion()' everywhere.\n// This was added for tech-debt backwards compatibility\nasync function getMaxIOSSDKWithoutRetry () {\n\n  const version = await getVersion();\n\n  if (version === '4') {\n    return '6.1';\n  }\n\n  const cmd = `xcrun --sdk iphonesimulator --show-sdk-version`;\n  const [stdout] = await exec(cmd, {maxBuffer: 524288, timeout: XCODE_SELECT_TIMEOUT});\n\n  const sdkVersion = stdout.trim();\n  const match = /\\d.\\d/.exec(stdout);\n\n  if (!match) {\n    throw new Error(`xcrun returned a non-numeric iOS SDK version: ${sdkVersion}`);\n  }\n\n  return sdkVersion;\n}\n\nconst getMaxIOSSDK = _.memoize(\n  function (retries = DEFAULT_NUMBER_OF_RETRIES) {\n    return retry(retries, getMaxIOSSDKWithoutRetry);\n  }\n);\n\nfunction clearInternalCache () {\n\n  // memoized functions\n  const memoized = [getPath, getVersion, getAutomationTraceTemplatePath,\n                    getMaxIOSSDK];\n\n  memoized.forEach((f) => {\n    if (f.cache) {\n      f.cache = new _.memoize.Cache();\n    }\n  });\n\n\n}\n\nexport { getPath, getVersion, getAutomationTraceTemplatePath, getMaxIOSSDK,\n         getAutomationTraceTemplatePathWithoutRetry, getMaxIOSSDKWithoutRetry,\n         clearInternalCache };\n","Object.defineProperties(exports, $__placeholder__0);","{get: $__placeholder__0}","get $__placeholder__0() { return $__placeholder__1; }","__esModule: true","{value: $__placeholder__0}","($__placeholder__0 = require($__placeholder__1),\n        $__placeholder__2 && $__placeholder__3.__esModule && $__placeholder__4 || {default: $__placeholder__5})","return $__placeholder__0(\n              $__placeholder__1, this);","$traceurRuntime.asyncWrap","function($ctx) {\n      while (true) $__placeholder__0\n    }","$ctx.state = ($__placeholder__0) ? $__placeholder__1 : $__placeholder__2;\n        break","Promise.resolve($__placeholder__0).then(\n          $ctx.createCallback($__placeholder__1), $ctx.errback);\n          return;","$ctx.value","$ctx.returnValue = $__placeholder__0","return $ctx.end()","var $arguments = arguments;"]} | ||
//# sourceURL=xcode.js | ||
exports.getPath = getPath; | ||
exports.getVersion = getVersion; | ||
exports.getAutomationTraceTemplatePath = getAutomationTraceTemplatePath; | ||
exports.getMaxIOSSDK = getMaxIOSSDK; | ||
exports.getAutomationTraceTemplatePathWithoutRetry = getAutomationTraceTemplatePathWithoutRetry; | ||
exports.getMaxIOSSDKWithoutRetry = getMaxIOSSDKWithoutRetry; | ||
exports.clearInternalCache = clearInternalCache; | ||
// Xcode < 5.x (?) | ||
// xcode-select allows users to override its settings with the DEVELOPER_DIR env var, | ||
// so check that first | ||
// We should only get here is we failed to capture xcode-select's stdout and our | ||
// other checks failed. Either Apple has moved the symlink to a new location or the user | ||
// is not using the default install. 99.999% chance it's the latter, so issue a warning | ||
// should we ever hit the edge case. | ||
// trim and remove trailing slash | ||
// we want to read the CFBundleShortVersionString from Xcode's plist. | ||
// It should be in /[root]/XCode.app/Contents/ | ||
// need to use string#match here; previous code used regexp#exec, which does not return null | ||
// for ios 8 and up, the file extension for AutiomationInstrument changed. | ||
// rather than waste time getting the iOSSDKVersion, just get both paths and see which one exists | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["lib/xcode.js"],"names":[],"mappings":"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","file":"lib/xcode.js","sourcesContent":["import npmlog from 'npmlog';\nimport support from 'appium-support';\nimport fs from 'fs';\nimport denodeify from 'denodeify';\nimport path from 'path';\nimport { retry } from 'asyncbox';\nimport _ from 'lodash';\n\nconst exec = support.core.exec;\nconst util = support.util;\nconst fileExists = support.util.fileExists;\nconst escapeSpace = support.util.escapeSpace;\nconst readSymlink = denodeify(fs.readlink);\nconst env = process.env;\n\nconst XCODE_SELECT_TIMEOUT = 3000;\nconst XCODE_SUBDIR = \"/Contents/Developer\";\nconst DEFAULT_NUMBER_OF_RETRIES = 3;\n\nconst log = process.env.GLOBAL_NPMLOG ? global.log : npmlog;\n\n\nfunction hasExpectedSubDir (path) {\n  return path.substring(path.length - XCODE_SUBDIR.length) === XCODE_SUBDIR;\n}\n\nasync function getPathFromSymlink (failMessage) {\n  // Node's invocation of xcode-select sometimes flakes and returns an empty string.\n  // Not clear why. As a workaround, Appium can reliably deduce the version in use by checking\n  // the locations xcode-select uses to store the selected version's path. This should be 100%\n  // reliable so long as the link locations remain the same. However, since we're relying on\n  // hardcoded paths, this approach will break the next time Apple changes the symlink location.\n  log.warn(`Finding XcodePath by symlink because ${failMessage}`);\n\n  const symlinkPath = \"/var/db/xcode_select_link\";\n  const legacySymlinkPath = \"/usr/share/xcode-select/xcode_dir_path\"; //  Xcode < 5.x (?)\n\n  // xcode-select allows users to override its settings with the DEVELOPER_DIR env var,\n  // so check that first\n  if (util.hasContent(env.DEVELOPER_DIR)) {\n    const customPath = hasExpectedSubDir(env.DEVELOPER_DIR) ?\n                                         env.DEVELOPER_DIR  :\n                                         env.DEVELOPER_DIR + XCODE_SUBDIR;\n\n    if (await fileExists(customPath)) {\n      return customPath;\n    } else {\n      let mesg = `Could not find path to Xcode, environment variable ` +\n                 `DEVELOPER_DIR set to: ${env.DEVELOPER_DIR} ` +\n                 `but no Xcode found`;\n      log.warn(mesg);\n      throw new Error(mesg);\n    }\n  }\n\n\n  if (await fileExists(symlinkPath)) {\n    return readSymlink(symlinkPath);\n  }\n\n  if (await fileExists(legacySymlinkPath)) {\n    return readSymlink(legacySymlinkPath);\n  }\n\n  // We should only get here is we failed to capture xcode-select's stdout and our\n  // other checks failed. Either Apple has moved the symlink to a new location or the user\n  // is not using the default install. 99.999% chance it's the latter, so issue a warning\n  // should we ever hit the edge case.\n  let msg = `Could not find path to Xcode by symlinks located in ${symlinkPath}, or ${legacySymlinkPath}`;\n  log.warn(msg);\n  throw new Error(msg);\n\n}\n\nasync function getPathFromXcodeSelect () {\n\n  let [stdout] = await exec('xcode-select --print-path', {maxBuffer: 524288, timeout: XCODE_SELECT_TIMEOUT});\n\n  // trim and remove trailing slash\n  const xcodeFolderPath = stdout.replace(new RegExp(\"/$\"), \"\").trim();\n\n  if (!util.hasContent(xcodeFolderPath)) {\n    throw new Error(\"xcode-select returned an empty string\");\n  }\n\n  if (await fileExists(xcodeFolderPath)) {\n    return xcodeFolderPath;\n  } else {\n    const msg = `xcode-select could not find xcode. Path: ${xcodeFolderPath} does not exist.`;\n    log.error(msg);\n    throw new Error(msg);\n  }\n}\n\nconst getPath = _.memoize(function () {\n\n  // first we try using xcode-select to find the path\n  // then we try using the symlinks that Apple has by default\n\n  return getPathFromXcodeSelect().catch(getPathFromSymlink);\n});\n\n\n\nasync function getVersionWithoutRetry () {\n\n  let xcodePath = await getPath();\n\n  // we want to read the CFBundleShortVersionString from Xcode's plist.\n  // It should be in /[root]/XCode.app/Contents/\n  const plistPath = xcodePath.replace(XCODE_SUBDIR, \"/Contents/Info.plist\");\n\n  if (!await fileExists(plistPath)) {\n    throw new Error(`Could not get Xcode version. ${plistPath} does not exist on disk.`);\n  }\n\n  const cmd = `/usr/libexec/PlistBuddy -c 'Print CFBundleShortVersionString' ${escapeSpace(plistPath)}`;\n  let [stdout] = await exec(cmd, {maxBuffer: 524288, timeout: XCODE_SELECT_TIMEOUT});\n\n  let versionPattern = /\\d\\.\\d\\.*\\d*/;\n  // need to use string#match here; previous code used regexp#exec, which does not return null\n  let match = stdout.match(versionPattern);\n  if (match === null || !util.hasContent(match[0])) {\n    throw new Error(`Could not parse Xcode version. xcodebuild output was: ${stdout}`);\n  }\n\n  return match[0];\n}\n\n\nconst getVersion = _.memoize(\n  function (retries = DEFAULT_NUMBER_OF_RETRIES) {\n    return retry(retries, getVersionWithoutRetry);\n  }\n);\n\nasync function getAutomationTraceTemplatePathWithoutRetry () {\n\n  const xcodePath = await getPath();\n\n  // for ios 8 and up, the file extension for AutiomationInstrument changed.\n  // rather than waste time getting the iOSSDKVersion, just get both paths and see which one exists\n  const extensions = ['xrplugin', 'bundle'];\n  const pathPrefix = path.resolve(xcodePath, \"../Applications/Instruments.app/Contents/PlugIns\");\n  const pathSuffix = \"Contents/Resources/Automation.tracetemplate\";\n  let automationTraceTemplatePaths = [\n    path.resolve(pathPrefix, \"AutomationInstrument.\" + extensions[0], pathSuffix),\n    path.resolve(pathPrefix, \"AutomationInstrument.\" + extensions[1], pathSuffix)\n  ];\n\n  if (await fileExists(automationTraceTemplatePaths[0])) {\n    return automationTraceTemplatePaths[0];\n  }\n\n  if (await fileExists(automationTraceTemplatePaths[1])) {\n    return automationTraceTemplatePaths[1];\n  }\n\n  const msg = \"Could not find Automation.tracetemplate in any of the following\" +\n              `locations ${automationTraceTemplatePaths.toString()}`;\n  log.error(msg);\n  throw new Error(msg);\n\n}\n\nconst getAutomationTraceTemplatePath = _.memoize(\n  function (retries = DEFAULT_NUMBER_OF_RETRIES) {\n    return retry(retries, getAutomationTraceTemplatePathWithoutRetry);\n  }\n);\n\n// TODO remove this function. should really just be using 'getVersion()' everywhere.\n// This was added for tech-debt backwards compatibility\nasync function getMaxIOSSDKWithoutRetry () {\n\n  const version = await getVersion();\n\n  if (version === '4') {\n    return '6.1';\n  }\n\n  const cmd = `xcrun --sdk iphonesimulator --show-sdk-version`;\n  const [stdout] = await exec(cmd, {maxBuffer: 524288, timeout: XCODE_SELECT_TIMEOUT});\n\n  const sdkVersion = stdout.trim();\n  const match = /\\d.\\d/.exec(stdout);\n\n  if (!match) {\n    throw new Error(`xcrun returned a non-numeric iOS SDK version: ${sdkVersion}`);\n  }\n\n  return sdkVersion;\n}\n\nconst getMaxIOSSDK = _.memoize(\n  function (retries = DEFAULT_NUMBER_OF_RETRIES) {\n    return retry(retries, getMaxIOSSDKWithoutRetry);\n  }\n);\n\nfunction clearInternalCache () {\n\n  // memoized functions\n  const memoized = [getPath, getVersion, getAutomationTraceTemplatePath,\n                    getMaxIOSSDK];\n\n  memoized.forEach((f) => {\n    if (f.cache) {\n      f.cache = new _.memoize.Cache();\n    }\n  });\n\n\n}\n\nexport { getPath, getVersion, getAutomationTraceTemplatePath, getMaxIOSSDK,\n         getAutomationTraceTemplatePathWithoutRetry, getMaxIOSSDKWithoutRetry,\n         clearInternalCache };\n"]} |
@@ -1,201 +0,207 @@ | ||
"use strict"; | ||
var $___46__46__47_lib_47_xcode__, | ||
$__chai__, | ||
$__chai_45_as_45_promised__, | ||
$__mochawait__, | ||
$__fs__, | ||
$__denodeify__, | ||
$__lodash__; | ||
require('appium-transpile-runtime'); | ||
var xcode = ($___46__46__47_lib_47_xcode__ = require("../lib/xcode"), $___46__46__47_lib_47_xcode__ && $___46__46__47_lib_47_xcode__.__esModule && $___46__46__47_lib_47_xcode__ || {default: $___46__46__47_lib_47_xcode__}); | ||
var chai = ($__chai__ = require("chai"), $__chai__ && $__chai__.__esModule && $__chai__ || {default: $__chai__}).default; | ||
var chaiAsPromised = ($__chai_45_as_45_promised__ = require("chai-as-promised"), $__chai_45_as_45_promised__ && $__chai_45_as_45_promised__.__esModule && $__chai_45_as_45_promised__ || {default: $__chai_45_as_45_promised__}).default; | ||
($__mochawait__ = require("mochawait"), $__mochawait__ && $__mochawait__.__esModule && $__mochawait__ || {default: $__mochawait__}); | ||
var fs = ($__fs__ = require("fs"), $__fs__ && $__fs__.__esModule && $__fs__ || {default: $__fs__}).default; | ||
var denodeify = ($__denodeify__ = require("denodeify"), $__denodeify__ && $__denodeify__.__esModule && $__denodeify__ || {default: $__denodeify__}).default; | ||
var _ = ($__lodash__ = require("lodash"), $__lodash__ && $__lodash__.__esModule && $__lodash__ || {default: $__lodash__}).default; | ||
var should = chai.should(); | ||
chai.use(chaiAsPromised); | ||
var fileExists = denodeify(fs.stat); | ||
describe('xcode @skip-linux', (function() { | ||
it('should get the path to xcode executable', function() { | ||
'use strict'; | ||
var _regeneratorRuntime = require('babel-runtime/regenerator')['default']; | ||
var _interopRequireWildcard = require('babel-runtime/helpers/interop-require-wildcard')['default']; | ||
var _this = this; | ||
var _import = require('../lib/xcode'); | ||
var xcode = _interopRequireWildcard(_import); | ||
var _chai = require('chai'); | ||
var _chai2 = _interopRequireWildcard(_chai); | ||
var _chaiAsPromised = require('chai-as-promised'); | ||
var _chaiAsPromised2 = _interopRequireWildcard(_chaiAsPromised); | ||
require('mochawait'); | ||
var _fs = require('fs'); | ||
var _fs2 = _interopRequireWildcard(_fs); | ||
var _denodeify = require('denodeify'); | ||
var _denodeify2 = _interopRequireWildcard(_denodeify); | ||
var _import2 = require('lodash'); | ||
var _import3 = _interopRequireWildcard(_import2); | ||
require('source-map-support').install(); | ||
var should = _chai2['default'].should(); | ||
_chai2['default'].use(_chaiAsPromised2['default']); | ||
var fileExists = _denodeify2['default'](_fs2['default'].stat); | ||
describe('xcode @skip-linux', function () { | ||
it('should get the path to xcode executable', function callee$1$0() { | ||
var path; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
Promise.resolve(xcode.getPath()).then($ctx.createCallback(3), $ctx.errback); | ||
return; | ||
case 3: | ||
path = $ctx.value; | ||
$ctx.state = 2; | ||
break; | ||
case 2: | ||
should.exist(path); | ||
$ctx.state = 7; | ||
break; | ||
case 7: | ||
Promise.resolve(fileExists(path)).then($ctx.createCallback(-2), $ctx.errback); | ||
return; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) { | ||
while (1) switch (context$2$0.prev = context$2$0.next) { | ||
case 0: | ||
context$2$0.next = 2; | ||
return xcode.getPath(); | ||
case 2: | ||
path = context$2$0.sent; | ||
should.exist(path); | ||
context$2$0.next = 6; | ||
return fileExists(path); | ||
case 6: | ||
case 'end': | ||
return context$2$0.stop(); | ||
} | ||
}, null, this); | ||
}); | ||
it('should get the version of xcode', function() { | ||
it('should get the version of xcode', function callee$1$1() { | ||
var version; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
Promise.resolve(xcode.getVersion()).then($ctx.createCallback(3), $ctx.errback); | ||
return; | ||
case 3: | ||
version = $ctx.value; | ||
$ctx.state = 2; | ||
break; | ||
case 2: | ||
should.exist(version); | ||
_.isString(version).should.be.true; | ||
/\d\.\d\.*\d*/.test(version).should.be.true; | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
return _regeneratorRuntime.async(function callee$1$1$(context$2$0) { | ||
while (1) switch (context$2$0.prev = context$2$0.next) { | ||
case 0: | ||
context$2$0.next = 2; | ||
return xcode.getVersion(); | ||
case 2: | ||
version = context$2$0.sent; | ||
should.exist(version); | ||
_import3['default'].isString(version).should.be['true']; | ||
/\d\.\d\.*\d*/.test(version).should.be['true']; | ||
case 6: | ||
case 'end': | ||
return context$2$0.stop(); | ||
} | ||
}, null, this); | ||
}); | ||
it('should get the path and version again, these values are cached', function() { | ||
var before, | ||
path, | ||
after, | ||
version; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
Promise.resolve(xcode.getPath()).then($ctx.createCallback(2), $ctx.errback); | ||
return; | ||
case 2: | ||
Promise.resolve(xcode.getVersion()).then($ctx.createCallback(4), $ctx.errback); | ||
return; | ||
case 4: | ||
before = new Date(); | ||
$ctx.state = 14; | ||
break; | ||
case 14: | ||
Promise.resolve(xcode.getPath()).then($ctx.createCallback(7), $ctx.errback); | ||
return; | ||
case 7: | ||
path = $ctx.value; | ||
$ctx.state = 6; | ||
break; | ||
case 6: | ||
after = new Date(); | ||
should.exist(path); | ||
$ctx.state = 16; | ||
break; | ||
case 16: | ||
Promise.resolve(fileExists(path)).then($ctx.createCallback(9), $ctx.errback); | ||
return; | ||
case 9: | ||
(after - before).should.be.at.most(2); | ||
before = new Date(); | ||
$ctx.state = 18; | ||
break; | ||
case 18: | ||
Promise.resolve(xcode.getVersion()).then($ctx.createCallback(12), $ctx.errback); | ||
return; | ||
case 12: | ||
version = $ctx.value; | ||
$ctx.state = 11; | ||
break; | ||
case 11: | ||
after = new Date(); | ||
should.exist(version); | ||
_.isString(version).should.be.true; | ||
/\d\.\d\.*\d*/.test(version).should.be.true; | ||
(after - before).should.be.at.most(2); | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
it('should get the path and version again, these values are cached', function callee$1$2() { | ||
var before, path, after, version; | ||
return _regeneratorRuntime.async(function callee$1$2$(context$2$0) { | ||
while (1) switch (context$2$0.prev = context$2$0.next) { | ||
case 0: | ||
context$2$0.next = 2; | ||
return xcode.getPath(); | ||
case 2: | ||
context$2$0.next = 4; | ||
return xcode.getVersion(); | ||
case 4: | ||
before = new Date(); | ||
context$2$0.next = 7; | ||
return xcode.getPath(); | ||
case 7: | ||
path = context$2$0.sent; | ||
after = new Date(); | ||
should.exist(path); | ||
context$2$0.next = 12; | ||
return fileExists(path); | ||
case 12: | ||
(after - before).should.be.at.most(2); | ||
before = new Date(); | ||
context$2$0.next = 16; | ||
return xcode.getVersion(); | ||
case 16: | ||
version = context$2$0.sent; | ||
after = new Date(); | ||
should.exist(version); | ||
_import3['default'].isString(version).should.be['true']; | ||
/\d\.\d\.*\d*/.test(version).should.be['true']; | ||
(after - before).should.be.at.most(2); | ||
case 22: | ||
case 'end': | ||
return context$2$0.stop(); | ||
} | ||
}, null, this); | ||
}); | ||
it('should clear the cache if asked to', function() { | ||
var before, | ||
after; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
xcode.clearInternalCache(); | ||
before = new Date(); | ||
$ctx.state = 4; | ||
break; | ||
case 4: | ||
Promise.resolve(xcode.getPath()).then($ctx.createCallback(2), $ctx.errback); | ||
return; | ||
case 2: | ||
after = new Date(); | ||
(after - before).should.be.at.least(7); | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
it('should clear the cache if asked to', function callee$1$3() { | ||
var before, after; | ||
return _regeneratorRuntime.async(function callee$1$3$(context$2$0) { | ||
while (1) switch (context$2$0.prev = context$2$0.next) { | ||
case 0: | ||
xcode.clearInternalCache(); | ||
before = new Date(); | ||
context$2$0.next = 4; | ||
return xcode.getPath(); | ||
case 4: | ||
after = new Date(); | ||
(after - before).should.be.at.least(7); | ||
case 6: | ||
case 'end': | ||
return context$2$0.stop(); | ||
} | ||
}, null, this); | ||
}); | ||
it('should find the automation trace template', (function() { | ||
var path, | ||
suffix; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
Promise.resolve(xcode.getAutomationTraceTemplatePath()).then($ctx.createCallback(3), $ctx.errback); | ||
return; | ||
case 3: | ||
path = $ctx.value; | ||
$ctx.state = 2; | ||
break; | ||
case 2: | ||
should.exist(path); | ||
fileExists(path).should.eventually.be.true; | ||
suffix = ".tracetemplate"; | ||
path.slice(-suffix.length).should.equal(suffix); | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
})); | ||
it('should get max iOS SDK version', (function() { | ||
it('should find the automation trace template', function callee$1$4() { | ||
var path, suffix; | ||
return _regeneratorRuntime.async(function callee$1$4$(context$2$0) { | ||
while (1) switch (context$2$0.prev = context$2$0.next) { | ||
case 0: | ||
context$2$0.next = 2; | ||
return xcode.getAutomationTraceTemplatePath(); | ||
case 2: | ||
path = context$2$0.sent; | ||
should.exist(path); | ||
fileExists(path).should.eventually.be['true']; | ||
suffix = '.tracetemplate'; | ||
path.slice(-suffix.length).should.equal(suffix); | ||
case 7: | ||
case 'end': | ||
return context$2$0.stop(); | ||
} | ||
}, null, _this); | ||
}); | ||
it('should get max iOS SDK version', function callee$1$5() { | ||
var version; | ||
return $traceurRuntime.asyncWrap(function($ctx) { | ||
while (true) | ||
switch ($ctx.state) { | ||
case 0: | ||
Promise.resolve(xcode.getMaxIOSSDK()).then($ctx.createCallback(3), $ctx.errback); | ||
return; | ||
case 3: | ||
version = $ctx.value; | ||
$ctx.state = 2; | ||
break; | ||
case 2: | ||
should.exist(version); | ||
(typeof version).should.equal('string'); | ||
(parseFloat(version) - 6.1).should.be.at.least(0); | ||
$ctx.state = -2; | ||
break; | ||
default: | ||
return $ctx.end(); | ||
} | ||
}, this); | ||
})); | ||
})); | ||
return _regeneratorRuntime.async(function callee$1$5$(context$2$0) { | ||
while (1) switch (context$2$0.prev = context$2$0.next) { | ||
case 0: | ||
context$2$0.next = 2; | ||
return xcode.getMaxIOSSDK(); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xcode-specs.js","sources":["xcode-specs.js","@traceur/generated/TemplateParser/2","@traceur/generated/TemplateParser/15","@traceur/generated/TemplateParser/8","@traceur/generated/TemplateParser/14","@traceur/generated/TemplateParser/12","@traceur/generated/TemplateParser/9","@traceur/generated/TemplateParser/13"],"names":[],"mappings":"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","sourceRoot":"/Users/jonahss/Workspace/appium-xcode/test/","sourcesContent":["/*# sourceMappingURL=path/to/source.map*/\nrequire('appium-transpile-runtime');\nimport * as xcode from '../lib/xcode';\nimport chai from 'chai';\nimport chaiAsPromised from 'chai-as-promised';\nimport 'mochawait';\nimport fs from 'fs';\nimport denodeify from 'denodeify';\nimport _ from 'lodash';\n\nlet should = chai.should();\nchai.use(chaiAsPromised);\n\nlet fileExists = denodeify(fs.stat);\n\ndescribe('xcode @skip-linux', () => {\n\n  it('should get the path to xcode executable', async function () {\n\n    let path = await xcode.getPath();\n    should.exist(path);\n    await fileExists(path);\n\n  });\n\n  it('should get the version of xcode', async function () {\n\n    let version = await xcode.getVersion();\n    should.exist(version);\n    _.isString(version).should.be.true;\n    /\\d\\.\\d\\.*\\d*/.test(version).should.be.true;\n  });\n\n  it('should get the path and version again, these values are cached', async function () {\n\n    await xcode.getPath();\n    await xcode.getVersion();\n\n    let before = new Date();\n    let path = await xcode.getPath();\n    let after = new Date();\n\n    should.exist(path);\n    await fileExists(path);\n    (after-before).should.be.at.most(2);\n\n    before = new Date();\n    let version = await xcode.getVersion();\n    after = new Date();\n\n    should.exist(version);\n    _.isString(version).should.be.true;\n    /\\d\\.\\d\\.*\\d*/.test(version).should.be.true;\n    (after-before).should.be.at.most(2);\n\n  });\n\n  it('should clear the cache if asked to', async function () {\n\n    xcode.clearInternalCache();\n\n    let before = new Date();\n    await xcode.getPath();\n    let after = new Date();\n    (after-before).should.be.at.least(7);\n\n  });\n\n  it('should find the automation trace template', async () => {\n    let path = await xcode.getAutomationTraceTemplatePath();\n\n    should.exist(path);\n    fileExists(path).should.eventually.be.true;\n    let suffix = \".tracetemplate\";\n    path.slice(-suffix.length).should.equal(suffix);\n  });\n\n  it('should get max iOS SDK version', async() => {\n    let version = await xcode.getMaxIOSSDK();\n\n    should.exist(version);\n    (typeof version).should.equal('string');\n    (parseFloat(version)-6.1).should.be.at.least(0);\n  });\n\n});\n","($__placeholder__0 = require($__placeholder__1),\n        $__placeholder__2 && $__placeholder__3.__esModule && $__placeholder__4 || {default: $__placeholder__5})","return $__placeholder__0(\n              $__placeholder__1, this);","$traceurRuntime.asyncWrap","function($ctx) {\n      while (true) $__placeholder__0\n    }","Promise.resolve($__placeholder__0).then(\n          $ctx.createCallback($__placeholder__1), $ctx.errback);\n          return;","$ctx.value","return $ctx.end()"]} | ||
//# sourceURL=xcode-specs.js | ||
case 2: | ||
version = context$2$0.sent; | ||
should.exist(version); | ||
(typeof version).should.equal('string'); | ||
(parseFloat(version) - 6.1).should.be.at.least(0); | ||
case 6: | ||
case 'end': | ||
return context$2$0.stop(); | ||
} | ||
}, null, _this); | ||
}); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,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SUFBSSxJQUFJLEVBQUU7O0FBQ3RCLFdBQUMsS0FBSyxHQUFDLE1BQU0sQ0FBQSxDQUFFLE1BQU0sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQzs7Ozs7OztHQUV0QyxDQUFDLENBQUM7O0FBRUgsSUFBRSxDQUFDLDJDQUEyQyxFQUFFO1FBQzFDLElBQUksRUFJSixNQUFNOzs7OztpQkFKTyxLQUFLLENBQUMsOEJBQThCLEVBQUU7OztBQUFuRCxjQUFJOztBQUVSLGdCQUFNLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQ25CLG9CQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxFQUFFLFFBQUssQ0FBQztBQUN2QyxnQkFBTSxHQUFHLGdCQUFnQjs7QUFDN0IsY0FBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDOzs7Ozs7O0dBQ2pELENBQUMsQ0FBQzs7QUFFSCxJQUFFLENBQUMsZ0NBQWdDLEVBQUU7UUFDL0IsT0FBTzs7Ozs7aUJBQVMsS0FBSyxDQUFDLFlBQVksRUFBRTs7O0FBQXBDLGlCQUFPOztBQUVYLGdCQUFNLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0FBQ3RCLFdBQUMsT0FBTyxPQUFPLENBQUEsQ0FBRSxNQUFNLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBQ3hDLFdBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxHQUFDLEdBQUcsQ0FBQSxDQUFFLE1BQU0sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQzs7Ozs7OztHQUNqRCxDQUFDLENBQUM7Q0FFSixDQUFDLENBQUMiLCJmaWxlIjoidGVzdC94Y29kZS1zcGVjcy5qcyIsInNvdXJjZXNDb250ZW50IjpbInJlcXVpcmUoJ3NvdXJjZS1tYXAtc3VwcG9ydCcpLmluc3RhbGwoKTtcblxuaW1wb3J0ICogYXMgeGNvZGUgZnJvbSAnLi4vbGliL3hjb2RlJztcbmltcG9ydCBjaGFpIGZyb20gJ2NoYWknO1xuaW1wb3J0IGNoYWlBc1Byb21pc2VkIGZyb20gJ2NoYWktYXMtcHJvbWlzZWQnO1xuaW1wb3J0ICdtb2NoYXdhaXQnO1xuaW1wb3J0IGZzIGZyb20gJ2ZzJztcbmltcG9ydCBkZW5vZGVpZnkgZnJvbSAnZGVub2RlaWZ5JztcbmltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5cbmxldCBzaG91bGQgPSBjaGFpLnNob3VsZCgpO1xuY2hhaS51c2UoY2hhaUFzUHJvbWlzZWQpO1xuXG5sZXQgZmlsZUV4aXN0cyA9IGRlbm9kZWlmeShmcy5zdGF0KTtcblxuZGVzY3JpYmUoJ3hjb2RlIEBza2lwLWxpbnV4JywgKCkgPT4ge1xuXG4gIGl0KCdzaG91bGQgZ2V0IHRoZSBwYXRoIHRvIHhjb2RlIGV4ZWN1dGFibGUnLCBhc3luYyBmdW5jdGlvbiAoKSB7XG5cbiAgICBsZXQgcGF0aCA9IGF3YWl0IHhjb2RlLmdldFBhdGgoKTtcbiAgICBzaG91bGQuZXhpc3QocGF0aCk7XG4gICAgYXdhaXQgZmlsZUV4aXN0cyhwYXRoKTtcblxuICB9KTtcblxuICBpdCgnc2hvdWxkIGdldCB0aGUgdmVyc2lvbiBvZiB4Y29kZScsIGFzeW5jIGZ1bmN0aW9uICgpIHtcblxuICAgIGxldCB2ZXJzaW9uID0gYXdhaXQgeGNvZGUuZ2V0VmVyc2lvbigpO1xuICAgIHNob3VsZC5leGlzdCh2ZXJzaW9uKTtcbiAgICBfLmlzU3RyaW5nKHZlcnNpb24pLnNob3VsZC5iZS50cnVlO1xuICAgIC9cXGRcXC5cXGRcXC4qXFxkKi8udGVzdCh2ZXJzaW9uKS5zaG91bGQuYmUudHJ1ZTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCBnZXQgdGhlIHBhdGggYW5kIHZlcnNpb24gYWdhaW4sIHRoZXNlIHZhbHVlcyBhcmUgY2FjaGVkJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuXG4gICAgYXdhaXQgeGNvZGUuZ2V0UGF0aCgpO1xuICAgIGF3YWl0IHhjb2RlLmdldFZlcnNpb24oKTtcblxuICAgIGxldCBiZWZvcmUgPSBuZXcgRGF0ZSgpO1xuICAgIGxldCBwYXRoID0gYXdhaXQgeGNvZGUuZ2V0UGF0aCgpO1xuICAgIGxldCBhZnRlciA9IG5ldyBEYXRlKCk7XG5cbiAgICBzaG91bGQuZXhpc3QocGF0aCk7XG4gICAgYXdhaXQgZmlsZUV4aXN0cyhwYXRoKTtcbiAgICAoYWZ0ZXItYmVmb3JlKS5zaG91bGQuYmUuYXQubW9zdCgyKTtcblxuICAgIGJlZm9yZSA9IG5ldyBEYXRlKCk7XG4gICAgbGV0IHZlcnNpb24gPSBhd2FpdCB4Y29kZS5nZXRWZXJzaW9uKCk7XG4gICAgYWZ0ZXIgPSBuZXcgRGF0ZSgpO1xuXG4gICAgc2hvdWxkLmV4aXN0KHZlcnNpb24pO1xuICAgIF8uaXNTdHJpbmcodmVyc2lvbikuc2hvdWxkLmJlLnRydWU7XG4gICAgL1xcZFxcLlxcZFxcLipcXGQqLy50ZXN0KHZlcnNpb24pLnNob3VsZC5iZS50cnVlO1xuICAgIChhZnRlci1iZWZvcmUpLnNob3VsZC5iZS5hdC5tb3N0KDIpO1xuXG4gIH0pO1xuXG4gIGl0KCdzaG91bGQgY2xlYXIgdGhlIGNhY2hlIGlmIGFza2VkIHRvJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuXG4gICAgeGNvZGUuY2xlYXJJbnRlcm5hbENhY2hlKCk7XG5cbiAgICBsZXQgYmVmb3JlID0gbmV3IERhdGUoKTtcbiAgICBhd2FpdCB4Y29kZS5nZXRQYXRoKCk7XG4gICAgbGV0IGFmdGVyID0gbmV3IERhdGUoKTtcbiAgICAoYWZ0ZXItYmVmb3JlKS5zaG91bGQuYmUuYXQubGVhc3QoNyk7XG5cbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCBmaW5kIHRoZSBhdXRvbWF0aW9uIHRyYWNlIHRlbXBsYXRlJywgYXN5bmMgKCkgPT4ge1xuICAgIGxldCBwYXRoID0gYXdhaXQgeGNvZGUuZ2V0QXV0b21hdGlvblRyYWNlVGVtcGxhdGVQYXRoKCk7XG5cbiAgICBzaG91bGQuZXhpc3QocGF0aCk7XG4gICAgZmlsZUV4aXN0cyhwYXRoKS5zaG91bGQuZXZlbnR1YWxseS5iZS50cnVlO1xuICAgIGxldCBzdWZmaXggPSBcIi50cmFjZXRlbXBsYXRlXCI7XG4gICAgcGF0aC5zbGljZSgtc3VmZml4Lmxlbmd0aCkuc2hvdWxkLmVxdWFsKHN1ZmZpeCk7XG4gIH0pO1xuXG4gIGl0KCdzaG91bGQgZ2V0IG1heCBpT1MgU0RLIHZlcnNpb24nLCBhc3luYygpID0+IHtcbiAgICBsZXQgdmVyc2lvbiA9IGF3YWl0IHhjb2RlLmdldE1heElPU1NESygpO1xuXG4gICAgc2hvdWxkLmV4aXN0KHZlcnNpb24pO1xuICAgICh0eXBlb2YgdmVyc2lvbikuc2hvdWxkLmVxdWFsKCdzdHJpbmcnKTtcbiAgICAocGFyc2VGbG9hdCh2ZXJzaW9uKS02LjEpLnNob3VsZC5iZS5hdC5sZWFzdCgwKTtcbiAgfSk7XG5cbn0pO1xuIl19 |
"use strict"; | ||
var gulp = require('gulp'), | ||
merge = require('merge-stream'), | ||
mocha = require('gulp-mocha'), | ||
Q = require('q'), | ||
spawnWatcher = require('appium-gulp-plugins').spawnWatcher.use(gulp), | ||
Transpiler = require('appium-gulp-plugins').Transpiler, | ||
runSequence = Q.denodeify(require('run-sequence')), | ||
jshint = require('gulp-jshint'), | ||
jscs = require('gulp-jscs'), | ||
vinylPaths = require('vinyl-paths'), | ||
del = require('del'); | ||
boilerplate = require('appium-gulp-plugins').boilerplate.use(gulp); | ||
var argv = require('yargs') | ||
.count('prod') | ||
.argv; | ||
gulp.task('clean', function () { | ||
return gulp.src('build', {read: false}) | ||
.pipe(vinylPaths(del)); | ||
}); | ||
gulp.task('transpile', function () { | ||
var transpiler = new Transpiler(); | ||
if (!argv.prod) { | ||
transpiler.traceurOpts.typeAssertions = true; | ||
transpiler.traceurOpts.typeAssertionModule = 'rtts-assert'; | ||
} | ||
var index = gulp.src('index.js') | ||
.pipe(transpiler.stream()) | ||
.on('error', spawnWatcher.handleError) | ||
.pipe(gulp.dest('build')); | ||
var lib = gulp.src('lib/**/*.js') | ||
.pipe(transpiler.stream()) | ||
.on('error', spawnWatcher.handleError) | ||
.pipe(gulp.dest('build/lib')); | ||
var test = gulp.src('test/**/*.js') | ||
.pipe(transpiler.stream()) | ||
.on('error', spawnWatcher.handleError) | ||
.pipe(gulp.dest('build/test')); | ||
return merge(index, lib, test); | ||
}); | ||
gulp.task('jscs', function () { | ||
return gulp | ||
.src(['gulpfile.js']) | ||
.pipe(jscs()) | ||
.on('error', spawnWatcher.handleError); | ||
}); | ||
gulp.task('jshint', function () { | ||
return gulp | ||
.src(['*.js', 'lib/**/*.js', 'test/**/*.js']) | ||
.pipe(jshint()) | ||
.pipe(jshint.reporter('jshint-stylish')) | ||
.pipe(jshint.reporter('fail')) | ||
.on('error', spawnWatcher.handleError); | ||
}); | ||
gulp.task('lint',['jshint','jscs']); | ||
gulp.task('test', ['transpile'], function () { | ||
process.env.SKIP_TRACEUR_RUNTIME = true; | ||
return gulp | ||
.src('build/test/**/*-specs.js', {read: false}) | ||
.pipe(mocha({reporter: 'nyan'})) | ||
.on('error', spawnWatcher.handleError); | ||
}); | ||
process.env.APPIUM_NOTIF_BUILD_NAME = 'appium-xcode'; | ||
spawnWatcher.configure('watch', ['index.js', 'lib/**/*.js','test/**/*.js'], function () { | ||
return runSequence('clean', 'lint', 'transpile', 'test'); | ||
}); | ||
gulp.task('prepublish', function () { | ||
return runSequence('clean', 'transpile'); | ||
}); | ||
gulp.task('once', function () { | ||
return runSequence('clean','lint', 'transpile','test'); | ||
}); | ||
gulp.task('default', ['watch']); | ||
boilerplate({build: "Appium Xcode", jscs: false}); |
@@ -132,3 +132,3 @@ import npmlog from 'npmlog'; | ||
const getVersion = _.memoize( | ||
async function (retries = DEFAULT_NUMBER_OF_RETRIES) { | ||
function (retries = DEFAULT_NUMBER_OF_RETRIES) { | ||
return retry(retries, getVersionWithoutRetry); | ||
@@ -168,3 +168,3 @@ } | ||
const getAutomationTraceTemplatePath = _.memoize( | ||
async function (retries = DEFAULT_NUMBER_OF_RETRIES) { | ||
function (retries = DEFAULT_NUMBER_OF_RETRIES) { | ||
return retry(retries, getAutomationTraceTemplatePathWithoutRetry); | ||
@@ -171,0 +171,0 @@ } |
@@ -7,3 +7,3 @@ { | ||
], | ||
"version": "1.0.2", | ||
"version": "2.0.0", | ||
"author": "appium", | ||
@@ -28,10 +28,9 @@ "license": "Apache License 2.0", | ||
"appium-support": "^1.0.0", | ||
"appium-transpile-runtime": "^0.0.4", | ||
"asyncbox": "^1.0.9", | ||
"chai": "^2.1.2", | ||
"chai-as-promised": "^4.3.0", | ||
"asyncbox": "^2.0.2", | ||
"babel-runtime": "^5.0.12", | ||
"denodeify": "^1.2.1", | ||
"lodash": "^3.6.0", | ||
"npmlog": "^1.2.0", | ||
"q": "^1.2.0" | ||
"q": "^1.2.0", | ||
"source-map-support": "^0.2.10" | ||
}, | ||
@@ -44,19 +43,8 @@ "scripts": { | ||
"devDependencies": { | ||
"appium-gulp-plugins": "^0.0.10", | ||
"chai": "^1.10.0", | ||
"chai-as-promised": "^4.1.1", | ||
"del": "^1.1.1", | ||
"appium-gulp-plugins": "^1.0.3", | ||
"chai": "^2.2.0", | ||
"chai-as-promised": "^4.3.0", | ||
"gulp": "^3.8.10", | ||
"gulp-jscs": "^1.3.1", | ||
"gulp-jshint": "https://github.com/appium/gulp-jshint/archive/master.tar.gz", | ||
"gulp-mocha": "^2.0.0", | ||
"jshint-stylish": "^1.0.0", | ||
"lodash": "^3.6.0", | ||
"merge-stream": "^0.1.6", | ||
"mocha": "^2.1.0", | ||
"mochawait": "^1.1.0", | ||
"run-sequence": "^1.0.2", | ||
"vinyl-paths": "^1.0.0", | ||
"yargs": "^1.3.3" | ||
"mochawait": "^2.0.0" | ||
} | ||
} |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Native code
Supply chain riskContains native code (e.g., compiled binaries or shared libraries). Including native code can obscure malicious behavior.
Found 3 instances in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Environment variable access
Supply chain riskPackage accesses environment variables, which may be a sign of credential stuffing or data theft.
Found 2 instances in 1 package
Filesystem access
Supply chain riskAccesses the file system, and could potentially read sensitive data.
Found 1 instance in 1 package
8
5
17
8
74029
681
5
+ Addedbabel-runtime@^5.0.12
+ Addedsource-map-support@^0.2.10
+ Added@types/bluebird@3.5.42(transitive)
+ Addedasyncbox@2.9.4(transitive)
+ Addedbabel-runtime@5.8.38(transitive)
+ Addedbluebird@3.7.2(transitive)
+ Addedbuffer-from@1.1.2(transitive)
+ Addedcore-js@1.2.7(transitive)
+ Addedlodash@4.17.21(transitive)
+ Addedsource-map@0.6.1(transitive)
+ Addedsource-map-support@0.5.21(transitive)
- Removedappium-transpile-runtime@^0.0.4
- Removedchai@^2.1.2
- Removedchai-as-promised@^4.3.0
- Removedappium-transpile-runtime@0.0.4(transitive)
- Removedassertion-error@1.0.0(transitive)
- Removedast-types@0.5.7(transitive)
- Removedasyncbox@1.0.9(transitive)
- Removedbalanced-match@1.0.2(transitive)
- Removedbrace-expansion@1.1.11(transitive)
- Removedchai@2.3.0(transitive)
- Removedchai-as-promised@4.3.0(transitive)
- Removedcls@0.1.5(transitive)
- Removedcommander@2.20.3(transitive)
- Removedconcat-map@0.0.1(transitive)
- Removeddeep-eql@0.1.3(transitive)
- Removeddepd@1.0.1(transitive)
- Removedes6-mapify@1.0.2(transitive)
- Removedesprima-fb@7001.1.0-dev-harmony-fb(transitive)
- Removedglob@4.3.54.5.3(transitive)
- Removedinflight@1.0.6(transitive)
- Removedjsesc@0.5.0(transitive)
- Removedminimatch@2.0.10(transitive)
- Removedonce@1.4.0(transitive)
- Removedprivate@0.1.8(transitive)
- Removedrecast@0.8.8(transitive)
- Removedregenerate@1.4.2(transitive)
- Removedregexpu@0.3.0(transitive)
- Removedregjsgen@0.2.0(transitive)
- Removedregjsparser@0.1.5(transitive)
- Removedrsvp@3.6.2(transitive)
- Removedsemver@2.3.2(transitive)
- Removedtraceur@0.0.740.0.79(transitive)
- Removedtype-detect@0.1.1(transitive)
- Removedwrappy@1.0.2(transitive)
Updatedasyncbox@^2.0.2