glusterfs

Форк
0
/
bug-1408712.t 
101 строка · 3.9 Кб
1
#!/bin/bash
2

3
. $(dirname $0)/../../include.rc
4
. $(dirname $0)/../../volume.rc
5
. $(dirname $0)/../../afr.rc
6

7
cleanup
8

9
TESTS_EXPECTED_IN_LOOP=12
10

11
TEST glusterd
12
TEST pidof glusterd
13

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
20

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
29

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
34

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
39

40
TEST cd $M0
41
TEST dd if=/dev/zero of=file bs=1M count=8
42

43
# Kill brick-0.
44
TEST kill_brick $V0 $H0 $B0/${V0}0
45
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT "0" brick_up_status $V0 $H0 $B0/${V0}0
46

47
TEST "dd if=/dev/zero bs=1M count=8 >> file"
48

49
FILE_GFID=$(get_gfid_string $M0/file)
50

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
55
for i in {2..3}
56
do
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
59
done
60

61
TEST cd ~
62
TEST md5sum $M1/file
63

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
67
for i in {2..3}
68
do
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
71
done
72

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
78

79
# Enable shd
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
85

86
TEST $CLI volume heal $V0
87

88
# Wait for heal to complete
89
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0
90

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
94

95
for i in {2..3}
96
do
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
99
done
100

101
cleanup
102

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.