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
|
/**
* Ensure that IPs cannot be used as hostnames for split horizon configurations.
* Incompatible with the ephemeral storage engine; replSetInitiate does not work correctly.
* @tags: [ incompatible_with_eft ]
*/
(function() {
"use strict";
// Tests that when replSetInitiate/Reconfig are called with one member with the given host name and
// horizon name, with the given mongod startup options, we fail the split horizon IP check if
// expectedReject.
function testConfig(hostName, horizonName, expectedReject, options = {}) {
const mongod = MongoRunner.runMongod(Object.assign({replSet: "test"}, options));
const config = {
_id: "test",
members: [{_id: 0, host: hostName, horizons: {"horizon_name": horizonName}}]
};
// Make sure replSetInitiate fails with correct error
let output = mongod.adminCommand({replSetInitiate: config});
jsTestLog("Command result: " + tojson(output));
assert.eq(output.ok, 0);
assert.eq(output.errmsg.includes("Found split horizon configuration using IP"), expectedReject);
// Correctly start up a replset with the mongod as its node, and wait until it becomes primary
assert.commandWorked(mongod.adminCommand(
{replSetInitiate: {_id: "test", members: [{_id: 0, host: "localhost:" + mongod.port}]}}));
assert.soon(() => {
return assert.commandWorked(mongod.adminCommand({hello: 1})).isWritablePrimary;
});
// Make sure replSetReconfig fails with correct error
config.version = 2;
output = mongod.adminCommand({"replSetReconfig": config});
jsTestLog("Command result: " + tojson(output));
assert.eq(output.ok, 0);
assert.eq(output.errmsg.includes("Found split horizon configuration using IP"), expectedReject);
MongoRunner.stopMongod(mongod);
}
testConfig("a", "b", false);
// Hostname being an IP is fine
testConfig("12.34.56.78", "a", false);
// Any valid CIDR will fail the check
testConfig("a", "12.34.56.78", true);
testConfig("a", "12.34.56.78/20", true);
// Make sure setting this parameter disables the check
testConfig("a", "12.34.56.78", false, {setParameter: {disableSplitHorizonIPCheck: true}});
testConfig("a", "12.34.56.78/20", false, {setParameter: {disableSplitHorizonIPCheck: true}});
}());
|