summaryrefslogtreecommitdiffstats
path: root/tests/basic/afr/halo.t
blob: 3f61f5a0402b81974d2a50870d50891f0fda9dea (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
#!/bin/bash
#Tests that halo basic functionality works as expected

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

cleanup;

function get_up_child()
{
    if [ "1" == $(afr_private_key_value $V0 $M0 0 "child_up\[0\]") ];
    then
        echo 0
    elif [ "1" == $(afr_private_key_value $V0 $M0 0 "child_up\[1\]") ]
    then
        echo 1
    fi
}

TEST glusterd
TEST pidof glusterd
TEST $CLI volume create $V0 replica 2 $H0:$B0/${V0}{0,1}
TEST $CLI volume set $V0 cluster.halo-enabled yes
TEST $CLI volume set $V0 cluster.halo-max-replicas 1
TEST $CLI volume start $V0
TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0;
EXPECT "^1$" afr_private_key_value $V0 $M0 0 "halo_child_up\[0\]"
EXPECT "^1$" afr_private_key_value $V0 $M0 0 "halo_child_up\[1\]"
EXPECT_NOT "^-1$" afr_private_key_value $V0 $M0 0 "child_latency\[0\]"
EXPECT_NOT "^-1$" afr_private_key_value $V0 $M0 0 "child_latency\[1\]"

up_id=$(get_up_child)
TEST [[ ! -z "$up_id" ]]

down_id=$((1-up_id))

TEST kill_brick $V0 $H0 $B0/${V0}${up_id}
#As max-replicas is configured to be 1, down_child should be up now
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT "^1$" afr_private_key_value $V0 $M0 0 "halo_child_up\[${down_id}\]"
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT "^1$" afr_private_key_value $V0 $M0 0 "child_up\[${down_id}\]"
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT "^0$" afr_private_key_value $V0 $M0 0 "halo_child_up\[${up_id}\]"
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT "^0$" afr_private_key_value $V0 $M0 0 "child_up\[${up_id}\]"
EXPECT "^-1$" afr_private_key_value $V0 $M0 0 "child_latency\[${up_id}\]"
EXPECT_NOT "^-1$" afr_private_key_value $V0 $M0 0 "child_latency\[${down_id}\]"

#Bring the brick back up and the state should be restored
TEST $CLI volume start $V0 force
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "^1$" afr_private_key_value $V0 $M0 0 "halo_child_up\[${up_id}\]"

up_id=$(get_up_child)
TEST [[ ! -z "$up_id" ]]
down_id=$((1-up_id))
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT "^1$" afr_private_key_value $V0 $M0 0 "halo_child_up\[${down_id}\]"
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT "^0$" afr_private_key_value $V0 $M0 0 "child_up\[${down_id}\]"
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT "^1$" afr_private_key_value $V0 $M0 0 "halo_child_up\[${up_id}\]"
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT "^1$" afr_private_key_value $V0 $M0 0 "child_up\[${up_id}\]"
EXPECT_NOT "^-1$" afr_private_key_value $V0 $M0 0 "child_latency\[0\]"
EXPECT_NOT "^-1$" afr_private_key_value $V0 $M0 0 "child_latency\[1\]"

cleanup;