3
. $(dirname $0)/../../include.rc
4
. $(dirname $0)/../../volume.rc
9
TEST $CLI volume create $V0 replica 3 $H0:$B0/${V0}{0,1,2}
10
TEST $CLI volume set $V0 features.shard on
11
TEST $CLI volume set $V0 features.shard-block-size 4MB
12
TEST $CLI volume set $V0 features.shard-lru-limit 25
13
TEST $CLI volume start $V0
14
EXPECT 'Started' volinfo_field $V0 'Status';
15
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}0
16
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}1
17
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}2
19
TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0
21
# Perform a write that would cause 25 shards to be created, 24 of them under .shard
22
TEST dd if=/dev/zero of=$M0/foo bs=1M count=100
24
statedump=$(generate_mount_statedump $V0)
26
EXPECT "25" echo $(grep "lru-max-limit" $statedump | cut -f2 -d'=' | tail -1)
28
# Base shard is never added to this list. So all other shards should make up for 24 inodes in lru list
29
EXPECT "24" echo $(grep "inode-count" $statedump | cut -f2 -d'=' | tail -1)
33
# Test to ensure there's no "reconfiguration" of the value once set.
34
TEST $CLI volume set $V0 features.shard-lru-limit 30
35
statedump=$(generate_mount_statedump $V0)
37
EXPECT "25" echo $(grep "lru-max-limit" $statedump | cut -f2 -d'=' | tail -1)
40
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
42
TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0
43
statedump=$(generate_mount_statedump $V0)
45
EXPECT "30" echo $(grep "lru-max-limit" $statedump | cut -f2 -d'=' | tail -1)
48
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
49
TEST $CLI volume stop $V0
50
TEST $CLI volume delete $V0