package com.emc.storageos.coordinator.service.impl; import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; import java.io.File; import java.io.FileInputStream; import java.util.Properties; import com.emc.storageos.coordinator.client.model.Constants; import org.apache.zookeeper.server.quorum.QuorumPeer.LearnerType; import org.apache.zookeeper.server.quorum.QuorumPeer.QuorumServer; import org.junit.Before; import org.junit.Test; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class SpringQuorumPeerConfigTest { private static final Logger log = LoggerFactory.getLogger(SpringQuorumPeerConfigTest.class); private Properties properties; private SpringQuorumPeerConfig springQuorumPeerConfig; @Before public void setup() { properties = new Properties(); properties.setProperty("tickTime", "2000"); properties.setProperty("dataDir", "/tmp/zk"); properties.setProperty("clientPort", "2181"); properties.setProperty("initLimit", "5"); properties.setProperty("syncLimit", "2"); properties.setProperty("server.1", "192.168.1.1,2888,3888"); properties.setProperty("server.2", "hostname,2888,3888"); properties.setProperty("server.3", "[fe80:0:0:0:81fe:4fd:95b1:8bbf],2888,3888"); springQuorumPeerConfig = new SpringQuorumPeerConfig(); } @Test public void testInitWithCustomizedSeperator() throws Exception { springQuorumPeerConfig.setProperties(properties); springQuorumPeerConfig.init(); assertTrue(springQuorumPeerConfig.getServers().size() == 3); QuorumServer server1 = springQuorumPeerConfig.getServers().get(new Long(1)); assertTrue(server1.addr.toString().equals("/192.168.1.1:2888")); assertTrue(server1.electionAddr.toString().equals("/192.168.1.1:3888")); assertTrue(server1.type == LearnerType.PARTICIPANT); QuorumServer server2 = springQuorumPeerConfig.getServers().get(new Long(2)); assertTrue(server2.addr.toString().equals("hostname:2888")); assertTrue(server2.electionAddr.toString().equals("hostname:3888")); assertTrue(server2.type == LearnerType.PARTICIPANT); QuorumServer server3 = springQuorumPeerConfig.getServers().get(new Long(3)); assertTrue(server3.addr.toString().equals("/fe80:0:0:0:81fe:4fd:95b1:8bbf:2888")); assertTrue(server3.electionAddr.toString().equals("/fe80:0:0:0:81fe:4fd:95b1:8bbf:3888")); assertTrue(server3.type == LearnerType.PARTICIPANT); } @Test public void testServerPropertiesHasbeenRemoved() throws Exception { SpringQuorumPeerConfig target = new SpringQuorumPeerConfig() { @Override protected void preprocessQuorumServers(Properties zkProp) throws ConfigException { super.preprocessQuorumServers(zkProp); // check whether server properties are removed for (Object key : zkProp.keySet()) { assertFalse(key.toString().trim().startsWith("server.")); } } }; target.setProperties(properties); target.init(); } }