mirror of
https://github.com/samba-team/samba.git
synced 2025-01-14 19:24:43 +03:00
b8b28cb567
Many tests currently do this sort of thing: onnode 0 $CTDB_TEST_WRAPPER wait_until_node_has_status 1 disconnected In fact, they all use exactly the same "onnode 0 $CTDB_TEST_WRAPPER" idiom. This is both repetitious and dangerous, since node 0 might be shutdown during a test. Instead, we push "onnode any $CTDB_TEST_WRAPPER" (which selects a connected node) into wait_until_node_has_status() and just call that function directly in tests, like this: wait_until_node_has_status 1 disconnected Signed-off-by: Martin Schwenke <martin@meltin.net> (This used to be ctdb commit a2aaef03d4d6bbd4b42f50f732254935d4d3469c)
72 lines
1.8 KiB
Bash
Executable File
72 lines
1.8 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
test_info()
|
|
{
|
|
cat <<EOF
|
|
Verify the operation of the 'ctdb continue' command.
|
|
|
|
This is a superficial test of the 'ctdb continue' command. It trusts
|
|
information from CTDB that indicates that the IP failover and failback
|
|
has happened correctly. Another test should check that the failover
|
|
and failback has actually happened at the networking level.
|
|
|
|
Prerequisites:
|
|
|
|
* An active CTDB cluster with at least 2 active nodes.
|
|
|
|
Steps:
|
|
|
|
1. Verify that the status on all of the ctdb nodes is 'OK'.
|
|
2. Stop one of the nodes using the 'ctdb stop' command.
|
|
3. Verify that the status of the node changes to 'stopped'.
|
|
4. Verify that the public IP addresses that were being served by
|
|
the node are failed over to one of the other nodes.
|
|
5. Use 'ctdb continue' to bring the node back online.
|
|
6. Verify that the status of the node changes back to 'OK' and that
|
|
the public IP addresses move back to the node.
|
|
|
|
Expected results:
|
|
|
|
* The 'ctdb continue' command successfully brings a stopped node online.
|
|
EOF
|
|
}
|
|
|
|
. ctdb_test_functions.bash
|
|
|
|
ctdb_test_init "$@"
|
|
|
|
set -e
|
|
|
|
cluster_is_healthy
|
|
|
|
# Reset configuration
|
|
ctdb_restart_when_done
|
|
|
|
select_test_node_and_ips
|
|
|
|
echo "Stopping node ${test_node}..."
|
|
try_command_on_node 1 $CTDB stop -n $test_node
|
|
|
|
wait_until_node_has_status $test_node stopped
|
|
|
|
if wait_until_ips_are_on_nodeglob "[!${test_node}]" $ips ; then
|
|
echo "All IPs moved."
|
|
else
|
|
echo "Some IPs didn't move."
|
|
testfailures=1
|
|
fi
|
|
|
|
echo "Continuing node $test_node"
|
|
try_command_on_node 1 $CTDB continue -n $test_node
|
|
|
|
wait_until_node_has_status $test_node notstopped
|
|
|
|
# BUG: this is only guaranteed if DeterministicIPs is 1 and
|
|
# NoIPFailback is 0.
|
|
if wait_until_ips_are_on_nodeglob "$test_node" $ips ; then
|
|
echo "All IPs moved."
|
|
else
|
|
echo "Some IPs didn't move."
|
|
testfailures=1
|
|
fi
|