2
. $(dirname $0)/../../include.rc
3
. $(dirname $0)/../../volume.rc
9
# Conversion from 2x1 to 2x3
11
TEST $CLI volume create $V0 $H0:$B0/${V0}{0,1}
12
EXPECT 'Created' volinfo_field $V0 'Status';
13
TEST $CLI volume start $V0
14
EXPECT 'Started' volinfo_field $V0 'Status';
16
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}0
17
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}1
19
TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0;
21
TEST dd if=/dev/urandom of=$M0/dir/file bs=100K count=5
22
file_md5sum=$(md5sum $M0/dir/file | awk '{print $1}')
24
TEST $CLI volume add-brick $V0 replica 3 $H0:$B0/${V0}{2..5}
26
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}2
27
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}3
28
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}4
29
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}5
31
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "Y" glustershd_up_status
32
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V0 0
33
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V0 1
34
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V0 2
35
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V0 3
36
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V0 4
37
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V0 5
39
# Trigger heal and wait for for it to complete
40
TEST $CLI volume heal $V0
41
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0
43
# Check whether the directory & file are healed to the newly added bricks
49
TEST [ $file_md5sum == $(md5sum $B0/${V0}4/dir/file | awk '{print $1}') ]
50
TEST [ $file_md5sum == $(md5sum $B0/${V0}5/dir/file | awk '{print $1}') ]
53
# Conversion from 2x1 to 2x(2+1)
55
TEST $CLI volume create $V1 $H0:$B0/${V1}{0,1}
56
EXPECT 'Created' volinfo_field $V1 'Status';
57
TEST $CLI volume start $V1
58
EXPECT 'Started' volinfo_field $V1 'Status';
60
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V1 $H0 $B0/${V1}0
61
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V1 $H0 $B0/${V1}1
63
TEST $GFS --volfile-id=$V1 --volfile-server=$H0 $M1;
65
TEST dd if=/dev/urandom of=$M1/dir/file bs=100K count=5
66
file_md5sum=$(md5sum $M1/dir/file | awk '{print $1}')
68
TEST $CLI volume add-brick $V1 replica 3 arbiter 1 $H0:$B0/${V1}{2..5}
69
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V1 $H0 $B0/${V1}2
70
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V1 $H0 $B0/${V1}3
71
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V1 $H0 $B0/${V1}4
72
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V1 $H0 $B0/${V1}5
74
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "Y" glustershd_up_status
75
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V1 0
76
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V1 1
77
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V1 2
78
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V1 3
79
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V1 4
80
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V1 5
82
# Trigger heal and wait for for it to complete
83
TEST $CLI volume heal $V1
84
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V1
86
# Check whether the directory & file are healed to the newly added bricks
92
EXPECT "0" stat -c %s $B0/${V1}5/dir/file
93
TEST [ $file_md5sum == $(md5sum $B0/${V1}4/dir/file | awk '{print $1}') ]