1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-15 23:24:37 +03:00
samba-mirror/ctdb/tests/simple/07_ctdb_process_exists.sh

77 lines
1.7 KiB
Bash
Raw Normal View History

#!/bin/bash
test_info()
{
cat <<EOF
Verify that 'ctdb process-exists' shows correct information.
The implementation is creative about how it gets PIDs for existing and
non-existing processes.
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. On one of the cluster nodes, get the PID of an existing process
(using ps wax).
3. Run 'ctdb process-exists <pid>' on the node and verify that the
correct output is shown.
4. Run 'ctdb process-exists <pid>' with a pid of a non-existent
process and verify that the correct output is shown.
Expected results:
* 'ctdb process-exists' shows the correct output.
EOF
}
. ctdb_test_functions.bash
ctdb_test_init "$@"
set -e
onnode 0 $CTDB_TEST_WRAPPER cluster_is_healthy
# Create a background process on node 2 that will last for 60 seconds.
# It should still be there when we check.
try_command_on_node 2 'sleep 60 >/dev/null 2>&1 & echo $!'
pid="$out"
echo "Checking for PID $pid on node 2"
# set -e is good, but avoid it here
status=0
onnode 1 "ctdb process-exists 2:$pid" || status=$?
echo "$out"
if [ $status -eq 0 ] ; then
echo "OK"
else
echo "BAD"
testfailures=1
fi
# Now just echo the PID of the shell from the onnode process on node
# 2. This PID will disappear and PIDs shouldn't roll around fast
# enough to trick the test... but there is a chance that will happen!
try_command_on_node 2 'echo $$'
pid="$out"
echo "Checking for PID $pid on node 2"
# set -e is good, but avoid it here
status=0
onnode 1 "ctdb process-exists 2:$pid" || status=$?
echo "$out"
if [ $status -ne 0 ] ; then
echo "OK"
else
echo "BAD"
testfailures=1
fi
ctdb_test_exit