3 # Verify that the cluster recovers if the recovery lock is removed.
5 . "${TEST_SCRIPTS_DIR}/integration.bash"
9 ctdb_test_skip_on_cluster
13 generation_has_changed ()
16 local generation_init="$2"
18 # Leak this so it can be printed by test
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")
26 [ "$generation_new" != "$generation_init" ]
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"
39 if [ -z "$reclock_setting" ] ; then
40 ctdb_test_skip "Recovery lock is not set"
43 t="${reclock_setting% 5}"
46 if [ ! -f "$reclock" ] ; then
47 ctdb_test_error "Recovery lock file \"${reclock}\" is missing"
50 echo "Recovery lock setting is \"${reclock_setting}\""
51 echo "Recovery lock file is \"${reclock}\""
54 echo "Get current recovery master"
55 ctdb_onnode "$test_node" recmaster
57 echo "Recovery master is node ${recmaster}"
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}"
68 echo "Remove recovery lock"
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"
76 echo "Generation changed to ${generation_new}"
79 echo "Get current recovery master"
80 ctdb_onnode "$test_node" recmaster
83 if [ "$recmaster" != "$recmaster_new" ] ; then
85 "BAD: Recovery master has changed to node ${recmaster_new}"
87 echo "GOOD: Recovery master is still node ${recmaster_new}"