2016-06-23 14:50:28 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const chalk = require('chalk');
|
|
|
|
const child_process = require('child_process');
|
|
|
|
const os = require('os');
|
|
|
|
const path = require('path');
|
|
|
|
const Promise = require('promise');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Starts iOS device syslog tail
|
|
|
|
*/
|
|
|
|
function logIOS() {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
_logIOS(resolve, reject);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2016-07-30 15:59:16 +00:00
|
|
|
function _logIOS() {
|
2016-06-23 14:50:28 +00:00
|
|
|
let rawDevices;
|
|
|
|
|
|
|
|
try {
|
|
|
|
rawDevices = child_process.execFileSync(
|
|
|
|
'xcrun', ['simctl', 'list', 'devices', '--json'], {encoding: 'utf8'}
|
|
|
|
);
|
|
|
|
} catch (e) {
|
|
|
|
console.log(chalk.red(
|
|
|
|
'xcrun invocation failed. Please check that Xcode is installed.'
|
|
|
|
));
|
2016-07-30 15:59:16 +00:00
|
|
|
return Promise.reject(e);
|
2016-06-23 14:50:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const { devices } = JSON.parse(rawDevices);
|
|
|
|
|
|
|
|
const device = _findAvailableDevice(devices);
|
|
|
|
if (device === undefined) {
|
|
|
|
console.log(chalk.red(
|
|
|
|
'No active iOS device found'
|
|
|
|
));
|
2016-07-30 15:59:16 +00:00
|
|
|
return Promise.reject();
|
2016-06-23 14:50:28 +00:00
|
|
|
}
|
|
|
|
|
2016-07-30 15:59:16 +00:00
|
|
|
return tailDeviceLogs(device.udid);
|
2016-06-23 14:50:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function _findAvailableDevice(devices) {
|
|
|
|
for (const key of Object.keys(devices)) {
|
|
|
|
for (const device of devices[key]) {
|
|
|
|
if (device.availability === '(available)' && device.state === 'Booted') {
|
|
|
|
return device;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-30 15:59:16 +00:00
|
|
|
function tailDeviceLogs(udid) {
|
2016-06-23 14:50:28 +00:00
|
|
|
const logDir = path.join(
|
|
|
|
os.homedir(),
|
|
|
|
'Library',
|
|
|
|
'Logs',
|
|
|
|
'CoreSimulator',
|
|
|
|
udid,
|
|
|
|
'asl',
|
|
|
|
);
|
|
|
|
|
|
|
|
const log =
|
|
|
|
child_process.spawnSync('syslog', ['-w', '-F', 'std', '-d', logDir], {stdio: 'inherit'});
|
|
|
|
|
|
|
|
if (log.error !== null) {
|
|
|
|
console.log(chalk.red(
|
|
|
|
'syslog invocation failed.'
|
|
|
|
));
|
2016-07-30 15:59:16 +00:00
|
|
|
return Promise.reject(log.error);
|
2016-06-23 14:50:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-30 15:59:16 +00:00
|
|
|
module.exports = {
|
|
|
|
name: 'log-ios',
|
|
|
|
description: 'starts iOS device syslog tail',
|
|
|
|
func: logIOS,
|
|
|
|
};
|