summaryrefslogtreecommitdiffstats
path: root/tests/basic/ec/ec-reset-brick.t
blob: f1a625df4ffd4297dafa433286035ab9ad7b8307 (plain)
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
#!/bin/bash

. $(dirname $0)/../../include.rc
. $(dirname $0)/../../volume.rc

cleanup
function num_entries {
        ls -l $1 | wc -l
}

TEST glusterd
TEST pidof glusterd
TEST $CLI volume create $V0 disperse 6 redundancy 2 $H0:$B0/${V0}{0..5}
TEST $CLI volume start $V0
TEST glusterfs --entry-timeout=0 --attribute-timeout=0 -s $H0 --volfile-id $V0 $M0
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count $V0 0

mkdir $M0/dir
touch $M0/dir/{1..10}

mkdir $M0/dir/dir1
touch $M0/dir/dir1/{1..10}

#kill brick process
TEST $CLI volume reset-brick $V0 $H0:$B0/${V0}5 start
EXPECT_WITHIN $CHILD_UP_TIMEOUT "5" ec_child_up_count $V0 0

#reset-brick by removing all the data and create dir again
rm -rf $B0/${V0}5
mkdir $B0/${V0}5

#start brick  process and heal by commiting reset-brick
TEST $CLI volume reset-brick $V0 $H0:$B0/${V0}5 $H0:$B0/${V0}5 commit force

EXPECT_WITHIN $PROCESS_UP_TIMEOUT "Y" glustershd_up_status
EXPECT_WITHIN $CHILD_UP_TIMEOUT "6" ec_child_up_count_shd $V0 0

EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count ${V0}

EXPECT "^12$" num_entries $B0/${V0}5/dir
EXPECT "^11$" num_entries $B0/${V0}5/dir/dir1

ec_version=$(get_hex_xattr trusted.ec.version $B0/${V0}0)
EXPECT "$ec_version" get_hex_xattr trusted.ec.version $B0/${V0}1
EXPECT "$ec_version" get_hex_xattr trusted.ec.version $B0/${V0}2
EXPECT "$ec_version" get_hex_xattr trusted.ec.version $B0/${V0}3
EXPECT "$ec_version" get_hex_xattr trusted.ec.version $B0/${V0}4
EXPECT "$ec_version" get_hex_xattr trusted.ec.version $B0/${V0}5

cleanup;