新增自动注销和自动注册测试用例

This commit is contained in:
lingwei.clw 2018-11-16 10:02:48 +08:00
parent f15d818e74
commit 625f3a9159

View File

@ -20,6 +20,7 @@ import com.alibaba.nacos.api.naming.NamingFactory;
import com.alibaba.nacos.api.naming.NamingService; import com.alibaba.nacos.api.naming.NamingService;
import com.alibaba.nacos.api.naming.pojo.Instance; import com.alibaba.nacos.api.naming.pojo.Instance;
import com.alibaba.nacos.client.naming.NacosNamingService; import com.alibaba.nacos.client.naming.NacosNamingService;
import com.alibaba.nacos.client.naming.beat.BeatInfo;
import com.alibaba.nacos.naming.NamingApp; import com.alibaba.nacos.naming.NamingApp;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Before; import org.junit.Before;
@ -58,8 +59,8 @@ public class AutoDeregisterInstance_ITCase {
public void init() throws Exception { public void init() throws Exception {
if (naming == null) { if (naming == null) {
TimeUnit.SECONDS.sleep(10); TimeUnit.SECONDS.sleep(10);
naming = NamingFactory.createNamingService("127.0.0.1" + ":" + port); // naming = NamingFactory.createNamingService("127.0.0.1" + ":" + port);
// naming = NamingFactory.createNamingService("11.239.112.230:8848,11.239.113.118:8848,11.239.113.156:8848"); naming = NamingFactory.createNamingService("11.239.113.204:8848,11.239.112.161:8848,11.239.114.187:8848");
} }
} }
@ -68,15 +69,15 @@ public class AutoDeregisterInstance_ITCase {
/** /**
* 客户端停止上报实例心跳服务端自动注销实例 * 指定cluster中单个多个实例客户端停止上报实例心跳服务端自动注销实例
* *
* @throws Exception * @throws Exception
*/ */
@Test @Test
public void autoDregDomTest() throws Exception { public void autoDregDomClustersTest() throws Exception {
String serviceName = randomDomainName(); String serviceName = randomDomainName();
// String serviceName="test.1"; // String serviceName="jinhanH0Gkc.cyS1n.com";
System.out.println(serviceName); System.out.println(serviceName);
naming.registerInstance(serviceName, "127.0.0.1", TEST_PORT,"c1"); naming.registerInstance(serviceName, "127.0.0.1", TEST_PORT,"c1");
@ -93,12 +94,10 @@ public class AutoDeregisterInstance_ITCase {
namingServiceImpl.getBeatReactor().removeBeatInfo(serviceName, "127.0.0.1", TEST_PORT); namingServiceImpl.getBeatReactor().removeBeatInfo(serviceName, "127.0.0.1", TEST_PORT);
TimeUnit.SECONDS.sleep(35); TimeUnit.SECONDS.sleep(40);
instances = naming.getAllInstances(serviceName); instances = naming.getAllInstances(serviceName);
// TimeUnit.SECONDS.sleep(1000000L);
Assert.assertEquals(1, instances.size()); Assert.assertEquals(1, instances.size());
instances = naming.getAllInstances(serviceName, Arrays.asList("c2")); instances = naming.getAllInstances(serviceName, Arrays.asList("c2"));
@ -107,7 +106,41 @@ public class AutoDeregisterInstance_ITCase {
instances = naming.getAllInstances(serviceName, Arrays.asList("c1")); instances = naming.getAllInstances(serviceName, Arrays.asList("c1"));
Assert.assertEquals(0, instances.size()); Assert.assertEquals(0, instances.size());
// TimeUnit.SECONDS.sleep(1000000L); }
/**
* 客户端停止上报实例心跳服务端自动注销实例
*
* @throws Exception
*/
@Test
public void autoDregDomTest() throws Exception {
String serviceName = randomDomainName();
// String serviceName="jinhanH0Gkc.cyS1n.com";
// System.out.println(serviceName);
naming.registerInstance(serviceName, "127.0.0.1", TEST_PORT);
naming.registerInstance(serviceName, "127.0.0.2", TEST_PORT);
TimeUnit.SECONDS.sleep(5);
List<Instance> instances;
instances = naming.getAllInstances(serviceName);
Assert.assertEquals(2, instances.size());
NacosNamingService namingServiceImpl = (NacosNamingService) naming;
namingServiceImpl.getBeatReactor().removeBeatInfo(serviceName, "127.0.0.1", TEST_PORT);
TimeUnit.SECONDS.sleep(40);
instances = naming.getAllInstances(serviceName);
Assert.assertEquals(1, instances.size());
} }
@ -136,15 +169,78 @@ public class AutoDeregisterInstance_ITCase {
namingServiceImpl.getBeatReactor().removeBeatInfo(serviceName, "127.0.0.1", TEST_PORT); namingServiceImpl.getBeatReactor().removeBeatInfo(serviceName, "127.0.0.1", TEST_PORT);
TimeUnit.SECONDS.sleep(35); TimeUnit.SECONDS.sleep(40);
// namingServiceImpl.getBeatReactor(). instances = naming.getAllInstances(serviceName);
Assert.assertEquals(instances.size(), 1);
BeatInfo beatInfo=new BeatInfo();
beatInfo.setDom(serviceName);
beatInfo.setIp("127.0.0.1");
beatInfo.setPort(TEST_PORT);
namingServiceImpl.getBeatReactor().addBeatInfo(serviceName,beatInfo);
TimeUnit.SECONDS.sleep(15);
instances = naming.getAllInstances(serviceName);
Assert.assertEquals(instances.size(), 2);
}
/**
* 指定cluster中单个多个实例,客户端停止上报实例心跳服务端自动注销实例,恢复心跳服务端自动注册实例
*
* @throws Exception
*/
@Test
public void autoRegDomClustersTest() throws Exception {
String serviceName = randomDomainName();
naming.registerInstance(serviceName, "127.0.0.1", TEST_PORT,"c1");
naming.registerInstance(serviceName, "127.0.0.2", TEST_PORT,"c2");
TimeUnit.SECONDS.sleep(5);
List<Instance> instances;
instances = naming.getAllInstances(serviceName);
Assert.assertEquals( 2,instances.size());
NacosNamingService namingServiceImpl = (NacosNamingService) naming;
namingServiceImpl.getBeatReactor().removeBeatInfo(serviceName, "127.0.0.1", TEST_PORT);
TimeUnit.SECONDS.sleep(40);
instances = naming.getAllInstances(serviceName);
Assert.assertEquals(instances.size(), 1);
BeatInfo beatInfo=new BeatInfo();
beatInfo.setDom(serviceName);
beatInfo.setIp("127.0.0.1");
beatInfo.setPort(TEST_PORT);
beatInfo.setCluster("c1");
namingServiceImpl.getBeatReactor().addBeatInfo(serviceName,beatInfo);
TimeUnit.SECONDS.sleep(15);
instances = naming.getAllInstances(serviceName);
Assert.assertEquals(instances.size(), 2);
instances = naming.getAllInstances(serviceName, Arrays.asList("c2"));
Assert.assertEquals(1,instances.size());
instances = naming.getAllInstances(serviceName, Arrays.asList("c1"));
Assert.assertEquals(1, instances.size());
} }
} }