mirror of
https://github.com/samba-team/samba.git
synced 2025-01-12 09:18:10 +03:00
3a7c73ff7b
1. Waiting for generation to change isn't enough. It now changes early in recovery and reclock might not have been set on all nodes. So wait until recovery is complete before checking reclock. 2. Use onnode -p when setting reclock on all nodes. That will cause it to be set quickly on all nodes, to avoid the situation where the recovery master is the late in the list and resets the reclock on earlier nodes back to the old value. This shouldn't matter if (1) is done but it can't hurt. Signed-off-by: Martin Schwenke <martin@meltin.net> Reviewed-by: Michael Adam <obnox@samba.org>
125 lines
3.0 KiB
Bash
Executable File
125 lines
3.0 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
test_info()
|
|
{
|
|
cat <<EOF
|
|
Verify that "ctdb setreclock" sets the recovery lock correctly.
|
|
|
|
This test only does something when there is a recovery lock
|
|
configured.
|
|
EOF
|
|
}
|
|
|
|
. "${TEST_SCRIPTS_DIR}/integration.bash"
|
|
|
|
ctdb_test_init "$@"
|
|
|
|
set -e
|
|
|
|
cluster_is_healthy
|
|
|
|
# Reset configuration
|
|
ctdb_restart_when_done
|
|
|
|
get_generation ()
|
|
{
|
|
local out
|
|
try_command_on_node any $CTDB status
|
|
generation=$(sed -n -e 's@^Generation:@@p' <<<"$out")
|
|
}
|
|
|
|
generation_has_changed ()
|
|
{
|
|
local old_generation="$generation"
|
|
get_generation
|
|
[ "$old_generation" != "$generation" ]
|
|
}
|
|
|
|
wait_until_generation_has_changed ()
|
|
{
|
|
echo
|
|
echo "Wait until generation has changed..."
|
|
wait_until 60 generation_has_changed
|
|
}
|
|
|
|
wait_until_recovered ()
|
|
{
|
|
wait_until_generation_has_changed
|
|
wait_until_node_has_status all recovered
|
|
}
|
|
|
|
echo "Check that recovery lock is set the same on all nodes..."
|
|
try_command_on_node -v -q all $CTDB getreclock
|
|
n=$(echo "$out" | sort -u | wc -l)
|
|
if [ "$n" = 1 ] ; then
|
|
echo "GOOD: All nodes have the same recovery lock setting"
|
|
else
|
|
echo "BAD: Recovery lock setting differs across nodes"
|
|
exit 1
|
|
fi
|
|
|
|
echo
|
|
echo "Check that recovery lock is actually enabled..."
|
|
t=$(echo "$out" | sed -e 's@^Reclock file:@@' | sort -u)
|
|
if [ "$t" != "No reclock file used." ] ; then
|
|
echo "OK: Recovery lock is set"
|
|
else
|
|
echo "OOPS: Recovery lock is unset. Skipping remainder of test"
|
|
exit 0
|
|
fi
|
|
|
|
echo
|
|
orig_reclock=$(sed -n -e '1s@^Reclock file:@@p' <<<"$out")
|
|
echo "Remember original recovery lock file: \"${orig_reclock}\""
|
|
|
|
echo
|
|
echo "Unset and test the recovery lock on all nodes..."
|
|
try_command_on_node -pq all $CTDB setreclock
|
|
wait_until_recovered
|
|
try_command_on_node -v -q all $CTDB getreclock
|
|
t=$(sort -u <<<"$out")
|
|
if [ "$t" = "No reclock file used." ] ; then
|
|
echo "GOOD: Recovery lock unset on all nodes"
|
|
else
|
|
echo "BAD: Recovery lock not unset on all nodes"
|
|
exit 1
|
|
fi
|
|
|
|
echo
|
|
get_generation
|
|
echo "Current generation is ${generation}"
|
|
|
|
alt="${orig_reclock}.test"
|
|
echo
|
|
echo "Set alternative recovery lock (${alt}) and test on all nodes..."
|
|
try_command_on_node -pq all $CTDB setreclock "$alt"
|
|
wait_until_recovered
|
|
try_command_on_node -v -q all $CTDB getreclock
|
|
t=$(echo "$out" | sed -e 's@^Reclock file:@@' | sort -u)
|
|
if [ "$t" = "$alt" ] ; then
|
|
echo "GOOD: Recovery lock set on all nodes"
|
|
else
|
|
echo "BAD: Recovery lock not set on all nodes"
|
|
try_command_on_node -vf all rm -v "$alt" || true
|
|
exit 1
|
|
fi
|
|
|
|
# Setting or updating the recovery lock file must cause a recovery
|
|
echo "Current generation is ${generation}"
|
|
|
|
echo
|
|
echo "Restore and test the recovery lock on all nodes..."
|
|
try_command_on_node -pq all $CTDB setreclock "$orig_reclock"
|
|
wait_until_recovered
|
|
try_command_on_node -v all rm -vf "$alt"
|
|
try_command_on_node -v -q all $CTDB getreclock
|
|
t=$(echo "$out" | sed -e 's@^Reclock file:@@' | sort -u)
|
|
if [ "$t" = "$orig_reclock" ] ; then
|
|
echo "GOOD: Recovery lock restored on all nodes"
|
|
else
|
|
echo "BAD: Recovery lock not restored on all nodes"
|
|
exit 1
|
|
fi
|
|
|
|
echo "Current generation is ${generation}"
|