Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More

appium-xcode

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

appium-xcode - npm Package Compare versions

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"
}
}