Blame tests/basic/multiplex.t

Packit Service e080da
#!/bin/bash
Packit Service e080da
Packit Service e080da
. $(dirname $0)/../include.rc
Packit Service e080da
. $(dirname $0)/../traps.rc
Packit Service e080da
. $(dirname $0)/../volume.rc
Packit Service e080da
Packit Service e080da
function count_up_bricks {
Packit Service e080da
        $CLI --xml volume status $V0 | grep '<status>1' | wc -l
Packit Service e080da
}
Packit Service e080da
Packit Service e080da
function count_brick_processes {
Packit Service e080da
	pgrep glusterfsd | wc -l
Packit Service e080da
}
Packit Service e080da
Packit Service e080da
function count_brick_pids {
Packit Service e080da
        $CLI --xml volume status $V0 | sed -n '/.*<pid>\([^<]*\).*/s//\1/p' \
Packit Service e080da
                                     | grep -v "N/A" | sort | uniq | wc -l
Packit Service e080da
}
Packit Service e080da
Packit Service e080da
cleanup
Packit Service e080da
Packit Service e080da
TEST glusterd
Packit Service e080da
TEST $CLI volume set all cluster.brick-multiplex on
Packit Service e080da
Packit Service e080da
TEST $CLI volume create $V0 $H0:$B0/brick{0,1}
Packit Service e080da
TEST $CLI volume set $V0 features.trash enable
Packit Service e080da
Packit Service e080da
TEST $CLI volume start $V0
Packit Service e080da
# Without multiplexing, there would be two.
Packit Service e080da
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
Packit Service e080da
EXPECT 1 count_brick_processes
Packit Service e080da
Packit Service e080da
TEST $CLI volume stop $V0
Packit Service e080da
#Testing the volume set command introduced for protocol/server
Packit Service e080da
TEST $CLI volume set $V0 transport.listen-backlog 1024
Packit Service e080da
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 0 count_brick_processes
Packit Service e080da
TEST $CLI volume start $V0
Packit Service e080da
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
Packit Service e080da
EXPECT 1 count_brick_processes
Packit Service e080da
Packit Service e080da
TEST kill_brick $V0 $H0 $B0/brick1
Packit Service e080da
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_up_bricks
Packit Service e080da
# Make sure the whole process didn't go away.
Packit Service e080da
EXPECT 1 count_brick_processes
Packit Service e080da
Packit Service e080da
TEST $CLI volume start $V0 force
Packit Service e080da
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
Packit Service e080da
EXPECT 1 count_brick_processes
Packit Service e080da
Packit Service e080da
# Killing the first brick is a bit more of a challenge due to socket-path
Packit Service e080da
# issues.
Packit Service e080da
TEST kill_brick $V0 $H0 $B0/brick0
Packit Service e080da
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_up_bricks
Packit Service e080da
EXPECT 1 count_brick_processes
Packit Service e080da
TEST $CLI volume start $V0 force
Packit Service e080da
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
Packit Service e080da
EXPECT 1 count_brick_processes
Packit Service e080da
Packit Service e080da
# Make sure that the two bricks show the same PID.
Packit Service e080da
EXPECT 1 count_brick_pids
Packit Service e080da
Packit Service e080da
# Do a quick test to make sure that the bricks are acting as separate bricks
Packit Service e080da
# even though they're in the same process.
Packit Service e080da
TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0
Packit Service e080da
for i in $(seq 10 99); do
Packit Service e080da
        echo hello > $M0/file$i
Packit Service e080da
done
Packit Service e080da
nbrick0=$(ls $B0/brick0/file?? | wc -l)
Packit Service e080da
nbrick1=$(ls $B0/brick1/file?? | wc -l)
Packit Service e080da
TEST [ $((nbrick0 + nbrick1)) -eq 90 ]
Packit Service e080da
TEST [ $((nbrick0 * nbrick1)) -ne 0 ]
Packit Service e080da
Packit Service e080da
pkill gluster
Packit Service e080da
TEST glusterd
Packit Service e080da
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_brick_pids
Packit Service e080da
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_brick_processes
Packit Service e080da
Packit Service e080da
cleanup;