[dirty] let it smoke

This commit is contained in:
Consolatis 2024-03-16 09:10:02 +01:00
parent 1597d683ca
commit 7124cf79c1

View file

@ -1,5 +1,7 @@
#!/usr/bin/env bash #!/usr/bin/env bash
LET_IT_SMOKE=y
if ! test -x "$1/labwc"; then if ! test -x "$1/labwc"; then
echo "$1/labwc not found" echo "$1/labwc not found"
exit 1 exit 1
@ -14,11 +16,7 @@ args=(
export XDG_RUNTIME_DIR=$(mktemp -d) export XDG_RUNTIME_DIR=$(mktemp -d)
export WLR_BACKENDS=headless export WLR_BACKENDS=headless
echo "Starting ${args[@]}" gdb_run() {
output=$("${args[@]}" 2>&1)
ret=$?
if test $ret -ge 128; then
# Not using -Db_sanitize=address,undefined # Not using -Db_sanitize=address,undefined
# because it slows down the usual execution # because it slows down the usual execution
# way too much and spams pages over pages # way too much and spams pages over pages
@ -30,10 +28,8 @@ if test $ret -ge 128; then
# just running labwc again is a lot faster # just running labwc again is a lot faster
# anyway. # anyway.
echo
echo "labwc crashed, restarting under gdb"
echo
gdb --batch \ gdb --batch \
--return-child-result \
-ex run \ -ex run \
-ex 'bt full' \ -ex 'bt full' \
-ex 'echo \n' \ -ex 'echo \n' \
@ -43,6 +39,34 @@ if test $ret -ge 128; then
-ex 'set listsize 50' \ -ex 'set listsize 50' \
-ex list \ -ex list \
--args "${args[@]}" --args "${args[@]}"
return $?
}
if test "$LET_IT_SMOKE" = "y"; then
ret=0
for x in {1..10}; do
printf "Starting run %2s\n" $x
output=$(gdb_run 2>&1)
ret=$?
if test $ret -ne 0; then
echo "Crash enountered:"
echo "-----------------"
echo "$output"
break
fi
done
exit $ret
fi
echo "Starting ${args[@]}"
output=$("${args[@]}" 2>&1)
ret=$?
if test $ret -ge 128; then
echo
echo "labwc crashed, restarting under gdb"
echo
gdb_run
else else
echo "$output" echo "$output"
fi fi