RetroDECK/automation_tools/post_build_check.sh
MonkeyX eb926fd9e4
Some checks are pending
Build RetroDECK / Build_RetroDECK (push) Waiting to run
Build RetroDECK / GitHub-publish (push) Blocked by required conditions
Cooker (#982)
* Fix features.json, add srm launcher

* Logging

* Set correct logging levels

* Bob makes it nexy year already!

* full splash screen dates

* Alpha version of post build check
2024-12-09 21:27:31 +00:00

55 lines
1.3 KiB
Bash
Executable file

#!/bin/bash
# todo create launch test commands ie mame -help, ruffle --version
# Log file
LOG_FILE="$HOME/check.log"
# Clear previous log
> "$LOG_FILE"
# Extract launch commands using jq
commands=($(jq -r '.emulator | to_entries[] | .value.launch' /app/retrodeck/config/retrodeck/reference_lists//features.json))
# Timeout duration in seconds
TIMEOUT=5
# Function to run command with timeout
run_and_check() {
local cmd="$1"
# Verify command exists
if ! command -v "$cmd" &> /dev/null; then
echo "✗ Command not found: $cmd (Exit Code: 127)" | tee -a "$LOG_FILE"
return 127
fi
# Run command with timeout
timeout -s TERM $TIMEOUT "$cmd"
local exit_code=$?
# Log the results
echo "Command: $cmd, Exit Code: $exit_code" | tee -a "$LOG_FILE"
case $exit_code in
0)
echo "$cmd completed successfully" | tee -a "$LOG_FILE"
;;
124)
echo "$cmd terminated after $TIMEOUT seconds" | tee -a "$LOG_FILE"
;;
137)
echo "$cmd killed" | tee -a "$LOG_FILE"
;;
*)
echo "$cmd failed" | tee -a "$LOG_FILE"
;;
esac
return $exit_code
}
# Execute commands
for cmd in "${commands[@]}"; do
run_and_check "$cmd"
done