eccf0bea9daf8a95082bc9aa2ad93d5dafe77d2e
[ddiss/samba-autobuild/.git] / ctdb / tests / INTEGRATION / simple / cluster.015.reclock_remove_lock.sh
1 #!/usr/bin/env bash
2
3 # Verify that the cluster recovers if the recovery lock is removed.
4
5 . "${TEST_SCRIPTS_DIR}/integration.bash"
6
7 set -e
8
9 ctdb_test_skip_on_cluster
10
11 ctdb_test_init -r 5
12
13 generation_has_changed ()
14 {
15         local node="$1"
16         local generation_init="$2"
17
18         # Leak this so it can be printed by test
19         generation_new=""
20
21         ctdb_onnode "$node" status
22         # shellcheck disable=SC2154
23         # $outfile set by ctdb_onnode() above
24         generation_new=$(sed -n -e 's/^Generation:\([0-9]*\)/\1/p' "$outfile")
25
26         [ "$generation_new" != "$generation_init" ]
27 }
28
29 select_test_node
30
31 echo "Get recovery lock setting"
32 # shellcheck disable=SC2154
33 # $test_node set by select_test_node() above
34 ctdb_onnode "$test_node" getreclock
35 # shellcheck disable=SC2154
36 # $out set by ctdb_onnode() above
37 reclock_setting="$out"
38
39 if [ -z "$reclock_setting" ] ; then
40         ctdb_test_skip "Recovery lock is not set"
41 fi
42
43 t="${reclock_setting% 5}"
44 reclock="${t##* }"
45
46 if [ ! -f "$reclock" ] ; then
47         ctdb_test_error "Recovery lock file \"${reclock}\" is missing"
48 fi
49
50 echo "Recovery lock setting is \"${reclock_setting}\""
51 echo "Recovery lock file is \"${reclock}\""
52 echo
53
54 echo "Get current recovery master"
55 ctdb_onnode "$test_node" recmaster
56 recmaster="$out"
57 echo "Recovery master is node ${recmaster}"
58 echo
59
60 echo "Get initial generation"
61 ctdb_onnode "$test_node" status
62 # shellcheck disable=SC2154
63 # $outfile set by ctdb_onnode() above
64 generation_init=$(sed -n -e 's/^Generation:\([0-9]*\)/\1/p' "$outfile")
65 echo "Initial generation is ${generation_init}"
66 echo
67
68 echo "Remove recovery lock"
69 rm "$reclock"
70 echo
71
72 # This will mean an election has taken place and a recovery has occured
73 echo "Wait until generation changes"
74 wait_until 30 generation_has_changed "$test_node" "$generation_init"
75 echo
76 echo "Generation changed to ${generation_new}"
77 echo
78
79 echo "Get current recovery master"
80 ctdb_onnode "$test_node" recmaster
81 recmaster_new="$out"
82
83 if [ "$recmaster" != "$recmaster_new" ] ; then
84         ctdb_test_fail \
85                 "BAD: Recovery master has changed to node ${recmaster_new}"
86 fi
87 echo "GOOD: Recovery master is still node ${recmaster_new}"
88 echo
89
90 cluster_is_healthy