Blame tests/basic/multiplex.t

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