summaryrefslogtreecommitdiffstats
path: root/tests/bugs/distribute/bug-1122443.t
blob: 3e2455e63821bd30d50194f0cc70e38cc3061fbd (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
#!/bin/bash

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

make_files() {
    mkdir $1 && \
    ln -s ../ $1/symlink && \
    mknod $1/special_b b 1 2 && \
    mknod $1/special_c c 3 4 && \
    mknod $1/special_u u 5 6 && \
    mknod $1/special_p p && \
    touch -h --date=@1 $1/symlink && \
    touch -h --date=@2 $1/special_b &&
    touch -h --date=@3 $1/special_c &&
    touch -h --date=@4 $1/special_u &&
    touch -h --date=@5 $1/special_p
}

bug_1113050_workaround() {
    # Test if graph change has settled (bug-1113050?)
    test=$(stat -c "%n:%Y" $1 2>&1 | tr '\n' ',')
    if [ $? -eq 0 ] ; then
	echo RECONNECTED
    else
	echo WAITING
    fi
    return 0
}

cleanup

TEST glusterd
TEST pidof glusterd

TEST $CLI volume create $V0 $H0:$B0/${V0}0
TEST $CLI volume start $V0

# Mount FUSE and create symlink
TEST glusterfs -s $H0 --volfile-id $V0 $M0
TEST make_files $M0/subdir

# Get mtime before migration
BEFORE="$(stat -c %n:%Y $M0/subdir/* | tr '\n' ',')"

# Migrate brick
TEST $CLI volume add-brick $V0 $H0:$B0/${V0}1
TEST $CLI volume remove-brick $V0 $H0:$B0/${V0}0 start
EXPECT_WITHIN $REBALANCE_TIMEOUT "0" remove_brick_completed
TEST $CLI volume remove-brick $V0 $H0:$B0/${V0}0 commit

# Get mtime after migration
EXPECT_WITHIN 5 RECONNECTED bug_1113050_workaround $M0/subdir/*
AFTER="$(stat -c %n:%Y $M0/subdir/* | tr '\n' ',')"

# Check if mtime is unchanged
TEST [ "$AFTER" == "$BEFORE" ]

cleanup