realm-js/scripts/test.sh

428 lines
11 KiB
Bash
Raw Normal View History

2015-12-17 12:42:02 -08:00
#!/bin/bash
set -o pipefail
set -e
2016-08-19 10:06:45 -07:00
export TEST_SCRIPT=1
export NPM_CONFIG_PROGRESS=false
TARGET=$1
CONFIGURATION=${2:-Release}
2017-09-18 13:23:27 -07:00
if echo "$CONFIGURATION" | grep -i "^Debug$" > /dev/null ; then
2017-03-16 12:15:20 +01:00
CONFIGURATION="Debug"
fi
IOS_SIM_DEVICE=${IOS_SIM_DEVICE:-} # use preferentially, otherwise will be set and re-exported
PATH="/opt/android-sdk-linux/platform-tools:$PATH"
SRCROOT=$(cd "$(dirname "$0")/.." && pwd)
2017-01-02 13:35:45 +01:00
XCPRETTY=$(which xcpretty || true)
CI_RUN=false
if [ -n "${JENKINS_HOME}" ]; then
CI_RUN=true
fi
2016-01-22 13:32:56 -08:00
SIM_DEVICE_NAME=realm-js-test
# Start current working directory at the root of the project.
cd "$SRCROOT"
# Add node_modules to PATH just in case we weren't called from `npm test`
PATH="$PWD/node_modules/.bin:$PATH"
if [[ $TARGET = *-android ]]; then
# Inform the prepublish script to build Android modules.
export REALM_BUILD_ANDROID=1
2016-01-22 13:30:16 -08:00
fi
SERVER_PID=0
PACKAGER_OUT="$SRCROOT/packager_out.txt"
LOGCAT_OUT="$SRCROOT/logcat_out.txt"
die() {
echo "$@" >&2
exit 1
}
download_server() {
echo "test.sh: downloading ROS"
2017-07-12 18:50:37 +02:00
./scripts/download-object-server.sh
}
start_server() {
echo "test.sh: starting ROS"
2017-09-08 19:56:40 +03:00
#disabled ROS logging
# sh ./object-server-for-testing/start-object-server.command &> /dev/null &
2017-09-08 19:56:40 +03:00
#enabled ROS logging
#sh ./object-server-for-testing/start-object-server.command &
2017-11-14 11:43:02 +02:00
export ROS_SKIP_PROMPTS=true && ./node_modules/.bin/ros start --data realm-object-server-data &
SERVER_PID=$!
echo ROS PID: ${SERVER_PID}
}
stop_server() {
echo stopping server
2017-01-02 13:35:45 +01:00
if [[ ${SERVER_PID} -gt 0 ]] ; then
echo server is running. killing it
kill -9 ${SERVER_PID} >/dev/null 2>&1 || true
fi
}
startedSimulator=false
log_temp=
test_temp_dir=
cleanup() {
# Kill started object server
stop_server || true
2017-01-02 13:35:45 +01:00
echo "shutting down running simulators"
shutdown_ios_simulator >/dev/null 2>&1
2018-01-26 17:21:09 +01:00
# Quit Simulator.app to give it a chance to go down gracefully
if $startedSimulator; then
osascript -e 'tell app "Simulator" to quit without saving' || true
sleep 0.25 # otherwise the pkill following will get it too early
fi
2017-01-02 13:35:45 +01:00
# Kill all child processes.
pkill -9 -P $$ || true
# Kill react native packager
pkill -x node || true
rm -f "$PACKAGER_OUT" "$LOGCAT_OUT"
2017-01-02 13:35:45 +01:00
# Cleanup temp files
if [ -n "$log_temp" ] && [ -e "$log_temp" ]; then
rm "$log_temp" || true
fi
if [ -n "$test_temp_dir" ] && [ -e "$test_temp_dir" ]; then
rm -rf "$test_temp_dir" || true
fi
}
2018-01-26 17:21:09 +01:00
open_chrome() {
if [ $CONFIGURATION == 'Release' ]; then
return;
fi
2018-01-26 17:21:09 +01:00
local dir
for dir in "$HOME/Applications" "/Applications"; do
if [ -d "$dir/Google Chrome.app" ]; then
open "$dir/Google Chrome.app"
break
fi
2015-12-17 10:56:08 -08:00
done
}
start_packager() {
2016-03-16 13:30:06 -07:00
watchman watch-del-all || true
2017-11-15 11:59:13 +01:00
./node_modules/react-native/scripts/packager.sh | tee "$PACKAGER_OUT" &
while :; do
2017-11-15 11:59:13 +01:00
if grep -Fxq "Metro Bundler ready." "$PACKAGER_OUT"; then
break
else
echo "Waiting for packager."
sleep 2
fi
done
2016-01-26 20:23:26 +00:00
}
2016-05-13 16:30:57 -07:00
xctest() {
setup_ios_simulator
2017-01-02 13:35:45 +01:00
# - Run the build and test
echo "Building application"
xcrun xcodebuild -scheme "$1" -configuration "$CONFIGURATION" -sdk iphonesimulator -destination id="${IOS_SIM_DEVICE_ID}" -derivedDataPath ./build build || {
EXITCODE=$?
echo "*** Failure (exit code $EXITCODE). ***"
exit $EXITCODE
}
2018-01-26 17:21:09 +01:00
echo "Installing application on ${SIM_DEVICE_NAME}"
echo "Application Path" $(pwd)/build/Build/Products/$CONFIGURATION-iphonesimulator/$1.app
xcrun simctl install ${SIM_DEVICE_NAME} $(pwd)/build/Build/Products/$CONFIGURATION-iphonesimulator/$1.app
2018-01-26 17:21:09 +01:00
echo "Launching application. (output is in $(pwd)/build/out.txt)"
testpid=$(xcrun simctl launch --stdout=$(pwd)/build/out.txt --stderr=$(pwd)/build/err.txt ${SIM_DEVICE_NAME} io.realm.$1 | grep -m1 -o '\d\+$')
tail -n +0 -f $(pwd)/build/out.txt &
stdoutpid=$!
tail -n +0 -f $(pwd)/build/err.txt &
stderrpid=$!
# `kill -0` checks if a signal can be sent to the pid without actually doing so
while kill -0 $testpid 2> /dev/null; do sleep 1; done
kill $stdoutpid
kill $stderrpid
echo "Shuttting down ${SIM_DEVICE_NAME} simulator. (device is not deleted. you can use it to debug the app)"
shutdown_ios_simulator
check_test_results $1
}
check_test_results() {
echo "Checking tests results"
if grep -q "REALM_FAILING_TESTS" $(pwd)/build/out.txt; then
echo "*** REALM JS TESTS FAILED. See tests results above ***"
exit 20
2016-08-19 10:06:45 -07:00
else
echo "*** $1 SUCCESS ***"
fi
}
2018-01-26 17:21:09 +01:00
setup_ios_simulator() {
#try deleting old simulator with same name.
echo "Preparing to create a new simulator"
delete_ios_simulator >/dev/null 2>&1
2017-01-02 13:35:45 +01:00
#parse devices
IOS_RUNTIME=$(xcrun simctl list runtimes | grep -v unavailable | grep -m1 -o 'com.apple.CoreSimulator.SimRuntime.iOS.*' | sed 's/[()]//g')
echo using iOS Runtime ${IOS_RUNTIME} to create new simulator ${SIM_DEVICE_NAME}
2017-01-02 13:35:45 +01:00
#create new test simulator
IOS_SIM_DEVICE_ID=$(xcrun simctl create ${SIM_DEVICE_NAME} com.apple.CoreSimulator.SimDeviceType.iPhone-SE ${IOS_RUNTIME})
#boot new test simulator
xcrun simctl boot ${SIM_DEVICE_NAME}
}
2017-01-02 13:35:45 +01:00
2018-01-26 17:21:09 +01:00
shutdown_ios_simulator() {
#shutdown test simulator
xcrun simctl shutdown ${SIM_DEVICE_NAME} || true
}
2018-01-26 17:21:09 +01:00
delete_ios_simulator() {
shutdown_ios_simulator
#delete test simulator
xcrun simctl delete ${SIM_DEVICE_NAME} || true
}
# Cleanup now and also cleanup when this script exits.
cleanup >/dev/null 2>&1
trap cleanup EXIT
# Use a consistent version of Node if possible.
if [[ -z "$(command -v nvm)" ]]; then
set +e
if [ -f "$NVM_DIR/nvm.sh" ]; then
2017-09-18 19:16:28 -07:00
. "$NVM_DIR/nvm.sh" '' || true
elif [ -x "$(command -v brew)" ] && [ -f "$(brew --prefix nvm)/nvm.sh" ]; then
# we must be on mac and nvm was installed with brew
# TODO: change the mac slaves to use manual nvm installation
2017-09-18 19:16:28 -07:00
. "$(brew --prefix nvm)/nvm.sh" '' || true
elif [ -f "$HOME/.nvm/nvm.sh" ]; then
2017-09-18 19:16:28 -07:00
. ~/.nvm/nvm.sh ''
fi
set -e
2017-09-18 13:23:27 -07:00
fi
if [[ "$(command -v nvm)" ]]; then
2018-03-02 19:43:06 +01:00
nvm install 6.11.3
fi
# Remove cached packages
rm -rf ~/.yarn-cache/npm-realm-*
case "$TARGET" in
"check-environment")
npm run check-environment
;;
"eslint")
[[ $CONFIGURATION == 'Debug' ]] && exit 0
npm run eslint
;;
2016-11-17 16:55:02 +01:00
"eslint-ci")
[[ $CONFIGURATION == 'Debug' ]] && exit 0
npm install
./node_modules/.bin/eslint -f checkstyle . > eslint.xml || true
;;
"license-check")
[[ $CONFIGURATION == 'Debug' ]] && exit 0
npm run license-check
;;
"jsdoc")
[[ $CONFIGURATION == 'Debug' ]] && exit 0
npm run jsdoc
;;
"react-tests")
npm run check-environment
Add missing chrome debugging apis for Sync.User (#801) * Add user tests * Add Sync member to Realm * Add a simple test for addListener * Introduce browser User class * Introduce Sync.User proxy * Fix User.all * Add User.logout * Remove some console.log statements * Update rpc.cpp from tests-folder * Use user.current from user-methods, not cpp * remove user.current from two missing places * Start server in realmjs and react tests * Add user tests * Add Sync member to Realm * Add a simple test for addListener * Introduce browser User class * Introduce Sync.User proxy * Fix User.all * Add User.logout * Remove some console.log statements * Update rpc.cpp from tests-folder * Use user.current from user-methods, not cpp * remove user.current from two missing places * Start server in realmjs and react tests * Replace needle with node-fetch * Make AuthError work in the browser * Allow for persistent callbacks * Expose _authenticateRealm to native * Use clear_test_state in roc * Streamline test inclusion * Fix login tests * Promisify testLogin() * Disable AsyncTests for now * Mode jasmine timeout to spec/unit_tests.js * Avoid use of global for fetch module * Only include user-tests is sync is enabled * Skip ROS for android tests * Add some comments about persistent callbacks * Fix results-test * Run async-tests in node * Add a comment about (user object) * Cache all users in User.current and return promises in fetch * node_require async-tests so RN doesn't try and package them * Add missing parenthesis
2017-01-31 14:07:29 +01:00
download_server
start_server
pushd tests/react-test-app
2016-11-10 23:55:26 -08:00
npm install
open_chrome
2015-12-17 10:56:08 -08:00
start_packager
2016-01-22 23:23:27 +00:00
2016-03-23 13:20:05 -07:00
pushd ios
xctest ReactTests
Add missing chrome debugging apis for Sync.User (#801) * Add user tests * Add Sync member to Realm * Add a simple test for addListener * Introduce browser User class * Introduce Sync.User proxy * Fix User.all * Add User.logout * Remove some console.log statements * Update rpc.cpp from tests-folder * Use user.current from user-methods, not cpp * remove user.current from two missing places * Start server in realmjs and react tests * Add user tests * Add Sync member to Realm * Add a simple test for addListener * Introduce browser User class * Introduce Sync.User proxy * Fix User.all * Add User.logout * Remove some console.log statements * Update rpc.cpp from tests-folder * Use user.current from user-methods, not cpp * remove user.current from two missing places * Start server in realmjs and react tests * Replace needle with node-fetch * Make AuthError work in the browser * Allow for persistent callbacks * Expose _authenticateRealm to native * Use clear_test_state in roc * Streamline test inclusion * Fix login tests * Promisify testLogin() * Disable AsyncTests for now * Mode jasmine timeout to spec/unit_tests.js * Avoid use of global for fetch module * Only include user-tests is sync is enabled * Skip ROS for android tests * Add some comments about persistent callbacks * Fix results-test * Run async-tests in node * Add a comment about (user object) * Cache all users in User.current and return promises in fetch * node_require async-tests so RN doesn't try and package them * Add missing parenthesis
2017-01-31 14:07:29 +01:00
stop_server
;;
"react-example")
npm run check-environment
pushd examples/ReactExample
npm install
open_chrome
2015-12-17 10:56:08 -08:00
start_packager
echo "{ \"test\" : true }" > $(pwd)/components/params.json
2016-01-22 15:27:17 -08:00
pushd ios
xctest ReactExample
popd
echo "{}" > $(pwd)/components/params.json
;;
"react-tests-android")
npm run check-environment
if [ "$(uname)" = 'Darwin' ]; then
download_server
start_server
fi
[[ $CONFIGURATION == 'Debug' ]] && exit 0
XCPRETTY=''
pushd react-native/android
$(pwd)/gradlew publishAndroid
popd
2016-01-22 12:15:38 -08:00
pushd tests/react-test-app
2016-01-22 12:15:38 -08:00
npm install
2016-01-22 23:23:27 +00:00
echo "Resetting logcat"
# Despite the docs claiming -c to work, it doesn't, so `-T 1` alleviates that.
mkdir -p $(pwd)/build || true
adb logcat -c
adb logcat -T 1 | tee "$LOGCAT_OUT" | tee $(pwd)/build/out.txt &
./run-android.sh
echo "Start listening for Test completion"
while :; do
if grep -q "__REALM_JS_TESTS_COMPLETED__" "$LOGCAT_OUT"; then
break
else
echo "Waiting for tests."
sleep 2
fi
2016-01-22 23:23:27 +00:00
done
2016-01-22 12:15:38 -08:00
rm -f tests.xml
adb pull /sdcard/tests.xml .
# Stop running child processes before printing results.
cleanup
2016-01-26 21:10:23 +00:00
echo "********* TESTS COMPLETED *********";
echo "********* File location: $(pwd)/tests.xml *********";
cat tests.xml
2018-01-26 17:21:09 +01:00
check_test_results ReactTests
;;
2016-04-19 14:10:10 -07:00
"node")
npm run check-environment
2016-11-10 14:42:58 +01:00
if [ "$(uname)" = 'Darwin' ]; then
echo "downloading server"
2016-11-10 14:42:58 +01:00
download_server
echo "starting server"
2016-11-10 14:42:58 +01:00
start_server
2016-11-10 14:42:58 +01:00
npm_tests_cmd="npm run test"
npm install --build-from-source=realm --realm_enable_sync
2016-11-10 14:42:58 +01:00
else
2017-03-30 11:24:46 +03:00
npm_tests_cmd="npm run test"
npm install --build-from-source=realm
2016-11-10 14:42:58 +01:00
fi
2016-10-11 22:30:39 +02:00
2016-05-13 16:30:57 -07:00
# Change to a temp directory.
cd "$(mktemp -q -d -t realm.node.XXXXXX)"
test_temp_dir=$PWD # set it to be cleaned at exit
2016-04-19 14:10:10 -07:00
2016-10-04 15:02:51 -07:00
pushd "$SRCROOT/tests"
npm install
2017-07-12 18:50:37 +02:00
eval "$npm_tests_cmd"
2016-10-04 15:02:51 -07:00
popd
stop_server
2016-04-19 14:10:10 -07:00
;;
"electron")
if [ "$(uname)" = 'Darwin' ]; then
download_server
start_server
fi
# Change to a temp directory - because this is what is done for node - but we pushd right after?
cd "$(mktemp -q -d -t realm.electron.XXXXXX)"
test_temp_dir=$PWD # set it to be cleaned at exit
pushd "$SRCROOT/tests/electron"
if [ "$(uname)" = 'Darwin' ]; then
npm install --build-from-source --realm_enable_sync
else
npm install --build-from-source
fi
# npm test -- --filter=ListTests
# npm test -- --filter=LinkingObjectsTests
# npm test -- --filter=ObjectTests
# npm test -- --filter=RealmTests
# npm test -- --filter=ResultsTests
# npm test -- --filter=QueryTests
# npm test -- --filter=MigrationTests
# npm test -- --filter=EncryptionTests
# npm test -- --filter=UserTests
# npm test -- --filter=SessionTests
# npm test -- --filter=GarbageCollectionTests
# npm test -- --filter=AsyncTests
npm test -- --process=main
npm test -- --process=render
popd
if [ "$(uname)" = 'Darwin' ]; then
stop_server
fi
;;
"test-runners")
npm run check-environment
npm run test-runners
;;
"all")
# Run all tests that must pass before publishing.
for test in eslint license-check react-example react-tests-android react-tests; do
for configuration in Debug Release; do
echo "RUNNING TEST: $test ($configuration)"
echo '----------------------------------------'
npm test "$test" "$configuration" || die "Test Failed: $test ($configuration)"
echo
done
done
;;
2016-03-03 14:58:05 -08:00
"object-store")
pushd src/object-store
2017-01-02 13:35:45 +01:00
cmake -DCMAKE_BUILD_TYPE="$CONFIGURATION" .
2016-03-03 14:58:05 -08:00
make run-tests
2016-04-19 14:10:10 -07:00
;;
2016-10-04 15:02:51 -07:00
"download-object-server")
2017-01-02 13:35:45 +01:00
# shellcheck disable=SC1091
2016-10-04 15:02:51 -07:00
. dependencies.list
object_server_bundle="realm-object-server-bundled_node_darwin-$REALM_OBJECT_SERVER_VERSION.tar.gz"
curl -f -L "https://static.realm.io/downloads/object-server/$object_server_bundle" -o "$object_server_bundle"
rm -rf tests/sync-bundle
mkdir -p tests/sync-bundle
tar -C tests/sync-bundle -xf "$object_server_bundle"
rm "$object_server_bundle"
echo -e "enterprise:\n skip_setup: true\n" >> "tests/sync-bundle/object-server/configuration.yml"
touch "tests/sync-bundle/object-server/do_not_open_browser"
;;
*)
2015-12-16 18:14:14 -08:00
echo "Invalid target '${TARGET}'"
exit 1
esac