summaryrefslogtreecommitdiffstats
path: root/tests/basic/ec/ec-optimistic-changelog.t
blob: 1277da6ca1bbd421290a7c037a8223764a6de50c (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
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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
#!/bin/bash

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

# This test checks optimistic-change-log option

cleanup
TEST glusterd
TEST pidof glusterd
TEST $CLI volume create $V0 disperse 3 redundancy 1 $H0:$B0/${V0}{0..2}
TEST $CLI volume heal $V0 disable

TEST $CLI volume set $V0 performance.stat-prefetch off
TEST $CLI volume set $V0 performance.write-behind off
TEST $CLI volume set $V0 performance.quick-read off
TEST $CLI volume set $V0 performance.read-ahead off
TEST $CLI volume set $V0 performance.io-cache off
TEST $CLI volume set $V0 disperse.background-heals 0
TEST $CLI volume set $V0 disperse.optimistic-change-log off
TEST $CLI volume set $V0 disperse.eager-lock off
TEST $CLI volume start $V0

TEST $GFS --volfile-id=/$V0 --volfile-server=$H0 $M0;
EXPECT_WITHIN $CHILD_UP_TIMEOUT "3" ec_child_up_count $V0 0
EXPECT_WITHIN $CONFIG_UPDATE_TIMEOUT "0" mount_get_option_value $M0 $V0-disperse-0 background-heals
EXPECT_WITHIN $CONFIG_UPDATE_TIMEOUT "0" mount_get_option_value $M0 $V0-disperse-0 heal-wait-qlength

TEST $CLI volume set $V0 disperse.background-heals 1
TEST touch $M0/a
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" count_sh_entries $B0/${V0}0
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" count_sh_entries $B0/${V0}1
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" count_sh_entries $B0/${V0}2



### optimistic-change-log = off ; All bricks good. Test file operation
echo abc > $M0/a
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

## optimistic-change-log = off ; Kill one brick . Test file operation
TEST kill_brick $V0 $H0 $B0/${V0}2
echo abc > $M0/a
EXPECT 2 get_pending_heal_count $V0 #One for each active brick
$CLI volume start $V0 force
EXPECT_WITHIN $CHILD_UP_TIMEOUT "3" ec_child_up_count $V0 0
#Accessing file should heal the file now
EXPECT "abc" cat $M0/a
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

## optimistic-change-log = off ; All bricks good. Test entry operation
TEST touch $M0/b
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

## optimistic-change-log = off ; All bricks good. Test metadata operation
TEST chmod 0777 $M0/b
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

## optimistic-change-log = off ; Kill one brick. Test entry operation

TEST kill_brick $V0 $H0 $B0/${V0}2
TEST touch $M0/c
EXPECT 4 get_pending_heal_count $V0 #two for each active brick
$CLI volume start $V0 force
EXPECT_WITHIN $CHILD_UP_TIMEOUT "3" ec_child_up_count $V0 0
getfattr -d -m. -e hex $M0 2>&1 > /dev/null
getfattr -d -m. -e hex $M0/c 2>&1 > /dev/null
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

## optimistic-change-log = off ; Kill one brick. Test metadata operation
TEST kill_brick $V0 $H0 $B0/${V0}2
TEST chmod 0777 $M0/c
EXPECT 2 get_pending_heal_count $V0 #One for each active brick
$CLI volume start $V0 force
EXPECT_WITHIN $CHILD_UP_TIMEOUT "3" ec_child_up_count $V0 0
getfattr -d -m. -e hex $M0/c 2>&1 > /dev/null
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

TEST $CLI volume set $V0 disperse.optimistic-change-log on

### optimistic-change-log = on ; All bricks good. Test file operation

echo abc > $M0/aa
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

## optimistic-change-log = on ; Kill one brick. Test file operation

TEST kill_brick $V0 $H0 $B0/${V0}2
echo abc > $M0/aa
EXPECT 2 get_pending_heal_count $V0 #One for each active brick
$CLI volume start $V0 force
EXPECT_WITHIN $CHILD_UP_TIMEOUT "3" ec_child_up_count $V0 0
#Accessing file should heal the file now
getfattr -d -m. -e hex $M0/aa 2>&1 > /dev/null
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

## optimistic-change-log = on ; All bricks good. Test entry operation

TEST touch $M0/bb
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

## optimistic-change-log = on ; All bricks good. Test metadata operation

TEST chmod 0777 $M0/bb
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

## optimistic-change-log = on ; Kill one brick. Test entry operation

TEST kill_brick $V0 $H0 $B0/${V0}2
TEST touch $M0/cc
EXPECT 4 get_pending_heal_count $V0 #two for each active brick
$CLI volume start $V0 force
EXPECT_WITHIN $CHILD_UP_TIMEOUT "3" ec_child_up_count $V0 0
getfattr -d -m. -e hex $M0 2>&1 > /dev/null
getfattr -d -m. -e hex $M0/cc 2>&1 > /dev/null
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

## optimistic-change-log = on ; Kill one brick. Test metadata operation

TEST kill_brick $V0 $H0 $B0/${V0}2
TEST chmod 0777 $M0/cc
EXPECT 2 get_pending_heal_count $V0 #One for each active brick
$CLI volume start $V0 force
EXPECT_WITHIN $CHILD_UP_TIMEOUT "3" ec_child_up_count $V0 0
getfattr -d -m. -e hex $M0/cc 2>&1 > /dev/null
EXPECT_WITHIN $HEAL_TIMEOUT "^0$" get_pending_heal_count $V0

############################################################

cleanup