mirror of
https://github.com/status-im/react-native.git
synced 2025-01-11 01:56:26 +00:00
48ab5eb436
Summary: At the moment the run-ios command from the react-native cli does only work for simulators. The pull request adds a new option to the existing command: **"--device 'device-name'" which installs and launches an iOS application on a connected device.** This makes it easier to build a test environment using react-native for connected devices. I've tested my code with the following commands: react-native run-ios --device "Not existing device" react-native run-ios --device react-native run-ios --device "name-of-a-simulator" react-native run-ios --device "name-of-connected-device" Output of the first three commands: ![example_error_output](https://cloud.githubusercontent.com/assets/9102810/17669443/f53d5948-630d-11e6-9a80-7df2f352c6a3.png) Additional to the manual command tests i've added a test file 'parseIOSDevicesList-test.js'. I used **ios-deploy** In order to launch and install the .app-bundle on a connected device. ios-deploy on github: Closes https://github.com/facebook/react-native/pull/9414 Differential Revision: D3821638 Pulled By: javache fbshipit-source-id: c07b7bf25283a966e45613a22ed3184bb1aac714
74 lines
2.4 KiB
JavaScript
74 lines
2.4 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.*
|
|
*/
|
|
'use strict';
|
|
|
|
/**
|
|
* Takes in a parsed simulator list and a desired name, and returns an object with the matching simulator.
|
|
*
|
|
* If the simulatorName argument is null, we'll go into default mode and return the currently booted simulator, or if
|
|
* none is booted, it will be the first in the list.
|
|
*
|
|
* @param Object simulators a parsed list from `xcrun simctl list --json devices` command
|
|
* @param String|null simulatorName the string with the name of desired simulator. If null, it will use the currently
|
|
* booted simulator, or if none are booted, the first in the list.
|
|
* @returns {Object} {udid, name, version}
|
|
*/
|
|
function findMatchingSimulator(simulators, simulatorName) {
|
|
if (!simulators.devices) {
|
|
return null;
|
|
}
|
|
const devices = simulators.devices;
|
|
var match;
|
|
for (let version in devices) {
|
|
// Making sure the version of the simulator is an iOS (Removes Apple Watch, etc)
|
|
if (version.indexOf('iOS') !== 0) {
|
|
continue;
|
|
}
|
|
for (let i in devices[version]) {
|
|
let simulator = devices[version][i];
|
|
// Skipping non-available simulator
|
|
if (simulator.availability !== '(available)') {
|
|
continue;
|
|
}
|
|
// If there is a booted simulator, we'll use that as instruments will not boot a second simulator
|
|
if (simulator.state === 'Booted') {
|
|
if (simulatorName !== null) {
|
|
console.warn("We couldn't boot your defined simulator due to an already booted simulator. We are limited to one simulator launched at a time.");
|
|
}
|
|
return {
|
|
udid: simulator.udid,
|
|
name: simulator.name,
|
|
version
|
|
};
|
|
}
|
|
if (simulator.name === simulatorName) {
|
|
return {
|
|
udid: simulator.udid,
|
|
name: simulator.name,
|
|
version
|
|
};
|
|
}
|
|
// Keeps track of the first available simulator for use if we can't find one above.
|
|
if (simulatorName === null && !match) {
|
|
match = {
|
|
udid: simulator.udid,
|
|
name: simulator.name,
|
|
version
|
|
};
|
|
}
|
|
}
|
|
}
|
|
if (match) {
|
|
return match;
|
|
}
|
|
return null;
|
|
}
|
|
|
|
module.exports = findMatchingSimulator;
|