mirror of
https://github.com/samba-team/samba.git
synced 2025-01-13 13:18:06 +03:00
b6623feb9c
Print just the debug level as a description, for both human and machine readable. Signed-off-by: Martin Schwenke <martin@meltin.net> Reviewed-by: Amitay Isaacs <amitay@gmail.com>
79 lines
1.5 KiB
Bash
Executable File
79 lines
1.5 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
test_info()
|
|
{
|
|
cat <<EOF
|
|
Verify that 'ctdb setdebug' works as expected.
|
|
|
|
This is a little superficial. It checks that CTDB thinks the debug
|
|
level has been changed but doesn't actually check that logging occurs
|
|
at the new level.
|
|
EOF
|
|
}
|
|
|
|
. "${TEST_SCRIPTS_DIR}/integration.bash"
|
|
|
|
ctdb_test_init "$@"
|
|
|
|
set -e
|
|
|
|
cluster_is_healthy
|
|
|
|
select_test_node_and_ips
|
|
|
|
get_debug ()
|
|
{
|
|
# Sets: check_debug
|
|
local node="$1"
|
|
|
|
local out
|
|
|
|
try_command_on_node -v $node "$CTDB getdebug"
|
|
check_debug="$out"
|
|
}
|
|
|
|
set_and_check_debug ()
|
|
{
|
|
local node="$1"
|
|
local level="$2"
|
|
local levelstr="${3:-$level}"
|
|
|
|
echo "Setting debug level on node ${node} to ${level}."
|
|
try_command_on_node $node "$CTDB setdebug ${level}"
|
|
|
|
local check_debug
|
|
get_debug $node
|
|
|
|
if [ "$levelstr" != "$check_debug" ] ; then
|
|
echo "BAD: Debug level should have changed to \"$levelstr\" but it is \"$check_debug\"."
|
|
testfailures=1
|
|
fi
|
|
}
|
|
|
|
get_debug $test_node
|
|
initial_debug="$check_debug"
|
|
|
|
levels="ERROR WARNING NOTICE INFO DEBUG"
|
|
|
|
for new_debug in $levels ; do
|
|
[ "$initial_debug" != "$new_debug" ] || continue
|
|
|
|
echo
|
|
set_and_check_debug $test_node "$new_debug"
|
|
done
|
|
|
|
i=0
|
|
for new_debug in $levels ; do
|
|
[ "$initial_debug" != "$i" ] || continue
|
|
|
|
echo
|
|
set_and_check_debug $test_node "$i" "$new_debug"
|
|
i=$[ $i + 1 ]
|
|
done
|
|
|
|
if [ "$testfailures" != 1 ] ; then
|
|
echo
|
|
echo "Returning the debug level to its initial value..."
|
|
set_and_check_debug $test_node "$initial_debug"
|
|
fi
|