3
. $(dirname $0)/../include.rc
4
. $(dirname $0)/../traps.rc
5
. $(dirname $0)/../volume.rc
7
function count_up_bricks {
8
$CLI --xml volume status $V0 | grep '<status>1' | wc -l
11
function count_brick_processes {
12
pgrep glusterfsd | wc -l
15
function count_brick_pids {
16
$CLI --xml volume status $V0 | sed -n '/.*<pid>\([^<]*\).*/s//\1/p' \
17
| grep -v "N/A" | sort | uniq | wc -l
23
TEST $CLI volume set all cluster.brick-multiplex on
25
TEST $CLI volume create $V0 $H0:$B0/brick{0,1}
26
TEST $CLI volume set $V0 features.trash enable
28
TEST $CLI volume start $V0
29
# Without multiplexing, there would be two.
30
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
31
EXPECT 1 count_brick_processes
33
TEST $CLI volume stop $V0
34
#Testing the volume set command introduced for protocol/server
35
TEST $CLI volume set $V0 transport.listen-backlog 1024
36
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 0 count_brick_processes
37
TEST $CLI volume start $V0
38
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
39
EXPECT 1 count_brick_processes
41
TEST kill_brick $V0 $H0 $B0/brick1
42
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_up_bricks
43
# Make sure the whole process didn't go away.
44
EXPECT 1 count_brick_processes
46
TEST $CLI volume start $V0 force
47
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
48
EXPECT 1 count_brick_processes
50
# Killing the first brick is a bit more of a challenge due to socket-path
52
TEST kill_brick $V0 $H0 $B0/brick0
53
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_up_bricks
54
EXPECT 1 count_brick_processes
55
TEST $CLI volume start $V0 force
56
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
57
EXPECT 1 count_brick_processes
59
# Make sure that the two bricks show the same PID.
60
EXPECT 1 count_brick_pids
62
# Do a quick test to make sure that the bricks are acting as separate bricks
63
# even though they're in the same process.
64
TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0
65
for i in $(seq 10 99); do
66
echo hello > $M0/file$i
68
nbrick0=$(ls $B0/brick0/file?? | wc -l)
69
nbrick1=$(ls $B0/brick1/file?? | wc -l)
70
TEST [ $((nbrick0 + nbrick1)) -eq 90 ]
71
TEST [ $((nbrick0 * nbrick1)) -ne 0 ]
75
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_brick_pids
76
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_brick_processes