veilid/veilid-tools/run_tests.sh

67 lines
2.2 KiB
Bash
Raw Normal View History

2022-11-27 10:27:06 -06:00
#!/bin/bash
2022-11-27 21:33:41 -06:00
SCRIPTDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )"
pushd $SCRIPTDIR 2>/dev/null
2022-11-27 10:27:06 -06:00
if [[ "$1" == "wasm" ]]; then
2023-05-29 14:24:57 -05:00
WASM_BINDGEN_TEST_TIMEOUT=120 wasm-pack test --firefox --headless --features=rt-wasm-bindgen
2022-11-27 21:33:41 -06:00
elif [[ "$1" == "ios" ]]; then
SYMROOT=/tmp/testout
APPNAME=veilidtools-tests
BUNDLENAME=com.veilid.veilidtools-tests
2022-11-29 11:16:28 -06:00
ID="$2"
if [[ "$ID" == "" ]]; then
echo "No emulator ID specified"
exit 1
fi
2022-11-27 21:33:41 -06:00
2022-11-29 11:16:28 -06:00
# Build for simulator
2022-11-27 21:33:41 -06:00
xcrun xcodebuild -project src/tests/ios/$APPNAME/$APPNAME.xcodeproj/ -scheme $APPNAME -destination "generic/platform=iOS Simulator" SYMROOT=$SYMROOT
2022-11-29 11:16:28 -06:00
# Run in temporary simulator
2022-11-27 21:33:41 -06:00
xcrun simctl install $ID $SYMROOT/Debug-iphonesimulator/$APPNAME.app
2022-12-01 15:49:37 -06:00
xcrun simctl spawn $ID log stream --level debug --predicate "subsystem == \"$BUNDLENAME\"" &
2022-11-27 21:33:41 -06:00
xcrun simctl launch --console $ID $BUNDLENAME
2022-12-01 15:49:37 -06:00
sleep 1 # Ensure the last log lines print
kill -INT %1
2022-11-29 11:16:28 -06:00
# Clean up build output
2022-11-27 21:33:41 -06:00
rm -rf /tmp/testout
2022-11-29 11:16:28 -06:00
elif [[ "$1" == "android" ]]; then
ID="$2"
if [[ "$ID" == "" ]]; then
echo "No emulator ID specified"
exit 1
fi
2022-11-30 08:39:12 -06:00
APPNAME=veilid_tools_android_tests
APPID=com.veilid.veilid_tools_android_tests
2022-11-29 11:16:28 -06:00
ACTIVITYNAME=MainActivity
pushd src/tests/android/$APPNAME >/dev/null
# Build apk
./gradlew assembleDebug
# Wait for boot
adb -s $ID wait-for-device
# Install app
adb -s $ID install -r ./app/build/outputs/apk/debug/app-debug.apk
# Start activity
adb -s $ID shell am start-activity -W $APPID/.$ACTIVITYNAME
# Get the pid of the program
APP_PID=`adb -s $ID shell pidof -s $APPID`
# Print the logcat
2022-11-30 08:39:12 -06:00
adb -s $ID shell logcat --pid=$APP_PID veilid-tools:V *:S &
2022-11-29 11:16:28 -06:00
# Wait for the pid to be done
while [ "$(adb -s $ID shell pidof -s $APPID)" != "" ]; do
sleep 1
done
# Terminate logcat
kill %1
# Finished
popd >/dev/null
2022-11-27 10:27:06 -06:00
else
2022-11-30 20:32:41 -06:00
cargo test --features=rt-tokio,tracing -- --nocapture
cargo test --features=rt-async-std,tracing -- --nocapture
cargo test --features=rt-tokio -- --nocapture
cargo test --features=rt-async-std -- --nocapture
2022-11-27 10:27:06 -06:00
fi
2022-11-27 21:33:41 -06:00
popd 2>/dev/null