2015-04-22 16:04:06 -07:00
|
|
|
#!/bin/bash
|
|
|
|
|
2016-06-15 08:52:58 -07:00
|
|
|
set -ex
|
2015-04-22 16:04:06 -07:00
|
|
|
|
|
|
|
SCRIPTS=$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)
|
|
|
|
ROOT=$(dirname $SCRIPTS)
|
|
|
|
|
|
|
|
cd $ROOT
|
|
|
|
|
|
|
|
function cleanup {
|
|
|
|
EXIT_CODE=$?
|
|
|
|
set +e
|
|
|
|
|
|
|
|
if [ $EXIT_CODE -ne 0 ];
|
|
|
|
then
|
|
|
|
WATCHMAN_LOGS=/usr/local/Cellar/watchman/3.1/var/run/watchman/$USER.log
|
|
|
|
[ -f $WATCHMAN_LOGS ] && cat $WATCHMAN_LOGS
|
|
|
|
fi
|
2016-06-15 08:52:58 -07:00
|
|
|
[ $SERVER_PID ] && kill -9 $SERVER_PID
|
2015-04-22 16:04:06 -07:00
|
|
|
}
|
|
|
|
trap cleanup EXIT
|
|
|
|
|
2016-06-15 08:52:58 -07:00
|
|
|
if [ -z "$TRAVIS" ]; then
|
|
|
|
# Run the packager process directly
|
|
|
|
node ./local-cli/cli.js start &
|
|
|
|
SERVER_PID=$!
|
|
|
|
fi
|
|
|
|
|
|
|
|
XCODE_PROJECT="Examples/UIExplorer/UIExplorer.xcodeproj"
|
|
|
|
XCODE_SCHEME="UIExplorer"
|
|
|
|
XCODE_SDK="iphonesimulator"
|
2016-06-08 04:41:15 -07:00
|
|
|
if [ -z "$XCODE_DESTINATION" ]; then
|
|
|
|
XCODE_DESTINATION="platform=iOS Simulator,name=iPhone 5,OS=9.3"
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Support for environments without xcpretty installed
|
|
|
|
set +e
|
|
|
|
OUTPUT_TOOL=$(which xcpretty)
|
|
|
|
set -e
|
|
|
|
|
2016-04-22 23:03:12 -07:00
|
|
|
# TODO: We use xcodebuild because xctool would stall when collecting info about
|
|
|
|
# the tests before running them. Switch back when this issue with xctool has
|
|
|
|
# been resolved.
|
2016-06-15 08:52:58 -07:00
|
|
|
if [ -z "$OUTPUT_TOOL" ]; then
|
|
|
|
xcodebuild \
|
|
|
|
-project $XCODE_PROJECT \
|
|
|
|
-scheme $XCODE_SCHEME \
|
|
|
|
-sdk $XCODE_SDK \
|
|
|
|
-destination "$XCODE_DESTINATION" \
|
|
|
|
test
|
|
|
|
else
|
|
|
|
xcodebuild \
|
|
|
|
-project $XCODE_PROJECT \
|
|
|
|
-scheme $XCODE_SCHEME \
|
|
|
|
-sdk $XCODE_SDK \
|
|
|
|
-destination "$XCODE_DESTINATION" \
|
|
|
|
test | $OUTPUT_TOOL && exit ${PIPESTATUS[0]}
|
|
|
|
fi
|