mirror of
https://github.com/samba-team/samba.git
synced 2025-01-26 10:04:02 +03:00
296bd44c04
$CTDB_TEST_WRAPPER is required only to run test functions or test binaries on remote nodes. For running ctdb command, $CTDB is sufficient. Signed-off-by: Amitay Isaacs <amitay@gmail.com> Reviewed-by: Michael Adam <obnox@samba.org>
134 lines
3.6 KiB
Bash
Executable File
134 lines
3.6 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
test_info()
|
|
{
|
|
cat <<EOF
|
|
Recovery can under certain circumstances lead to old record copies
|
|
resurrecting: Recovery selects the newest record copy purely by RSN. At
|
|
the end of the recovery, the recovery master is the dmaster for all
|
|
records in all (non-persistent) databases. And the other nodes locally
|
|
hold the complete copy of the databases. The bug is that the recovery
|
|
process does not increment the RSN on the recovery master at the end of
|
|
the recovery. Now clients acting directly on the Recovery master will
|
|
directly change a record's content on the recmaster without migration
|
|
and hence without RSN bump. So a subsequent recovery can not tell that
|
|
the recmaster's copy is newer than the copies on the other nodes, since
|
|
their RSN is the same. Hence, if the recmaster is not node 0 (or more
|
|
precisely not the active node with the lowest node number), the recovery
|
|
will choose copies from nodes with lower number and stick to these.
|
|
|
|
Steps:
|
|
|
|
1. Create a test database
|
|
2. Add a record with value value1 on recovery master
|
|
3. Force a recovery
|
|
4. Update the record with value value2 on recovery master
|
|
5. Force a recovery
|
|
6. Fetch the record
|
|
|
|
Expected results:
|
|
|
|
* The record should have value value2 and not value1
|
|
|
|
EOF
|
|
}
|
|
|
|
. "${TEST_SCRIPTS_DIR}/integration.bash"
|
|
|
|
ctdb_test_init "$@"
|
|
|
|
set -e
|
|
|
|
cluster_is_healthy
|
|
|
|
# Reset configuration
|
|
ctdb_restart_when_done
|
|
|
|
#
|
|
# Main test
|
|
#
|
|
TESTDB="rec_test.tdb"
|
|
|
|
status=0
|
|
|
|
# Make sure node 0 is not the recovery master
|
|
echo "find out which node is recmaster"
|
|
try_command_on_node any $CTDB recmaster
|
|
recmaster="$out"
|
|
if [ "$recmaster" = "0" ]; then
|
|
echo "node 0 is recmaster, disable recmasterrole on node 0"
|
|
#
|
|
# Note:
|
|
# It should be sufficient to run "ctdb setrecmasterrole off"
|
|
# on node 0 and wait for election and recovery to finish.
|
|
# But there were problems related to this in this automatic
|
|
# test, so for now use "ctdb stop" and "ctdb continue".
|
|
#
|
|
echo "stop node 0"
|
|
try_command_on_node 0 $CTDB stop
|
|
wait_until_node_has_status 0 stopped
|
|
echo "continue node 0"
|
|
try_command_on_node 0 $CTDB continue
|
|
wait_until_node_has_status 0 notstopped
|
|
|
|
try_command_on_node any $CTDB recmaster
|
|
recmaster="$out"
|
|
if [ "$recmaster" = "0" ]; then
|
|
echo "failed to move recmaster to different node"
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
echo "Recmaster:$recmaster"
|
|
|
|
# Create a temporary non-persistent database to test with
|
|
echo "create test database $TESTDB"
|
|
try_command_on_node $recmaster $CTDB attach $TESTDB
|
|
|
|
# Wipe Test database
|
|
echo "wipe test database"
|
|
try_command_on_node $recmaster $CTDB wipedb $TESTDB
|
|
|
|
# Add a record key=test1 data=value1
|
|
echo "store key(test1) data(value1)"
|
|
try_command_on_node $recmaster $CTDB writekey $TESTDB test1 value1
|
|
|
|
# Fetch a record key=test1
|
|
echo "read key(test1)"
|
|
try_command_on_node $recmaster $CTDB readkey $TESTDB test1
|
|
echo "$out"
|
|
|
|
# Do a recovery
|
|
echo "force recovery"
|
|
try_command_on_node $recmaster $CTDB recover
|
|
|
|
wait_until_node_has_status $recmaster recovered
|
|
|
|
# Add a record key=test1 data=value2
|
|
echo "store key(test1) data(value2)"
|
|
try_command_on_node $recmaster $CTDB writekey $TESTDB test1 value2
|
|
|
|
# Fetch a record key=test1
|
|
echo "read key(test1)"
|
|
try_command_on_node $recmaster $CTDB readkey $TESTDB test1
|
|
echo "$out"
|
|
|
|
# Do a recovery
|
|
echo "force recovery"
|
|
try_command_on_node $recmaster $CTDB recover
|
|
|
|
wait_until_node_has_status $recmaster recovered
|
|
|
|
# Verify record key=test1
|
|
echo "read key(test1)"
|
|
try_command_on_node $recmaster $CTDB readkey $TESTDB test1
|
|
echo "$out"
|
|
if [ "$out" = "Data: size:6 ptr:[value2]" ]; then
|
|
echo "GOOD: Recovery did not corrupt database"
|
|
else
|
|
echo "BAD: Recovery corrupted database"
|
|
status=1
|
|
fi
|
|
|
|
exit $status
|