2020-12-23 17:14:13 +00:00
|
|
|
# fail_after -- exits openMSX after timeout.
|
|
|
|
#
|
|
|
|
# Typically used in combination with the MSX-DOS 'omsxctl.com' utility.
|
|
|
|
#
|
2024-06-28 16:52:59 +00:00
|
|
|
# Adds two commands to openMSX;
|
2020-12-23 17:14:13 +00:00
|
|
|
#
|
2024-07-01 09:57:30 +00:00
|
|
|
# 'fail_after <timeout> [timeunit] [fail_id] [fail_code]'
|
2020-12-23 17:14:13 +00:00
|
|
|
# Schedules an openMSX exit after the timeout.
|
|
|
|
# This can be canceled by requesting a timeout of 0 or new timeout.
|
|
|
|
# The timeunit can be selected between (msx)'time' and (host)'realtime'.
|
|
|
|
# The fail_id can be used to differentiate between multiple fail_after commands.
|
|
|
|
# The failure exit code can be given too.
|
|
|
|
#
|
|
|
|
# 'fail_after_exit [fail_id] [fail_code]'
|
|
|
|
# Exits openMSX with an failure exit code and if the FAIL_AFTER_PATH is
|
|
|
|
# set it also creates a screenshot named from the failure id.
|
|
|
|
#
|
|
|
|
# Supported environment variables by this script;
|
|
|
|
#
|
2024-06-29 13:47:52 +00:00
|
|
|
# BOOT_WATCHDOG=30
|
2020-12-23 17:14:13 +00:00
|
|
|
# Enables the boot watchdog timer which will exit openMSX after the timeout(in seconds).
|
|
|
|
# To cancel this timer give an `fail_after 0` or any new fail_after command.
|
2024-06-29 13:47:52 +00:00
|
|
|
# (exits with status 124 see `man timeout`)
|
2020-12-23 17:14:13 +00:00
|
|
|
#
|
|
|
|
|
2024-06-29 13:47:52 +00:00
|
|
|
set fail_after_prev_timer 0
|
|
|
|
set fail_after_prev_id 0
|
|
|
|
set fail_after_boot_timeout 0
|
|
|
|
|
2020-12-23 17:14:13 +00:00
|
|
|
proc fail_after_exit {{fail_id "fail_after_exit"} {fail_code 2}} {
|
2024-06-29 13:47:52 +00:00
|
|
|
if {[catch {screenshot -prefix $fail_id} err_msg]} {
|
|
|
|
puts stderr "warning: $err_msg"
|
2020-12-23 17:14:13 +00:00
|
|
|
}
|
|
|
|
puts stderr "error: Failure request from $fail_id"
|
|
|
|
exit $fail_code
|
|
|
|
}
|
|
|
|
|
|
|
|
proc fail_after { timeout {time_unit "time"} {fail_id "fail_after"} {fail_code 2}} {
|
|
|
|
global fail_after_prev_timer
|
|
|
|
global fail_after_prev_id
|
|
|
|
set msg ""
|
|
|
|
if {$fail_after_prev_timer != 0} {
|
|
|
|
after cancel $fail_after_prev_timer
|
2024-06-29 13:47:52 +00:00
|
|
|
set msg "$fail_after_prev_id: Stopped attempt"
|
2020-12-23 17:14:13 +00:00
|
|
|
}
|
|
|
|
set fail_after_prev_id $fail_id
|
|
|
|
if {$time_unit != "time"} {
|
|
|
|
set time_unit "realtime"
|
|
|
|
}
|
|
|
|
if {$timeout != 0} {
|
|
|
|
if {[catch {set fail_after_prev_timer [after $time_unit $timeout "fail_after_exit $fail_id $fail_code"]} err_msg]} {
|
|
|
|
puts stderr "error: $err_msg"
|
|
|
|
fail_after_exit fail_after_timer_error 1
|
|
|
|
}
|
2024-06-28 16:52:59 +00:00
|
|
|
set msg "$msg\n$fail_id: Failure in $timeout $time_unit sec"
|
2020-12-23 17:14:13 +00:00
|
|
|
} else {
|
|
|
|
set fail_after_prev_timer 0
|
|
|
|
}
|
|
|
|
return $msg
|
|
|
|
}
|
|
|
|
|
2024-06-28 16:17:54 +00:00
|
|
|
proc fail_after_reboot_watchdog {} {
|
|
|
|
global fail_after_boot_timeout
|
|
|
|
if {$fail_after_boot_timeout != 0} {
|
|
|
|
fail_after $fail_after_boot_timeout realtime failed_boot 124
|
|
|
|
after boot "fail_after_reboot_watchdog"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-06-29 13:47:52 +00:00
|
|
|
if {[info exists ::env(BOOT_WATCHDOG)] && ([string trim $::env(BOOT_WATCHDOG)] != "")} {
|
|
|
|
set fail_after_boot_timeout [string trim $::env(BOOT_WATCHDOG)]
|
2024-06-28 16:17:54 +00:00
|
|
|
fail_after_reboot_watchdog
|
2020-12-23 17:14:13 +00:00
|
|
|
}
|