mirror of
https://github.com/samba-team/samba.git
synced 2025-01-13 13:18:06 +03:00
96b3517356
cluster_is_healthy() is now run locally in tests and internally causes _cluster_is_healthy() to be run on node 0. When it detects that the cluster is unhealthy and $ctdb_test_restart_scheduled is not true, debug information is printed. This replaces the previous use of $CTDB_TEST_CLEANING_UP. To avoid spurious debug on expected restarts, added scheduled restarts to several tests. Signed-off-by: Martin Schwenke <martin@meltin.net> (This used to be ctdb commit ee7caae3a55a64fb50cd28fa2fd4663c5dd83b4f)
83 lines
1.8 KiB
Bash
Executable File
83 lines
1.8 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
test_info()
|
|
{
|
|
cat <<EOF
|
|
Verify that 'ctdb getdebug' works as expected.
|
|
|
|
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. Get the current debug level on a node, using 'ctdb getdebug -n <node>'.
|
|
3. Verify that colon-separated output is generated with the -Y option.
|
|
4. Verify that the '-n all' option shows the debug level on all nodes.
|
|
|
|
Expected results:
|
|
|
|
* 'ctdb getdebug' shows the debug level on all the nodes.
|
|
EOF
|
|
}
|
|
|
|
. ctdb_test_functions.bash
|
|
|
|
ctdb_test_init "$@"
|
|
|
|
set -e
|
|
|
|
cluster_is_healthy
|
|
|
|
try_command_on_node 0 "$CTDB listnodes | wc -l"
|
|
num_nodes="$out"
|
|
|
|
try_command_on_node -v 1 "onnode -q all $CTDB getdebug"
|
|
getdebug_onnode="$out"
|
|
|
|
sanity_check_output \
|
|
$num_nodes \
|
|
'^Node [[:digit:]]+ is at debug level [[:alpha:]]+ \([[:digit:]]+\)$' \
|
|
"$out"
|
|
|
|
try_command_on_node -v 1 "$CTDB getdebug -n all"
|
|
getdebug_all="$out"
|
|
|
|
cmd=""
|
|
n=0
|
|
while [ $n -lt $num_nodes ] ; do
|
|
cmd="${cmd}${cmd:+; }$CTDB getdebug -n $n"
|
|
n=$(($n + 1))
|
|
done
|
|
try_command_on_node -v 1 "$cmd"
|
|
getdebug_n="$out"
|
|
|
|
if [ "$getdebug_onnode" = "$getdebug_all" -a \
|
|
"$getdebug_all" = "$getdebug_n" ] ; then
|
|
echo "They're the same... cool!"
|
|
else
|
|
echo "Error: they differ."
|
|
testfailures=1
|
|
fi
|
|
|
|
colons=""
|
|
nl="
|
|
"
|
|
while read line ; do
|
|
t=$(echo "$line" | sed -r -e 's@Node [[:digit:]]+ is at debug level ([[:alpha:]]+) \((-?[[:digit:]]+)\)$@:\1:\2:@')
|
|
colons="${colons}${colons:+${nl}}:Name:Level:${nl}${t}"
|
|
done <<<"$getdebug_onnode"
|
|
|
|
cmd="$CTDB -Y getdebug -n all"
|
|
echo "Checking that \"$cmd\" produces expected output..."
|
|
|
|
try_command_on_node 1 "$cmd"
|
|
if [ "$out" = "$colons" ] ; then
|
|
echo "Yep, looks good!"
|
|
else
|
|
echo "Nope, it looks like this:"
|
|
echo "$out"
|
|
testfailures=1
|
|
fi
|