Fix and improve mftest

This commit is contained in:
Scott Lahteine 2019-07-10 05:55:51 -05:00
parent 44c8f29e47
commit d4c210f21b

View File

@ -14,8 +14,10 @@ TESTPATH=buildroot/share/tests
shopt -s extglob nocasematch shopt -s extglob nocasematch
# Get test, allowing shorthand # Get test
TESTENV=${1:-"mega"} TESTENV=${1:-'-'}
# Allow shorthand for test name
case $TESTENV in case $TESTENV in
due) TESTENV='DUE' ;; due) TESTENV='DUE' ;;
esp) TESTENV='esp32' ;; esp) TESTENV='esp32' ;;
@ -26,6 +28,7 @@ case $TESTENV in
stm) TESTENV='STM32F1' ;; stm) TESTENV='STM32F1' ;;
t35) TESTENV='teensy35' ;; t35) TESTENV='teensy35' ;;
teensy) TESTENV='teensy35' ;; teensy) TESTENV='teensy35' ;;
-) ;;
esac esac
# Matching patterns # Matching patterns
@ -34,7 +37,7 @@ ISCMD='^(restore|opt|exec|use|pins|env)_'
ISEXEC='^exec_' ISEXEC='^exec_'
# List available tests and ask for selection # List available tests and ask for selection
if [[ $1 == '-' ]]; then if [[ $TESTENV == '-' ]]; then
IND=0 IND=0
NAMES=() NAMES=()
for FILE in $( ls -1 $TESTPATH/*-tests ) for FILE in $( ls -1 $TESTPATH/*-tests )
@ -43,6 +46,7 @@ if [[ $1 == '-' ]]; then
TNAME=${FILE/-tests/} TNAME=${FILE/-tests/}
TNAME=${TNAME/$TESTPATH\//} TNAME=${TNAME/$TESTPATH\//}
NAMES+=($TNAME) NAMES+=($TNAME)
(( IND < 10 )) && echo -n " "
echo " $IND) $TNAME" echo " $IND) $TNAME"
done done
@ -50,8 +54,8 @@ if [[ $1 == '-' ]]; then
for (( ; ; )) for (( ; ; ))
do do
read -p "Select a test to apply (1-$IND) : " NAMEIND read -p "Select a test to apply (1-$IND) : " NAMEIND
[[ -z "$NAMEIND" ]] && { echo "Quitting." ; exit 1 ; } [[ -z "$NAMEIND" ]] && { echo '(canceled)' ; exit 1 ; }
[[ $NAMEIND =~ $ISNUM ]] && ((NAMEIND >= 1 && NAMEIND <= IND)) && { TESTENV=${NAMES[$NAMEIND-1]} ; break ; } [[ $NAMEIND =~ $ISNUM ]] && ((NAMEIND >= 1 && NAMEIND <= IND)) && { TESTENV=${NAMES[$NAMEIND-1]} ; echo ; break ; }
echo "Invalid selection." echo "Invalid selection."
done done
fi fi
@ -66,17 +70,33 @@ TESTCOUNT=$( awk "/$ISEXEC/{a++}END{print a}" <<<"$OUT" )
# Get the entered or interactive test index # Get the entered or interactive test index
CHOICE=${2:-0} CHOICE=${2:-0}
if [[ $TESTCOUNT > 1 && ( $CHOICE == 0 || $1 == '-' ) ]]; then # User entered a number?
(( CHOICE && CHOICE > TESTCOUNT )) && { echo "Invalid test index '$CHOICE' (1-$TESTCOUNT)." ; exit 1 ; }
if [[ $CHOICE == 0 ]]; then
# List test descriptions with numbers
echo "Available '$TESTENV' tests:" ; echo "$OUT" | {
IND=0
SED=$(which gsed || which sed)
while IFS= read -r LINE
do
if [[ $LINE =~ $ISEXEC ]]; then
DESC=$( "$SED" -E 's/^.+"(.*)".*$/\1/g' <<<"$LINE" )
(( ++IND < 10 )) && echo -n " "
echo " $IND) $DESC"
fi
done
}
CHOICE=1
if [[ $TESTCOUNT > 1 ]]; then
for (( ; ; )) for (( ; ; ))
do do
read -p "Test '$TESTENV' index (1-$TESTCOUNT) : " CHOICE read -p "Select a '$TESTENV' test (1-$TESTCOUNT) : " CHOICE
[[ -z "$CHOICE" ]] && CHOICE=1 [[ -z "$CHOICE" ]] && { echo '(canceled)' ; exit 1 ; }
[[ $CHOICE =~ $ISNUM ]] && ((CHOICE >= 1 && CHOICE <= TESTCOUNT)) && break [[ $CHOICE =~ $ISNUM ]] && ((CHOICE >= 1 && CHOICE <= TESTCOUNT)) && break
echo "Invalid test index '$CHOICE'." echo ">>> Invalid test index '$CHOICE'."
done done
else fi
# Confirm a manually-entered test index
((CHOICE >= 1 && CHOICE <= TESTCOUNT)) || { echo "Invalid test index '$CHOICE' (1-$TESTCOUNT)." ; exit 1 ; }
fi fi
# Finally, run the specified test lines # Finally, run the specified test lines