File: start-kill-stop.sh

package info (click to toggle)
finit 4.14-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 5,216 kB
  • sloc: ansic: 17,060; sh: 6,281; makefile: 532
file content (61 lines) | stat: -rwxr-xr-x 1,366 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#!/bin/sh
# Regression test for Finit bug #313:
#   - services get the 'forking' flag on initctl reload
#   - stopping a crashing task while its restart callback is pending
#     causes state 'running' with pid:0 (i.e., not running at all.)
# 

set -eu

TEST_DIR=$(dirname "$0")

test_teardown()
{
#	run "initctl status -j serv"
	say "Running test teardown."
	run "rm -f $FINIT_CONF"
}

# shellcheck source=/dev/null
. "$TEST_DIR/lib/setup.sh"

say "Check deps ..."
check_dep jq

rm -f "$SYSROOT"/oldpid

say "Add service stanza in $FINIT_CONF"
run "echo 'service [2345] log:stderr serv -np -- Test service' > $FINIT_CONF"

say 'Reload Finit'
run "initctl reload"

say 'Verify serv is running ...'
retry 'assert_num_children 1 serv'

say 'Verify reload does not change forking type of service'
#run "initctl status -j serv"
run "initctl reload"
#run "initctl status -j serv"
assert_forking serv false

say 'Simulate service crash (kill -9 ..)'
run "initctl debug"
i=0
laps=7
while [ $i -lt $laps ]; do
	i=$((i + 1))
	say "Lap $i/$laps, killing service ..." # we have this, no sleep needed
	run "slay serv"
done

say 'Verify stopping service actually stops it'
sleep 1
run "initctl stop serv"
sleep 5
#run "initctl status serv"
assert_status serv stopped

say 'Verify restarting service actually starts it'
run "initctl start serv"
retry 'assert_num_children 1 serv'