aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSimon Brandhof <simon.brandhof@sonarsource.com>2017-09-21 15:45:30 +0200
committerSimon Brandhof <simon.brandhof@sonarsource.com>2017-09-26 23:49:38 +0200
commitb3968feb20e92cdc5c3252bf922293877e8b65df (patch)
treed6fc5d553885aa3fec3a0939fe29ba83c792bc43
parente401e830cd5eb2c52ad1a2749bd3cb9a3a2690b6 (diff)
downloadsonarqube-b3968feb20e92cdc5c3252bf922293877e8b65df.tar.gz
sonarqube-b3968feb20e92cdc5c3252bf922293877e8b65df.zip
SONAR-9802 fix support of overridden cluster name
-rw-r--r--server/sonar-main/src/main/java/org/sonar/application/AppStateFactory.java1
-rw-r--r--server/sonar-main/src/test/java/org/sonar/application/cluster/ClusterAppStateImplTest.java1
-rw-r--r--server/sonar-process/src/main/java/org/sonar/process/cluster/hz/HazelcastMemberBuilder.java12
-rw-r--r--server/sonar-process/src/test/java/org/sonar/process/cluster/hz/HazelcastMemberBuilderTest.java1
-rw-r--r--server/sonar-process/src/test/java/org/sonar/process/cluster/hz/HazelcastMemberImplTest.java1
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/cluster/StartableHazelcastMember.java1
-rw-r--r--tests/src/test/java/org/sonarqube/tests/cluster/ClusterTest.java18
7 files changed, 23 insertions, 12 deletions
diff --git a/server/sonar-main/src/main/java/org/sonar/application/AppStateFactory.java b/server/sonar-main/src/main/java/org/sonar/application/AppStateFactory.java
index 0498f2e4100..75f1577c432 100644
--- a/server/sonar-main/src/main/java/org/sonar/application/AppStateFactory.java
+++ b/server/sonar-main/src/main/java/org/sonar/application/AppStateFactory.java
@@ -49,7 +49,6 @@ public class AppStateFactory {
private static HazelcastMember createHzMember(Props props) {
HazelcastMemberBuilder builder = new HazelcastMemberBuilder()
- .setClusterName("sonarqube")
.setNetworkInterface(props.nonNullValue(ProcessProperties.CLUSTER_NODE_HOST))
.setMembers(asList(props.nonNullValue(ProcessProperties.CLUSTER_HOSTS).split(",")))
.setNodeType(NodeType.parse(props.nonNullValue(ProcessProperties.CLUSTER_NODE_TYPE)))
diff --git a/server/sonar-main/src/test/java/org/sonar/application/cluster/ClusterAppStateImplTest.java b/server/sonar-main/src/test/java/org/sonar/application/cluster/ClusterAppStateImplTest.java
index ba85353df39..7af7c97e83f 100644
--- a/server/sonar-main/src/test/java/org/sonar/application/cluster/ClusterAppStateImplTest.java
+++ b/server/sonar-main/src/test/java/org/sonar/application/cluster/ClusterAppStateImplTest.java
@@ -141,7 +141,6 @@ public class ClusterAppStateImplTest {
return new HazelcastMemberBuilder()
.setNodeType(NodeType.APPLICATION)
.setProcessId(ProcessId.COMPUTE_ENGINE)
- .setClusterName("foo")
.setNodeName("bar")
.setPort(NetworkUtilsImpl.INSTANCE.getNextAvailablePort(loopback))
.setNetworkInterface(loopback.getHostAddress())
diff --git a/server/sonar-process/src/main/java/org/sonar/process/cluster/hz/HazelcastMemberBuilder.java b/server/sonar-process/src/main/java/org/sonar/process/cluster/hz/HazelcastMemberBuilder.java
index 55a5dd0a4ed..73ba63abfa4 100644
--- a/server/sonar-process/src/main/java/org/sonar/process/cluster/hz/HazelcastMemberBuilder.java
+++ b/server/sonar-process/src/main/java/org/sonar/process/cluster/hz/HazelcastMemberBuilder.java
@@ -41,7 +41,6 @@ import static java.util.Objects.requireNonNull;
public class HazelcastMemberBuilder {
- private String clusterName;
private String nodeName;
private int port;
private NodeType nodeType;
@@ -49,11 +48,6 @@ public class HazelcastMemberBuilder {
private String networkInterface;
private List<String> members = new ArrayList<>();
- public HazelcastMemberBuilder setClusterName(String s) {
- this.clusterName = s;
- return this;
- }
-
public HazelcastMemberBuilder setNodeName(String s) {
this.nodeName = s;
return this;
@@ -97,7 +91,11 @@ public class HazelcastMemberBuilder {
public HazelcastMember build() {
Config config = new Config();
- config.getGroupConfig().setName(requireNonNull(clusterName, "Cluster name is missing"));
+ // do not use the value defined by property sonar.cluster.name.
+ // Hazelcast does not fail when joining a cluster with different name.
+ // Apparently this behavior exists since Hazelcast 3.8.2 (see note
+ // at http://docs.hazelcast.org/docs/3.8.6/manual/html-single/index.html#creating-cluster-groups)
+ config.getGroupConfig().setName("SonarQube");
// Configure network
NetworkConfig netConfig = config.getNetworkConfig();
diff --git a/server/sonar-process/src/test/java/org/sonar/process/cluster/hz/HazelcastMemberBuilderTest.java b/server/sonar-process/src/test/java/org/sonar/process/cluster/hz/HazelcastMemberBuilderTest.java
index 6a4973b8d13..b01223d7616 100644
--- a/server/sonar-process/src/test/java/org/sonar/process/cluster/hz/HazelcastMemberBuilderTest.java
+++ b/server/sonar-process/src/test/java/org/sonar/process/cluster/hz/HazelcastMemberBuilderTest.java
@@ -47,7 +47,6 @@ public class HazelcastMemberBuilderTest {
HazelcastMember member = underTest
.setNodeType(NodeType.APPLICATION)
.setProcessId(ProcessId.COMPUTE_ENGINE)
- .setClusterName("foo")
.setNodeName("bar")
.setPort(NetworkUtilsImpl.INSTANCE.getNextAvailablePort(loopback))
.setNetworkInterface(loopback.getHostAddress())
diff --git a/server/sonar-process/src/test/java/org/sonar/process/cluster/hz/HazelcastMemberImplTest.java b/server/sonar-process/src/test/java/org/sonar/process/cluster/hz/HazelcastMemberImplTest.java
index 4d83a82f233..3bf649baecd 100644
--- a/server/sonar-process/src/test/java/org/sonar/process/cluster/hz/HazelcastMemberImplTest.java
+++ b/server/sonar-process/src/test/java/org/sonar/process/cluster/hz/HazelcastMemberImplTest.java
@@ -114,7 +114,6 @@ public class HazelcastMemberImplTest {
return new HazelcastMemberBuilder()
.setNodeType(NodeType.APPLICATION)
.setProcessId(ProcessId.COMPUTE_ENGINE)
- .setClusterName("foo")
.setNodeName("name" + port)
.setPort(port)
.setNetworkInterface(loopback.getHostAddress())
diff --git a/server/sonar-server/src/main/java/org/sonar/server/cluster/StartableHazelcastMember.java b/server/sonar-server/src/main/java/org/sonar/server/cluster/StartableHazelcastMember.java
index 1e430e17d29..7bf6c82d487 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/cluster/StartableHazelcastMember.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/cluster/StartableHazelcastMember.java
@@ -140,7 +140,6 @@ public class StartableHazelcastMember implements HazelcastMember, Startable {
throw new IllegalStateException(format("Can not resolve address %s", networkAddress), e);
}
this.member = new HazelcastMemberBuilder()
- .setClusterName(config.get(ProcessProperties.CLUSTER_NAME).orElseThrow(() -> new IllegalStateException("Missing cluster name")))
.setNodeName(config.get(ProcessProperties.CLUSTER_NODE_NAME).orElseThrow(() -> new IllegalStateException("Missing node name")))
.setNodeType(NodeType.parse(config.get(CLUSTER_NODE_TYPE).orElseThrow(() -> new IllegalStateException("Missing node type"))))
.setPort(freePort)
diff --git a/tests/src/test/java/org/sonarqube/tests/cluster/ClusterTest.java b/tests/src/test/java/org/sonarqube/tests/cluster/ClusterTest.java
index 169e9a2caad..b7221c8bb03 100644
--- a/tests/src/test/java/org/sonarqube/tests/cluster/ClusterTest.java
+++ b/tests/src/test/java/org/sonarqube/tests/cluster/ClusterTest.java
@@ -233,6 +233,24 @@ public class ClusterTest {
}
@Test
+ public void cluster_name_can_be_overridden() throws Exception {
+ try (Cluster cluster = new Cluster("foo")) {
+ NodeConfig searchConfig1 = newSearchConfig("Search 1");
+ NodeConfig searchConfig2 = newSearchConfig("Search 2");
+ NodeConfig appConfig = newApplicationConfig("App 1");
+ NodeConfig.interconnectBus(searchConfig1, searchConfig2, appConfig);
+ NodeConfig.interconnectSearch(searchConfig1, searchConfig2, appConfig);
+
+ cluster.startNode(searchConfig1, nothing());
+ cluster.startNode(searchConfig2, nothing());
+ cluster.startNode(appConfig, nothing());
+
+ Node appNode = cluster.getAppNode(0);
+ appNode.waitForStatusUp();
+ }
+ }
+
+ @Test
public void node_fails_to_join_cluster_if_different_cluster_name() throws Exception {
try (Cluster cluster = new Cluster("foo")) {
NodeConfig searchConfig1 = newSearchConfig("Search 1");