mirror of
https://github.com/samba-team/samba.git
synced 2024-12-27 03:21:53 +03:00
bf197d097f
Signed-off-by: Martin Schwenke <martin@meltin.net> (This used to be ctdb commit 79adb50b3ce3873c3baf9e6715c1d1c3f181ce43)
58 lines
1.3 KiB
Bash
Executable File
58 lines
1.3 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
test_info()
|
|
{
|
|
cat <<EOF
|
|
Verify the operation of 'ctdb disable'.
|
|
|
|
This is a superficial test of the 'ctdb disable' command. It trusts
|
|
information from CTDB that indicates that the IP failover has happened
|
|
correctly. Another test should check that the failover 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. Disable one of the nodes using 'ctdb disable -n <node>'.
|
|
3. Verify that the status of the node changes to 'disabled'.
|
|
4. Verify that the IP addreses served by the disabled node are failed
|
|
over to other nodes.
|
|
|
|
Expected results:
|
|
|
|
* The status of the disabled node changes as expected and IP addresses
|
|
failover as expected.
|
|
EOF
|
|
}
|
|
|
|
. "${TEST_SCRIPTS_DIR}/integration.bash"
|
|
|
|
ctdb_test_init "$@"
|
|
|
|
set -e
|
|
|
|
cluster_is_healthy
|
|
|
|
# Reset configuration
|
|
ctdb_restart_when_done
|
|
|
|
select_test_node_and_ips
|
|
|
|
echo "Disabling node $test_node"
|
|
|
|
try_command_on_node 1 $CTDB disable -n $test_node
|
|
|
|
# Avoid a potential race condition...
|
|
wait_until_node_has_status $test_node disabled
|
|
|
|
if wait_until_ips_are_on_nodeglob "[!${test_node}]" $test_node_ips ; then
|
|
echo "All IPs moved."
|
|
else
|
|
echo "Some IPs didn't move."
|
|
testfailures=1
|
|
fi
|