Add some unit test for V2Controller (#10143)
* add unit test for HealthController * for rerun ci * add unit test for CatalogControllerV2
This commit is contained in:
parent
c39ba4a35c
commit
fe5002f485
@ -30,6 +30,9 @@ import org.mockito.Spy;
|
|||||||
import org.mockito.junit.MockitoJUnitRunner;
|
import org.mockito.junit.MockitoJUnitRunner;
|
||||||
import org.springframework.context.ConfigurableApplicationContext;
|
import org.springframework.context.ConfigurableApplicationContext;
|
||||||
import org.springframework.mock.env.MockEnvironment;
|
import org.springframework.mock.env.MockEnvironment;
|
||||||
|
import org.springframework.test.web.servlet.request.MockHttpServletRequestBuilder;
|
||||||
|
|
||||||
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
|
|
||||||
@ -76,6 +79,16 @@ public abstract class BaseTest {
|
|||||||
ApplicationUtils.injectContext(context);
|
ApplicationUtils.injectContext(context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected MockHttpServletRequestBuilder convert(Object simpleOb, MockHttpServletRequestBuilder builder)
|
||||||
|
throws IllegalAccessException {
|
||||||
|
Field[] declaredFields = simpleOb.getClass().getDeclaredFields();
|
||||||
|
for (Field declaredField : declaredFields) {
|
||||||
|
declaredField.setAccessible(true);
|
||||||
|
builder.param(declaredField.getName(), String.valueOf(declaredField.get(simpleOb)));
|
||||||
|
}
|
||||||
|
return builder;
|
||||||
|
}
|
||||||
|
|
||||||
protected void mockInjectPushServer() {
|
protected void mockInjectPushServer() {
|
||||||
doReturn(pushService).when(context).getBean(UdpPushService.class);
|
doReturn(pushService).when(context).getBean(UdpPushService.class);
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,86 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 1999-2022 Alibaba Group Holding Ltd.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.alibaba.nacos.naming.controllers.v2;
|
||||||
|
|
||||||
|
import com.alibaba.nacos.api.common.Constants;
|
||||||
|
import com.alibaba.nacos.api.naming.pojo.Instance;
|
||||||
|
import com.alibaba.nacos.api.naming.utils.NamingUtils;
|
||||||
|
import com.alibaba.nacos.common.utils.JacksonUtils;
|
||||||
|
import com.alibaba.nacos.naming.BaseTest;
|
||||||
|
import com.alibaba.nacos.naming.core.CatalogServiceV2Impl;
|
||||||
|
import com.alibaba.nacos.naming.misc.UtilsAndCommons;
|
||||||
|
import com.fasterxml.jackson.databind.JsonNode;
|
||||||
|
import org.junit.Assert;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.InjectMocks;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.junit.MockitoJUnitRunner;
|
||||||
|
import org.springframework.mock.web.MockHttpServletResponse;
|
||||||
|
import org.springframework.test.web.servlet.MockMvc;
|
||||||
|
import org.springframework.test.web.servlet.request.MockHttpServletRequestBuilder;
|
||||||
|
import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;
|
||||||
|
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
|
public class CatalogControllerV2Test extends BaseTest {
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private CatalogServiceV2Impl catalogServiceV2;
|
||||||
|
|
||||||
|
@InjectMocks
|
||||||
|
private CatalogControllerV2 catalogControllerV2;
|
||||||
|
|
||||||
|
private MockMvc mockmvc;
|
||||||
|
|
||||||
|
List instances;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void before() {
|
||||||
|
Instance instance = new Instance();
|
||||||
|
instance.setIp("1.1.1.1");
|
||||||
|
instance.setPort(1234);
|
||||||
|
instance.setClusterName(TEST_CLUSTER_NAME);
|
||||||
|
instance.setServiceName(TEST_SERVICE_NAME);
|
||||||
|
instance.setEnabled(false);
|
||||||
|
instances = new ArrayList<>(1);
|
||||||
|
instances.add(instance);
|
||||||
|
mockmvc = MockMvcBuilders.standaloneSetup(catalogControllerV2).build();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testInstanceList() throws Exception {
|
||||||
|
String serviceNameWithoutGroup = NamingUtils.getServiceName(TEST_SERVICE_NAME);
|
||||||
|
String groupName = NamingUtils.getGroupName(TEST_SERVICE_NAME);
|
||||||
|
when(catalogServiceV2.listAllInstances(Constants.DEFAULT_NAMESPACE_ID, groupName,
|
||||||
|
serviceNameWithoutGroup)).thenReturn(instances);
|
||||||
|
MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.get(
|
||||||
|
UtilsAndCommons.DEFAULT_NACOS_NAMING_CONTEXT_V2 + UtilsAndCommons.NACOS_NAMING_CATALOG_CONTEXT
|
||||||
|
+ "/instances").param("namespaceId", Constants.DEFAULT_NAMESPACE_ID)
|
||||||
|
.param("serviceName", TEST_SERVICE_NAME).param("pageNo", "1").param("pageSize", "100");
|
||||||
|
MockHttpServletResponse response = mockmvc.perform(builder).andReturn().getResponse();
|
||||||
|
Assert.assertEquals(200, response.getStatus());
|
||||||
|
JsonNode data = JacksonUtils.toObj(response.getContentAsString()).get("data").get("instances");
|
||||||
|
Assert.assertEquals(instances.size(), data.size());
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,80 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 1999-2022 Alibaba Group Holding Ltd.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.alibaba.nacos.naming.controllers.v2;
|
||||||
|
|
||||||
|
import com.alibaba.nacos.api.naming.utils.NamingUtils;
|
||||||
|
import com.alibaba.nacos.common.utils.JacksonUtils;
|
||||||
|
import com.alibaba.nacos.naming.BaseTest;
|
||||||
|
import com.alibaba.nacos.naming.core.HealthOperatorV2Impl;
|
||||||
|
import com.alibaba.nacos.naming.misc.UtilsAndCommons;
|
||||||
|
import com.alibaba.nacos.naming.model.form.UpdateHealthForm;
|
||||||
|
import org.junit.Assert;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.InjectMocks;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.junit.MockitoJUnitRunner;
|
||||||
|
import org.springframework.mock.web.MockHttpServletResponse;
|
||||||
|
import org.springframework.test.util.ReflectionTestUtils;
|
||||||
|
import org.springframework.test.web.servlet.MockMvc;
|
||||||
|
import org.springframework.test.web.servlet.request.MockHttpServletRequestBuilder;
|
||||||
|
import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;
|
||||||
|
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.doNothing;
|
||||||
|
|
||||||
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
|
public class HealthControllerV2Test extends BaseTest {
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private HealthOperatorV2Impl healthOperatorV2;
|
||||||
|
|
||||||
|
@InjectMocks
|
||||||
|
private HealthControllerV2 healthControllerV2;
|
||||||
|
|
||||||
|
private MockMvc mockmvc;
|
||||||
|
|
||||||
|
private UpdateHealthForm updateHealthForm;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void before() {
|
||||||
|
ReflectionTestUtils.setField(healthControllerV2, "healthOperatorV2", healthOperatorV2);
|
||||||
|
mockmvc = MockMvcBuilders.standaloneSetup(healthControllerV2).build();
|
||||||
|
updateHealthForm = new UpdateHealthForm();
|
||||||
|
updateHealthForm.setHealthy(true);
|
||||||
|
updateHealthForm.setNamespaceId(TEST_NAMESPACE);
|
||||||
|
updateHealthForm.setClusterName(TEST_CLUSTER_NAME);
|
||||||
|
updateHealthForm.setGroupName(TEST_GROUP_NAME);
|
||||||
|
updateHealthForm.setServiceName(TEST_SERVICE_NAME);
|
||||||
|
updateHealthForm.setIp("123.123.123.123");
|
||||||
|
updateHealthForm.setPort(8888);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testUpdate() throws Exception {
|
||||||
|
doNothing().when(healthOperatorV2).updateHealthStatusForPersistentInstance(TEST_NAMESPACE,
|
||||||
|
NamingUtils.getGroupedName(updateHealthForm.getServiceName(), updateHealthForm.getGroupName()),
|
||||||
|
TEST_CLUSTER_NAME, "123.123.123.123", 8888, true);
|
||||||
|
MockHttpServletRequestBuilder builder = convert(updateHealthForm, MockMvcRequestBuilders.put(
|
||||||
|
UtilsAndCommons.DEFAULT_NACOS_NAMING_CONTEXT_V2 + UtilsAndCommons.NACOS_NAMING_HEALTH_CONTEXT));
|
||||||
|
MockHttpServletResponse response = mockmvc.perform(builder).andReturn().getResponse();
|
||||||
|
Assert.assertEquals(200, response.getStatus());
|
||||||
|
Assert.assertEquals("ok", JacksonUtils.toObj(response.getContentAsString()).get("data").asText());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user