1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-12 09:18:10 +03:00
samba-mirror/ctdb/tests/simple/35_set_reclock.sh
Martin Schwenke 3a7c73ff7b ctdb-tests: Fix "setreclock" test
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>
2015-11-09 07:53:18 +01:00

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}"