glusterfs
46 строк · 1.6 Кб
1#!/bin/bash
2
3. $(dirname $0)/../../include.rc
4. $(dirname $0)/../../volume.rc
5. $(dirname $0)/../../cluster.rc
6
7SCRIPT_TIMEOUT=300
8
9cleanup;
10
11TEST launch_cluster 2;
12TEST $CLI_1 peer probe $H2;
13EXPECT_WITHIN $PROBE_TIMEOUT 1 peer_count
14
15$CLI_1 volume create $V0 $H1:$B1/$V0 $H2:$B2/$V0
16EXPECT 'Created' cluster_volinfo_field 1 $V0 'Status';
17
18$CLI_1 volume start $V0
19EXPECT 'Started' cluster_volinfo_field 1 $V0 'Status';
20
21TEST glusterfs -s $H1 --volfile-id $V0 $M0;
22TEST mkdir $M0/dir1
23
24# Create a large file (4 GB), so that rebalance takes time
25# Since we really don't care about the contents of the file, we use fallocate
26# to generate the file much faster. We could also use truncate, which is even
27# faster, but rebalance could take advantage of an sparse file and migrate it
28# in an optimized way, but we don't want a fast migration.
29TEST fallocate -l 4G $M0/dir1/foo
30
31TEST mv $M0/dir1/foo $M0/dir1/bar
32
33TEST $CLI_1 volume rebalance $V0 start force
34TEST ! $CLI_1 volume set $V0 parallel-readdir on
35EXPECT_WITHIN $REBALANCE_TIMEOUT "completed" cluster_rebalance_status_field 1 $V0
36EXPECT_WITHIN $REBALANCE_TIMEOUT "completed" cluster_rebalance_status_field 2 $V0
37TEST $CLI_1 volume set $V0 parallel-readdir on
38TEST mv $M0/dir1/bar $M0/dir1/foo
39
40EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
41TEST glusterfs -s $H1 --volfile-id $V0 $M0;
42TEST $CLI_1 volume rebalance $V0 start force
43TEST ln $M0/dir1/foo $M0/dir1/bar
44EXPECT_WITHIN $REBALANCE_TIMEOUT "completed" cluster_rebalance_status_field 1 $V0
45EXPECT_WITHIN $REBALANCE_TIMEOUT "completed" cluster_rebalance_status_field 2 $V0
46cleanup;
47