Merge remote-tracking branch 'origin/feature_naming_group' into feature_naming_group

This commit is contained in:
nkorange 2019-03-06 17:01:36 +08:00
commit d741c02259
4 changed files with 214 additions and 14 deletions

View File

@ -207,7 +207,6 @@ public class MultiTenant_ITCase {
@Test @Test
public void multipleTenant_group_equalIP() throws Exception { public void multipleTenant_group_equalIP() throws Exception {
String serviceName = randomDomainName(); String serviceName = randomDomainName();
System.out.println(serviceName);
naming1.registerInstance(serviceName, TEST_GROUP_1,"11.11.11.11", 80); naming1.registerInstance(serviceName, TEST_GROUP_1,"11.11.11.11", 80);
naming2.registerInstance(serviceName, TEST_GROUP_2,"11.11.11.11", 80); naming2.registerInstance(serviceName, TEST_GROUP_2,"11.11.11.11", 80);
@ -284,17 +283,18 @@ public class MultiTenant_ITCase {
public void multipleTenant_group_getServicesOfServer() throws Exception { public void multipleTenant_group_getServicesOfServer() throws Exception {
String serviceName = randomDomainName(); String serviceName = randomDomainName();
naming1.registerInstance(serviceName, "11.11.11.11", TEST_GROUP_1, TEST_PORT, "c1"); naming1.registerInstance(serviceName, TEST_GROUP_1, "11.11.11.11", TEST_PORT, "c1");
naming1.registerInstance(serviceName, "22.22.22.22", TEST_GROUP_2, TEST_PORT, "c1"); naming1.registerInstance(serviceName, TEST_GROUP_2, "22.22.22.22", TEST_PORT, "c1");
TimeUnit.SECONDS.sleep(5L); TimeUnit.SECONDS.sleep(5L);
ListView<String> listView = naming1.getServicesOfServer(1, 20); //服务不会删除实例会注销
Assert.assertEquals(0, listView.getCount()); ListView<String> listView = naming1.getServicesOfServer(1, 20, TEST_GROUP_1);
naming2.registerInstance(serviceName, "33.33.33.33", TEST_PORT, "c1"); naming2.registerInstance(serviceName, "33.33.33.33", TEST_PORT, "c1");
TimeUnit.SECONDS.sleep(5L); TimeUnit.SECONDS.sleep(5L);
ListView<String> listView1 = naming1.getServicesOfServer(1, 20, TEST_GROUP_1); ListView<String> listView1 = naming1.getServicesOfServer(1, 20, TEST_GROUP_1);
Assert.assertEquals(listView.getCount(), listView1.getCount()); Assert.assertEquals(listView.getCount(), listView1.getCount());
Assert.assertNotEquals(0, listView1.getCount());
} }
/** /**

View File

@ -130,6 +130,50 @@ public class MultiTenant_InstanceAPI_ITCase {
Assert.assertEquals(2, json.getJSONArray("hosts").size()); Assert.assertEquals(2, json.getJSONArray("hosts").size());
} }
/**
* @TCDescription : 多租户, 多group下, 注册IPlistInstance接口
* @TestStep :
* @ExpectResult :
*/
@Test
public void multipleTenant_group_listInstance() throws Exception {
String serviceName = randomDomainName();
naming1.registerInstance(serviceName, TEST_GROUP_1,"11.11.11.11", 80);
naming1.registerInstance(serviceName,"22.22.22.22", 80);
naming.registerInstance(serviceName, TEST_GROUP_1,"33.33.33.33", 8888);
naming.registerInstance(serviceName, TEST_GROUP_2,"44.44.44.44", 8888);
TimeUnit.SECONDS.sleep(5L);
String url = "/nacos/v1/ns/instance/list";
ResponseEntity<String> response = request(url,
Params.newParams()
.appendParam("serviceName", serviceName)
.appendParam("namespaceId", "namespace-1")
.appendParam("groupName", TEST_GROUP_1)
.done(),
String.class);
Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
JSONObject json = JSON.parseObject(response.getBody());
Assert.assertEquals("11.11.11.11", json.getJSONArray("hosts").getJSONObject(0).getString("ip"));
response = request(url,
Params.newParams()
.appendParam("serviceName", serviceName)
.appendParam("groupName", TEST_GROUP_1)
.done(),
String.class);
Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
json = JSON.parseObject(response.getBody());
Assert.assertEquals(1, json.getJSONArray("hosts").size());
Assert.assertEquals("33.33.33.33", json.getJSONArray("hosts").getJSONObject(0).getString("ip"));
}
/** /**
* @TCDescription : 多租户注册IPgetInstance接口 * @TCDescription : 多租户注册IPgetInstance接口
* @TestStep : * @TestStep :
@ -143,7 +187,7 @@ public class MultiTenant_InstanceAPI_ITCase {
naming2.registerInstance(serviceName, "22.22.22.22", 80); naming2.registerInstance(serviceName, "22.22.22.22", 80);
naming.registerInstance(serviceName, "33.33.33.33", 8888); naming.registerInstance(serviceName, "33.33.33.33", 8888, "c1");
naming.registerInstance(serviceName, "44.44.44.44", 8888); naming.registerInstance(serviceName, "44.44.44.44", 8888);
TimeUnit.SECONDS.sleep(5L); TimeUnit.SECONDS.sleep(5L);
@ -161,17 +205,60 @@ public class MultiTenant_InstanceAPI_ITCase {
response = request("/nacos/v1/ns/instance/list", response = request("/nacos/v1/ns/instance/list",
Params.newParams() Params.newParams()
.appendParam("serviceName", serviceName) .appendParam("serviceName", serviceName)
.appendParam("ip", "33.33.33.33") .appendParam("clusters", "c1")
.appendParam("port", "8888") .appendParam("healthyOnly", "true")
.done(), .done(),
String.class); String.class);
Assert.assertTrue(response.getStatusCode().is2xxSuccessful()); Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
JSONObject json = JSON.parseObject(response.getBody()); JSONObject json = JSON.parseObject(response.getBody());
Assert.assertEquals(2, json.getJSONArray("hosts").size()); Assert.assertEquals(1, json.getJSONArray("hosts").size());
Assert.assertEquals("33.33.33.33", json.getJSONArray("hosts").getJSONObject(0).getString("ip"));
} }
/** /**
* @TCDescription : 多租户注册IPdeleteInstance接口 * @TCDescription : 多租户注册IPgetInstance接口
* @TestStep :
* @ExpectResult :
*/
@Test
public void multipleTenant_group_getInstance() throws Exception {
String serviceName = randomDomainName();
naming1.registerInstance(serviceName, "11.11.11.11", 80);
naming2.registerInstance(serviceName, "22.22.22.22", 80);
naming.registerInstance(serviceName, "33.33.33.33", 8888, "c1");
naming.registerInstance(serviceName, "44.44.44.44", 8888, "c2");
TimeUnit.SECONDS.sleep(5L);
ResponseEntity<String> response = request("/nacos/v1/ns/instance",
Params.newParams()
.appendParam("serviceName", serviceName)
.appendParam("groupName", TEST_GROUP_1)
.appendParam("ip", "33.33.33.33") //不存在的IP隔离验证
.appendParam("port", "8888")
.appendParam("namespaceId", "namespace-2")
.done(),
String.class);
Assert.assertEquals(HttpStatus.NOT_FOUND, response.getStatusCode());
response = request("/nacos/v1/ns/instance/list",
Params.newParams()
.appendParam("serviceName", serviceName)
.appendParam("clusters", "c2")
.appendParam("healthyOnly", "true")
.done(),
String.class);
Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
JSONObject json = JSON.parseObject(response.getBody());
Assert.assertEquals(1, json.getJSONArray("hosts").size());
Assert.assertEquals("44.44.44.44", json.getJSONArray("hosts").getJSONObject(0).getString("ip"));
}
/**
* @TCDescription : 多租户注册IPdeleteInstance接口删除namespace-1中没有的IP
* @TestStep : * @TestStep :
* @ExpectResult : * @ExpectResult :
*/ */
@ -209,6 +296,45 @@ public class MultiTenant_InstanceAPI_ITCase {
Assert.assertEquals(2, json.getJSONArray("hosts").size()); Assert.assertEquals(2, json.getJSONArray("hosts").size());
} }
/**
* @TCDescription : 多租户注册IPgroup下deleteInstance接口正常删除IP
* @TestStep :
* @ExpectResult :
*/
@Test
public void multipleTenant_group_deleteInstance() throws Exception {
String serviceName = randomDomainName();
naming1.registerInstance(serviceName, TEST_GROUP_1,"11.11.11.11", 80);
naming2.registerInstance(serviceName, TEST_GROUP_2,"22.22.22.22", 80);
TimeUnit.SECONDS.sleep(5L);
ResponseEntity<String> response = request("/nacos/v1/ns/instance",
Params.newParams()
.appendParam("serviceName", serviceName)
.appendParam("namespaceId", "namespace-2") //删除namespace-1中没有的IP
.appendParam("groupName", TEST_GROUP_2)
.appendParam("ip", "22.22.22.22")
.appendParam("port", TEST_PORT3_4_DOM_1)
.done(),
String.class,
HttpMethod.DELETE);
Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
response = request("/nacos/v1/ns/instance/list",
Params.newParams()
.appendParam("serviceName", serviceName) //获取naming中的实例
.appendParam("namespaceId", "namespace-2")
.appendParam("groupName", TEST_GROUP_2)
.done(),
String.class);
Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
JSONObject json = JSON.parseObject(response.getBody());
Assert.assertEquals(0, json.getJSONArray("hosts").size());
}
/** /**
* @TCDescription : 多租户注册IPputInstance接口 * @TCDescription : 多租户注册IPputInstance接口
* @TestStep : * @TestStep :
@ -235,7 +361,6 @@ public class MultiTenant_InstanceAPI_ITCase {
.done(), .done(),
String.class, String.class,
HttpMethod.PUT); HttpMethod.PUT);
System.out.println(response.getBody());
Assert.assertTrue(response.getStatusCode().is2xxSuccessful()); Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
response = request("/nacos/v1/ns/instance/list", response = request("/nacos/v1/ns/instance/list",
@ -261,6 +386,46 @@ public class MultiTenant_InstanceAPI_ITCase {
Assert.assertEquals(1, json.getJSONArray("hosts").size()); Assert.assertEquals(1, json.getJSONArray("hosts").size());
} }
/**
* @TCDescription : 多租户, 多group下注册IPputInstance接口, 更新实例
* @TestStep :
* @ExpectResult :
*/
@Test
public void multipleTenant_group_putInstance() throws Exception {
String serviceName = randomDomainName();
naming1.registerInstance(serviceName, "11.11.11.11", 80);
naming2.registerInstance(serviceName, TEST_GROUP_2,"22.22.22.22", 80);
TimeUnit.SECONDS.sleep(5L);
ResponseEntity<String> response = request("/nacos/v1/ns/instance",
Params.newParams()
.appendParam("serviceName", serviceName)
.appendParam("groupName", TEST_GROUP_2)
.appendParam("ip", "22.22.22.22")
.appendParam("port", "80")
.appendParam("namespaceId", "namespace-2")
.appendParam("weight", "8.0")
.done(),
String.class,
HttpMethod.PUT);
Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
response = request("/nacos/v1/ns/instance/list",
Params.newParams()
.appendParam("serviceName", serviceName) //获取naming中的实例
.appendParam("namespaceId", "namespace-2")
.appendParam("groupName", TEST_GROUP_2)
.done(),
String.class);
Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
JSONObject json = JSON.parseObject(response.getBody());
Assert.assertEquals(1, json.getJSONArray("hosts").size());
Assert.assertEquals("8.0", json.getJSONArray("hosts").getJSONObject(0).getString("weight"));
}
/** /**
* @TCDescription : 多租户注册IPupdate一个没有的实例接口 * @TCDescription : 多租户注册IPupdate一个没有的实例接口
* @TestStep : * @TestStep :
@ -309,10 +474,46 @@ public class MultiTenant_InstanceAPI_ITCase {
String.class); String.class);
Assert.assertTrue(response.getStatusCode().is2xxSuccessful()); Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
json = JSON.parseObject(response.getBody()); json = JSON.parseObject(response.getBody());
System.out.println(json);
Assert.assertEquals(1, json.getJSONArray("hosts").size()); Assert.assertEquals(1, json.getJSONArray("hosts").size());
} }
/**
* @TCDescription : 多租户,多group下注册IP注册一个没有的实例接口
* @TestStep :
* @ExpectResult :
*/
@Test
public void multipleTenant_group_updateInstance_notExsitInstance() throws Exception {
String serviceName = randomDomainName();
naming1.registerInstance(serviceName, "11.11.11.11", 80);
naming2.registerInstance(serviceName, "22.22.22.22", 80);
TimeUnit.SECONDS.sleep(5L);
ResponseEntity<String> response = request("/nacos/v1/ns/instance",
Params.newParams()
.appendParam("serviceName", serviceName)
.appendParam("ip", "33.33.33.33")
.appendParam("port", "8888")
.appendParam("namespaceId", "namespace-1") //新增
.appendParam("groupName", TEST_GROUP_1)
.done(),
String.class,
HttpMethod.POST);
Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
response = request("/nacos/v1/ns/instance/list",
Params.newParams()
.appendParam("serviceName", serviceName) //获取naming中的实例
.appendParam("namespaceId", "namespace-1")
.appendParam("groupName", TEST_GROUP_1)
.done(),
String.class);
Assert.assertTrue(response.getStatusCode().is2xxSuccessful());
JSONObject json = JSON.parseObject(response.getBody());
Assert.assertEquals("33.33.33.33", json.getJSONArray("hosts").getJSONObject(0).getString("ip"));
}
/** /**
* @TCDescription : 多租户注册IPupdate一个已有的实例接口 * @TCDescription : 多租户注册IPupdate一个已有的实例接口
* @TestStep : * @TestStep :

View File

@ -35,6 +35,7 @@ public class NamingBase {
public static final String TEST_IP_4_DOM_1 = "127.0.0.1"; public static final String TEST_IP_4_DOM_1 = "127.0.0.1";
public static final String TEST_PORT_4_DOM_1 = "8080"; public static final String TEST_PORT_4_DOM_1 = "8080";
public static final String TEST_PORT2_4_DOM_1 = "8888"; public static final String TEST_PORT2_4_DOM_1 = "8888";
public static final String TEST_PORT3_4_DOM_1 = "80";
public static final String TEST_TOKEN_4_DOM_1 = "abc"; public static final String TEST_TOKEN_4_DOM_1 = "abc";
public static final String TEST_NEW_CLUSTER_4_DOM_1 = "TEST1"; public static final String TEST_NEW_CLUSTER_4_DOM_1 = "TEST1";

View File

@ -100,8 +100,6 @@ public class ServiceListTest {
}); });
serviceInfoList = naming.getSubscribeServices(); serviceInfoList = naming.getSubscribeServices();
System.out.println("dfdfdfd = " + serviceInfoList);
Assert.assertEquals(count + 1, serviceInfoList.size()); Assert.assertEquals(count + 1, serviceInfoList.size());
} }