1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114
|
#!/bin/bash
. $(dirname $0)/../../include.rc
. $(dirname $0)/../../volume.rc
. $(dirname $0)/../../ec.rc
cleanup
TEST glusterd
TEST pidof glusterd
TEST $CLI volume create $V0 disperse 6 redundancy 2 $H0:$B0/${V0}{0..5}
TEST $CLI volume start $V0
#Empty read-mask should fail
TEST ! $GFS --xlator-option=*.ec-read-mask="" -s $H0 --volfile-id $V0 $M0
#Less than 4 number of bricks should fail
TEST ! $GFS --xlator-option="*.ec-read-mask=0" -s $H0 --volfile-id $V0 $M0
TEST ! $GFS --xlator-option="*.ec-read-mask=0:1" -s $H0 --volfile-id $V0 $M0
TEST ! $GFS --xlator-option=*.ec-read-mask="0:1:2" -s $H0 --volfile-id $V0 $M0
#ids greater than 5 should fail
TEST ! $GFS --xlator-option="*.ec-read-mask=0:1:2:6" -s $H0 --volfile-id $V0 $M0
#ids less than 0 should fail
TEST ! $GFS --xlator-option="*.ec-read-mask=0:-1:2:5" -s $H0 --volfile-id $V0 $M0
#read-mask with non-alphabet or comma should fail
TEST ! $GFS --xlator-option="*.ec-read-mask=0:1:2:5:abc" -s $H0 --volfile-id $V0 $M0
TEST ! $GFS --xlator-option="*.ec-read-mask=0:1:2:5a" -s $H0 --volfile-id $V0 $M0
#mount with at least 4 read-mask-ids and all of them valid should pass
TEST $GFS --xlator-option="*.ec-read-mask=0:1:2:5:4:3" -s $H0 --volfile-id $V0 $M0
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count $V0 0
EXPECT "^111111$" ec_option_value $V0 $M0 0 read-mask
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
TEST $GFS --xlator-option="*.ec-read-mask=0:1:2:5" -s $H0 --volfile-id $V0 $M0
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count $V0 0
EXPECT "^100111$" ec_option_value $V0 $M0 0 read-mask
TEST dd if=/dev/urandom of=$M0/a bs=1M count=1
md5=$(md5sum $M0/a | awk '{print $1}')
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
#Read on the file should fail if any of the read-mask is down when number of
#ids is data-count
TEST $GFS --xlator-option="*.ec-read-mask=0:1:2:5" -s $H0 --volfile-id $V0 $M0
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count $V0 0
EXPECT "^100111$" ec_option_value $V0 $M0 0 read-mask
TEST kill_brick $V0 $H0 $B0/${V0}0
TEST ! dd if=$M0/a of=/dev/null
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
TEST $CLI volume start $V0 force
TEST $GFS --xlator-option="*.ec-read-mask=0:1:2:5" -s $H0 --volfile-id $V0 $M0
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count $V0 0
EXPECT "^100111$" ec_option_value $V0 $M0 0 read-mask
TEST kill_brick $V0 $H0 $B0/${V0}1
TEST ! dd if=$M0/a of=/dev/null
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
TEST $CLI volume start $V0 force
TEST $GFS --xlator-option="*.ec-read-mask=0:1:2:5" -s $H0 --volfile-id $V0 $M0
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count $V0 0
EXPECT "^100111$" ec_option_value $V0 $M0 0 read-mask
TEST kill_brick $V0 $H0 $B0/${V0}2
TEST ! dd if=$M0/a of=/dev/null
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
TEST $CLI volume start $V0 force
TEST $GFS --xlator-option="*.ec-read-mask=0:1:2:5" -s $H0 --volfile-id $V0 $M0
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count $V0 0
EXPECT "^100111$" ec_option_value $V0 $M0 0 read-mask
TEST kill_brick $V0 $H0 $B0/${V0}5
TEST ! dd if=$M0/a of=/dev/null
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
TEST $CLI volume start $V0 force
#Read on file should succeed when non-read-mask bricks are down
TEST $GFS --xlator-option="*.ec-read-mask=0:1:2:5" -s $H0 --volfile-id $V0 $M0
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count $V0 0
EXPECT "^100111$" ec_option_value $V0 $M0 0 read-mask
TEST kill_brick $V0 $H0 $B0/${V0}3
EXPECT "^$md5$" echo $(dd if=$M0/a | md5sum | awk '{print $1}')
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
TEST $CLI volume start $V0 force
TEST $GFS --xlator-option="*.ec-read-mask=0:1:2:5" -s $H0 --volfile-id $V0 $M0
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count $V0 0
EXPECT "^100111$" ec_option_value $V0 $M0 0 read-mask
TEST kill_brick $V0 $H0 $B0/${V0}4
EXPECT "^$md5$" echo $(dd if=$M0/a | md5sum | awk '{print $1}')
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
TEST $CLI volume start $V0 force
TEST $GFS --xlator-option="*.ec-read-mask=0:1:2:5" -s $H0 --volfile-id $V0 $M0
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count $V0 0
EXPECT "^100111$" ec_option_value $V0 $M0 0 read-mask
TEST kill_brick $V0 $H0 $B0/${V0}3
TEST kill_brick $V0 $H0 $B0/${V0}4
EXPECT "^$md5$" echo $(dd if=$M0/a | md5sum | awk '{print $1}')
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
TEST $CLI volume start $V0 force
#Deliberately corrupt chunks 3: 4 and check that reads still give correct data
TEST dd if=/dev/zero of=$B0/${V0}3/a bs=256k count=1
TEST dd if=/dev/zero of=$B0/${V0}4/a bs=256k count=1
TEST $GFS --xlator-option="*.ec-read-mask=0:1:2:5" -s $H0 --volfile-id $V0 $M0
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count $V0 0
EXPECT "^100111$" ec_option_value $V0 $M0 0 read-mask
EXPECT "^$md5$" echo $(dd if=$M0/a | md5sum | awk '{print $1}')
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
cleanup;
|