2020-08-28 13:21:31 -07:00
#!/bin/sh
2021-01-01 14:37:34 -08:00
2020-09-09 20:57:44 -07:00
# Copyright (c) 2020 The ZMK Contributors
2020-08-28 13:21:31 -07:00
# SPDX-License-Identifier: MIT
2021-01-01 14:37:34 -08:00
2020-08-28 13:21:31 -07:00
if [ -z " $1 " ] ; then
echo "Usage: ./run-test.sh <path to testcase>"
exit 1
2020-11-22 06:05:07 -08:00
fi
path = " $1 "
2020-11-23 12:55:04 -08:00
if [ $path = "all" ] ; then
path = "tests"
2020-11-22 06:05:07 -08:00
fi
2022-03-24 04:38:14 -07:00
testcases = $( find $path -name native_posix_64.keymap -exec dirname \{ \} \; )
2020-11-22 06:05:07 -08:00
num_cases = $( echo " $testcases " | wc -l)
2022-04-02 21:17:36 -07:00
if [ $num_cases -gt 1 ] || [ " $testcases " != " $path " ] ; then
2020-08-28 13:21:31 -07:00
echo "" > ./build/tests/pass-fail.log
2021-03-24 07:24:08 -07:00
echo " $testcases " | xargs -L 1 -P ${ J :- 4 } ./run-test.sh
2020-08-28 13:21:31 -07:00
err = $?
sort -k2 ./build/tests/pass-fail.log
exit $err
2020-08-28 13:21:31 -07:00
fi
2020-11-22 06:05:07 -08:00
testcase = " $path "
2020-08-28 13:21:31 -07:00
echo " Running $testcase : "
2022-03-24 04:38:14 -07:00
west build -d build/$testcase -b native_posix_64 -- -DZMK_CONFIG= " $( pwd ) / $testcase " > /dev/null 2>& 1
2020-08-28 13:21:31 -07:00
if [ $? -gt 0 ] ; then
2021-12-11 11:55:56 -08:00
echo " FAILED: $testcase did not build " | tee -a ./build/tests/pass-fail.log
2020-09-14 07:34:05 -07:00
exit 1
2021-12-11 11:55:56 -08:00
fi
./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
diff -au $testcase /keycode_events.snapshot build/$testcase /keycode_events.log
if [ $? -gt 0 ] ; then
if [ -f $testcase /pending ] ; then
echo " PENDING: $testcase " | tee -a ./build/tests/pass-fail.log
2020-08-28 13:28:49 -07:00
exit 0
2020-08-28 13:21:31 -07:00
fi
2021-12-11 11:55:56 -08:00
echo " FAILED: $testcase " | tee -a ./build/tests/pass-fail.log
exit 1
2021-01-21 12:05:30 -08:00
fi
2021-12-11 11:55:56 -08:00
echo " PASS: $testcase " | tee -a ./build/tests/pass-fail.log
exit 0