-
Notifications
You must be signed in to change notification settings - Fork 17
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
tests: Retry matching expected output to improve test robustness
This also reduces test time dramatically on faster hardware.
- Loading branch information
Showing
4 changed files
with
76 additions
and
12 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
Row # Country City AccentCit Region Populatio Latitude Longitude | ||
1 ir sarmaj-e Sarmaj-e 13 34.3578 47.5207 | ||
2 ad aixirival Aixirival 06 42.466666 1.5 | ||
3 mm mokho-atw Mokho-atw 09 18.033333 96.75 | ||
? for help 1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
Row # HA1 HA2 HA3 HB1 HB2 HB3 HC1 HC2 HC3 | ||
1 A1 B1 C1 | ||
2 A2 B2 C2 | ||
3 A3 B3 C3 | ||
4 A4 B4 C4 | ||
? for help 1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
#!/bin/sh -eu | ||
|
||
target=$1 | ||
if [ -z ${2:-} ]; then | ||
stage="" | ||
else | ||
stage=-$2 | ||
fi | ||
capture=${TMP_DIR}/${target}${stage}.out | ||
expected=$(pwd)/expected/${target}${stage}.out | ||
matched=false | ||
|
||
cleanup() { | ||
if $matched; then | ||
if [ -z $stage ]; then | ||
tmux send-keys -t $target "q" | ||
fi | ||
exit 0 | ||
fi | ||
|
||
tmux send-keys -t $target "q" | ||
echo 'Incorrect output:' | ||
cat $capture | ||
${CMP} -s $capture $expected | ||
exit 1 | ||
} | ||
|
||
trap cleanup INT TERM QUIT | ||
|
||
start_time=$(date +%s) | ||
warned=0 | ||
while true; do | ||
tmux capture-pane -t $target -p > $capture | ||
current_time=$(date +%s) | ||
span=$(( current_time - start_time )) | ||
|
||
if ${CMP} -s $capture $expected; then | ||
echo "$target$stage matched in ${span}s" | ||
matched=true | ||
break | ||
fi | ||
|
||
sleep 0.1 | ||
|
||
if (( span > 5 )); then | ||
echo "Timeout exceeded" | ||
break | ||
fi | ||
|
||
if (( span > 2 && !warned )); then | ||
warned=1 | ||
echo "Slow test" | ||
fi | ||
done | ||
|
||
cleanup |