|
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;
|