#!/bin/bash test_info() { cat </dev/null 2>&1" wait_until_get_src_socket "tcp" "${test_ip}:${test_port}" $nc_pid "nc" src_socket="$out" echo "Source socket is $src_socket" # This should happen as soon as connection is up... but unless we wait # we sometimes beat the registration. echo "Checking if CIFS connection is tracked by CTDB on test node..." wait_until 10 check_tickles $test_node $test_ip $test_port $src_socket echo "$out" if [ "${out/SRC: ${src_socket} /}" != "$out" ] ; then echo "GOOD: CIFS connection tracked OK by CTDB." else echo "BAD: Socket not tracked by CTDB." testfailures=1 fi # This is almost immediate. However, it is sent between nodes # asynchonously, so it is worth checking... echo "Wait until CIFS connection is tracked by CTDB on all nodes..." try_command_on_node $test_node "$CTDB listnodes | wc -l" numnodes="$out" wait_until 5 \ check_tickles_all $numnodes $test_ip $test_port $src_socket tcptickle_sniff_start $src_socket "${test_ip}:${test_port}" echo "Disabling node $test_node" try_command_on_node 1 $CTDB disable -n $test_node wait_until_node_has_status $test_node disabled tcptickle_sniff_wait_show