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
|
// test arbitration
var baseName = "jstests_pair3test";
ismaster = function( n ) {
var im = n.getDB( "admin" ).runCommand( { "ismaster" : 1 } );
print( "ismaster: " + tojson( im ) );
assert( im, "command ismaster failed" );
return im.ismaster;
}
connect = function() {
startMongoProgram( "mongobridge", "--port", alPort, "--dest", "localhost:" + aPort );
startMongoProgram( "mongobridge", "--port", arPort, "--dest", "localhost:" + aPort );
startMongoProgram( "mongobridge", "--port", lpPort, "--dest", "localhost:" + lPort );
startMongoProgram( "mongobridge", "--port", rpPort, "--dest", "localhost:" + rPort );
}
doTest = function() {
ports = allocatePorts( 7 );
aPort = ports[ 0 ];
alPort = ports[ 1 ];
arPort = ports[ 2 ];
lPort = ports[ 3 ];
lpPort = ports[ 4 ];
rPort = ports[ 5 ];
rpPort = ports[ 6 ];
connect();
a = startMongod( "--port", aPort, "--dbpath", "/data/db/" + baseName + "-arbiter", "--nohttpinterface" );
l = startMongod( "--port", lPort, "--dbpath", "/data/db/" + baseName + "-left", "--pairwith", "127.0.0.1:" + rpPort, "127.0.0.1:" + alPort, "--oplogSize", "1", "--nohttpinterface" );
r = startMongod( "--port", rPort, "--dbpath", "/data/db/" + baseName + "-right", "--pairwith", "127.0.0.1:" + lpPort, "127.0.0.1:" + arPort, "--oplogSize", "1", "--nohttpinterface" );
// normal startup
assert.soon( function() {
lm = ismaster( l );
rm = ismaster( r );
assert( lm == -1 || lm == 0, "lm value invalid" );
assert( rm == -1 || rm == 0 || rm == 1, "rm value invalid" );
return ( lm == 0 && rm == 1 );
} );
// disconnect l (slave)
stopMongoProgram( alPort );
stopMongoProgram( lpPort );
stopMongoProgram( rpPort );
assert.soon( function() {
lm = ismaster( l );
rm = ismaster( r );
assert( lm == 0 || lm == -3, "lm value invalid" );
assert( rm == 1, "rm value invalid" );
return ( lm == -3 );
} );
// disconnect r ( master )
stopMongoProgram( arPort );
assert.soon( function() {
rm = ismaster( r );
assert( rm == 1 || rm == -3, "rm value invalid" );
return ( rm == -3 );
} );
// reconnect
connect();
assert.soon( function() {
lm = ismaster( l );
rm = ismaster( r );
assert( lm == -3 || lm == 0, "lm value invalid" );
assert( rm == -3 || rm == 1, "rm value invalid" );
return ( lm == 0 && rm == 1 );
} );
// disconnect r ( master )
stopMongoProgram( arPort );
stopMongoProgram( lpPort );
stopMongoProgram( rpPort );
assert.soon( function() {
lm = ismaster( l );
rm = ismaster( r );
assert( lm == 0 || lm == 1, "lm value invalid" );
assert( rm == 1 || rm == -3, "rm value invalid" );
return ( rm == -3 && lm == 1 );
} );
// disconnect l ( new master )
stopMongoProgram( alPort );
assert.soon( function() {
lm = ismaster( l );
assert( lm == 1 || lm == -3, "lm value invalid" );
return ( lm == -3 );
} );
}
doTest();
|