1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-11 05:17:44 +03:00
systemd-stable/test/testsuite-16.units/extend-timeout.sh
Zbigniew Jędrzejewski-Szmek e5b0aaaf56 test/TEST-16: simplify how variables are set
The amount of lines doesn't change much, but I think it's much more
straightforward this way.
2020-03-28 11:46:47 +01:00

63 lines
1.5 KiB
Bash
Executable File

#!/usr/bin/env bash
set -x
set -e
set -o pipefail
# sleep interval (seconds)
: ${sleep_interval:=1}
# extend_timeout_interval second(s)
: ${extend_timeout_interval:=1}
# number of sleep_intervals before READY=1
: ${start_intervals:=10}
# number of sleep_intervals before exiting
: ${stop_intervals:=10}
# run intervals, number of sleep_intervals to run
: ${run_intervals:=7}
# We convert to usec
extend_timeout_interval=$(( $extend_timeout_interval * 1000000 ))
trap "{ touch /${SERVICE}.terminated; exit 1; }" SIGTERM SIGABRT
rm -f /${SERVICE}.*
touch /${SERVICE}.startfail
systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
while [ $start_intervals -gt 0 ]
do
sleep $sleep_interval
start_intervals=$(( $start_intervals - 1 ))
systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
done
systemd-notify --ready --status="Waiting for your request"
touch /${SERVICE}.runtimefail
rm /${SERVICE}.startfail
systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
while [ $run_intervals -gt 0 ]
do
sleep $sleep_interval
run_intervals=$(( $run_intervals - 1 ))
systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
done
systemd-notify STOPPING=1
touch /${SERVICE}.stopfail
rm /${SERVICE}.runtimefail
systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
while [ $stop_intervals -gt 0 ]
do
sleep $sleep_interval
stop_intervals=$(( $stop_intervals - 1 ))
systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
done
touch /${SERVICE}.success
rm /${SERVICE}.stopfail
exit 0