From: Marek Marczykowski-Górecki Date: Tue, 31 Oct 2023 02:16:53 +0000 (+0100) Subject: automation: fix race condition in adl-suspend test X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=2926952b35d648eb1bca921662f0e64ab3fed29f;p=people%2Faperard%2Fxen-unstable.git automation: fix race condition in adl-suspend test If system suspends too quickly, the message for the test controller to wake up the system may be not sent to the console before suspending. This will cause the test to timeout. Fix this by calling sync on the console and waiting a bit after printing the message. The test controller then resumes the system 30s after the message, so as long as the delay + suspending takes less time it is okay. Signed-off-by: Marek Marczykowski-Górecki Release-acked-by: Henry Wang Acked-by: Andrew Cooper (cherry picked from commit df43b54590e10b6199e44741b453fcbae2b06d25) --- diff --git a/automation/scripts/qubes-x86-64.sh b/automation/scripts/qubes-x86-64.sh index f5dae82358..51323b1ae0 100755 --- a/automation/scripts/qubes-x86-64.sh +++ b/automation/scripts/qubes-x86-64.sh @@ -54,11 +54,12 @@ until grep 'domU started' /var/log/xen/console/guest-domU.log; do sleep 1 done echo \"${wait_and_wakeup}\" +# let the above message flow to console, then suspend +sync /dev/stdout +sleep 5 set -x echo deep > /sys/power/mem_sleep echo mem > /sys/power/state -# now wait for resume -sleep 5 xl list xl dmesg | grep 'Finishing wakeup from ACPI S3 state' || exit 1 # check if domU is still alive