glusterfs

Форк
0
/
bug-1655854-support-dist-to-rep3-arb-conversion.t 
95 строк · 3.6 Кб
1
#!/bin/bash
2
. $(dirname $0)/../../include.rc
3
. $(dirname $0)/../../volume.rc
4
cleanup;
5

6
TEST glusterd
7
TEST pidof glusterd
8

9
# Conversion from 2x1 to 2x3
10

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';
15

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
18

19
TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0;
20
TEST mkdir $M0/dir
21
TEST dd if=/dev/urandom of=$M0/dir/file bs=100K count=5
22
file_md5sum=$(md5sum $M0/dir/file | awk '{print $1}')
23

24
TEST $CLI volume add-brick $V0 replica 3 $H0:$B0/${V0}{2..5}
25

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
30

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
38

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
42

43
# Check whether the directory & file are healed to the newly added bricks
44
TEST ls $B0/${V0}2/dir
45
TEST ls $B0/${V0}3/dir
46
TEST ls $B0/${V0}4/dir
47
TEST ls $B0/${V0}5/dir
48

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}') ]
51

52

53
# Conversion from 2x1 to 2x(2+1)
54

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';
59

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
62

63
TEST $GFS --volfile-id=$V1 --volfile-server=$H0 $M1;
64
TEST mkdir $M1/dir
65
TEST dd if=/dev/urandom of=$M1/dir/file bs=100K count=5
66
file_md5sum=$(md5sum $M1/dir/file | awk '{print $1}')
67

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
73

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
81

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
85

86
# Check whether the directory & file are healed to the newly added bricks
87
TEST ls $B0/${V1}2/dir
88
TEST ls $B0/${V1}3/dir
89
TEST ls $B0/${V1}4/dir
90
TEST ls $B0/${V1}5/dir
91

92
EXPECT "0" stat -c %s $B0/${V1}5/dir/file
93
TEST [ $file_md5sum == $(md5sum $B0/${V1}4/dir/file | awk '{print $1}') ]
94

95
cleanup;
96

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

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

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

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