zmk_mf68/app/run-test.sh

49 lines
1.3 KiB
Bash
Raw Normal View History

2020-08-29 06:21:31 +10:00
#!/bin/sh
2020-08-29 06:21:31 +10:00
#
# Copyright (c) 2020 The ZMK Contributors
2020-08-29 06:21:31 +10:00
#
# SPDX-License-Identifier: MIT
#
2020-08-29 06:21:31 +10:00
if [ -z "$1" ]; then
echo "Usage: ./run-test.sh <path to testcase>"
exit 1
fi
path="$1"
2020-11-24 07:55:04 +11:00
if [ $path = "all" ]; then
path="tests"
fi
testcases=$(find $path -name native_posix.keymap -exec dirname \{\} \;)
num_cases=$(echo "$testcases" | wc -l)
if [ $num_cases -gt 1 ]; then
2020-08-29 06:21:31 +10:00
echo "" > ./build/tests/pass-fail.log
echo "$testcases" | xargs -l -P 4 ./run-test.sh
2020-08-29 06:21:31 +10:00
err=$?
sort -k2 ./build/tests/pass-fail.log
exit $err
2020-08-29 06:21:31 +10:00
fi
testcase="$path"
2020-08-29 06:21:31 +10:00
echo "Running $testcase:"
west build -d build/$testcase -b native_posix -- -DZMK_CONFIG="$(pwd)/$testcase" > /dev/null 2>&1
2020-08-29 06:21:31 +10:00
if [ $? -gt 0 ]; then
echo "FAIL: $testcase did not build" >> ./build/tests/pass-fail.log
exit 1
2020-08-29 06:21:31 +10:00
else
./build/$testcase/zephyr/zmk.exe | sed -e "s/.*> //" | tee build/$testcase/keycode_events_full.log | sed -n -f $testcase/events.patterns > build/$testcase/keycode_events.log
2020-08-29 06:21:31 +10:00
diff -au $testcase/keycode_events.snapshot build/$testcase/keycode_events.log
if [ $? -gt 0 ]; then
if [ -f $testcase/pending ]; then
echo "PEND: $testcase" >> ./build/tests/pass-fail.log
exit 0
else
echo "FAIL: $testcase" >> ./build/tests/pass-fail.log
exit 1
fi
2020-08-29 06:21:31 +10:00
else
echo "PASS: $testcase" >> ./build/tests/pass-fail.log
exit 0
2020-08-29 06:21:31 +10:00
fi
fi