3
. $(dirname $0)/../../include.rc
4
. $(dirname $0)/../../volume.rc
5
. $(dirname $0)/../../afr.rc
9
TESTS_EXPECTED_IN_LOOP=12
14
TEST $CLI volume create $V0 replica 3 $H0:$B0/${V0}{0,1,2}
15
TEST $CLI volume start $V0
16
EXPECT 'Started' volinfo_field $V0 'Status'
17
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}0
18
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}1
19
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}2
21
TEST $CLI volume set $V0 features.shard on
22
TEST $CLI volume set $V0 features.shard-block-size 4MB
23
TEST $CLI volume heal $V0 granular-entry-heal enable
24
TEST $CLI volume set $V0 cluster.data-self-heal off
25
TEST $CLI volume set $V0 cluster.metadata-self-heal off
26
TEST $CLI volume set $V0 cluster.entry-self-heal off
27
TEST $CLI volume set $V0 self-heal-daemon off
28
TEST $CLI volume set $V0 performance.flush-behind off
30
TEST glusterfs --volfile-id=$V0 --volfile-server=$H0 $M0
31
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_meta $M0 $V0-replicate-0 0
32
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_meta $M0 $V0-replicate-0 1
33
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_meta $M0 $V0-replicate-0 2
35
TEST glusterfs --volfile-id=$V0 --volfile-server=$H0 $M1
36
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_meta $M1 $V0-replicate-0 0
37
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_meta $M1 $V0-replicate-0 1
38
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_meta $M1 $V0-replicate-0 2
41
TEST dd if=/dev/zero of=file bs=1M count=8
44
TEST kill_brick $V0 $H0 $B0/${V0}0
45
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT "0" brick_up_status $V0 $H0 $B0/${V0}0
47
TEST "dd if=/dev/zero bs=1M count=8 >> file"
49
FILE_GFID=$(get_gfid_string $M0/file)
51
# Test that the index associated with '/.shard' is created on B1 and B2.
52
TEST stat $B0/${V0}1/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID
53
TEST stat $B0/${V0}2/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID
54
# Check for successful creation of granular entry indices
57
TEST_IN_LOOP stat $B0/${V0}1/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID/$FILE_GFID.$i
58
TEST_IN_LOOP stat $B0/${V0}2/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID/$FILE_GFID.$i
64
# Test that the index associated with '/.shard' and the created shards do not disappear on B1 and B2.
65
TEST stat $B0/${V0}1/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID
66
TEST stat $B0/${V0}2/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID
69
TEST_IN_LOOP stat $B0/${V0}1/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID/$FILE_GFID.$i
70
TEST_IN_LOOP stat $B0/${V0}2/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID/$FILE_GFID.$i
73
# Start the brick that was down
74
TEST $CLI volume start $V0 force
75
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" afr_child_up_status $V0 0
76
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" afr_child_up_status $V0 1
77
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" afr_child_up_status $V0 2
80
TEST gluster volume set $V0 cluster.self-heal-daemon on
81
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "Y" glustershd_up_status
82
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V0 0
83
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V0 1
84
EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" afr_child_up_status_in_shd $V0 2
86
TEST $CLI volume heal $V0
88
# Wait for heal to complete
89
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0
91
# Now verify that there are no name indices left after self-heal
92
TEST ! stat $B0/${V0}1/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID
93
TEST ! stat $B0/${V0}2/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID
97
TEST_IN_LOOP ! stat $B0/${V0}1/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID/$FILE_GFID.$i
98
TEST_IN_LOOP ! stat $B0/${V0}2/.glusterfs/indices/entry-changes/$DOT_SHARD_GFID/$FILE_GFID.$i