Spring引导单元测试没有获取模拟控制器的请求映射

时间:2018-02-14 06:16:55

标签: spring unit-testing spring-boot junit mockito

我正在尝试测试我的控制器,但控制台说找不到模拟请求的url映射,我可以看到动态映射在我触发测试后出现在控制台中。它们被映射到相应的方法。

在我的设置中,我有一个模拟服务,它被注入我想测试的控制器内。

以下是测试网络应用配置

package com.example.persistance;

import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;

import com.example.dao.UserDao;
import com.example.model.User;

@Configuration
@ComponentScan("com.example")
@EnableWebMvc
class MockWebConfigurationForTest{

    @Bean
    public UserDao setupMockUserDao() {

        User mockUser;
        mockUser=new User();
        mockUser.setId(TestCaseConstants.UserId.uuidAsString());
        mockUser.setAge("24");
        mockUser.setFirstName("Sujal");
        mockUser.setLastName("Mandal");
        mockUser.setUserName("smandal");
        mockUser.setPasswordHash("ABCDE12345");

        UserDao userDao=mock(UserDao.class);
        when(userDao.findOne(TestCaseConstants.UserId.uuidAsString())).thenReturn(mockUser);
        return userDao;
    }
}

以下是测试类

package com.example.persistance;

import static org.junit.Assert.assertNotNull;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.InjectMocks;
import org.mockito.MockitoAnnotations;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringRunner;
import org.springframework.test.context.web.WebAppConfiguration;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
import com.example.controllers.UserController;
import com.example.model.User;
import com.google.gson.Gson;

@RunWith(SpringRunner.class)
@SpringBootTest
@WebAppConfiguration
@ContextConfiguration(classes = {MockWebConfigurationForTest.class})
public class DataPersistenceServiceApplicationTests {

    MockMvc mockMvc;
    String mockUserId=TestCaseConstants.UserId.uuidAsString();
    User mockUser;

    @InjectMocks
    private UserController userController;

    @Before
    public void setUpTestData() {
        mockUser=new User();
        mockUser.setId(mockUserId);
        mockUser.setAge("24");
        mockUser.setFirstName("Sujal");
        mockUser.setLastName("Mandal");
        mockUser.setUserName("smandal");
        mockUser.setPasswordHash("ABCDE12345");

        MockitoAnnotations.initMocks(this);
        mockMvc=MockMvcBuilders.standaloneSetup(UserController.class).build();
    }

    @Test
    public void testUserController_getOne() throws Exception {
        String result=mockMvc.perform(get("/info")).andReturn().getResponse().getContentAsString();
        assertNotNull(result);
    }

}

当我运行测试时,我会在控制台中看到以下内容。

2018-02-14 11:31:39.912  INFO 9408 --- [           main] p.DataPersistenceServiceApplicationTests : No active profile set, falling back to default profiles: default
2018-02-14 11:31:39.915  INFO 9408 --- [           main] o.s.w.c.s.GenericWebApplicationContext   : Refreshing org.springframework.web.context.support.GenericWebApplicationContext@427b5f92: startup date [Wed Feb 14 11:31:39 IST 2018]; parent: org.springframework.context.annotation.AnnotationConfigApplicationContext@1b2abca6
2018-02-14 11:31:40.946  INFO 9408 --- [           main] o.s.cloud.context.scope.GenericScope     : BeanFactory id=9c2829f3-6e5c-30f7-aeae-06169329e061
2018-02-14 11:31:41.023  INFO 9408 --- [           main] f.a.AutowiredAnnotationBeanPostProcessor : JSR-330 'javax.inject.Inject' annotation found and supported for autowiring
2018-02-14 11:31:41.138  INFO 9408 --- [           main] trationDelegate$BeanPostProcessorChecker : Bean 'org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration' of type [org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration$$EnhancerBySpringCGLIB$$4404e8] is not eligible for getting processed by all BeanPostProcessors (for example: not eligible for auto-proxying)
2018-02-14 11:31:41.822  INFO 9408 --- [           main] org.mongodb.driver.cluster               : Cluster created with settings {hosts=[localhost:27017], mode=SINGLE, requiredClusterType=UNKNOWN, serverSelectionTimeout='30000 ms', maxWaitQueueSize=500}
2018-02-14 11:31:41.892  INFO 9408 --- [localhost:27017] org.mongodb.driver.connection            : Opened connection [connectionId{localValue:1, serverValue:40}] to localhost:27017
2018-02-14 11:31:41.894  INFO 9408 --- [localhost:27017] org.mongodb.driver.cluster               : Monitor thread successfully connected to server with description ServerDescription{address=localhost:27017, type=STANDALONE, state=CONNECTED, ok=true, version=ServerVersion{versionList=[3, 6, 2]}, minWireVersion=0, maxWireVersion=6, maxDocumentSize=16777216, roundTripTimeNanos=597711}
2018-02-14 11:31:42.279  INFO 9408 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/info]}" onto public java.lang.String com.example.controllers.InfoController.info()
2018-02-14 11:31:42.282  INFO 9408 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/users/],methods=[GET]}" onto public java.util.List<com.example.model.User> com.example.controllers.UserController.getAllUsers()
2018-02-14 11:31:42.282  INFO 9408 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/users/],methods=[PUT]}" onto public com.example.model.User com.example.controllers.UserController.updateOne(com.example.model.User)
2018-02-14 11:31:42.282  INFO 9408 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/users/],methods=[DELETE]}" onto public void com.example.controllers.UserController.deleteOne(com.example.model.User)
2018-02-14 11:31:42.283  INFO 9408 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/users/],methods=[POST]}" onto public com.example.model.User com.example.controllers.UserController.saveOne(com.example.model.User)
2018-02-14 11:31:42.283  INFO 9408 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/users/{id}],methods=[GET]}" onto public com.example.model.User com.example.controllers.UserController.getOne(java.lang.String)
2018-02-14 11:31:42.287  INFO 9408 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error]}" onto public org.springframework.http.ResponseEntity<java.util.Map<java.lang.String, java.lang.Object>> org.springframework.boot.autoconfigure.web.BasicErrorController.error(javax.servlet.http.HttpServletRequest)
2018-02-14 11:31:42.288  INFO 9408 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],produces=[text/html]}" onto public org.springframework.web.servlet.ModelAndView org.springframework.boot.autoconfigure.web.BasicErrorController.errorHtml(javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse)
2018-02-14 11:31:42.605  INFO 9408 --- [           main] s.w.s.m.m.a.RequestMappingHandlerAdapter : Looking for @ControllerAdvice: org.springframework.web.context.support.GenericWebApplicationContext@427b5f92: startup date [Wed Feb 14 11:31:39 IST 2018]; parent: org.springframework.context.annotation.AnnotationConfigApplicationContext@1b2abca6
2018-02-14 11:31:43.231  WARN 9408 --- [           main] c.n.c.sources.URLConfigurationSource     : No URLs will be polled as dynamic configuration sources.
2018-02-14 11:31:43.231  INFO 9408 --- [           main] c.n.c.sources.URLConfigurationSource     : To enable URLs as dynamic configuration sources, define System property archaius.configurationSource.additionalUrls or make config.properties available on classpath.
2018-02-14 11:31:43.241  WARN 9408 --- [           main] c.n.c.sources.URLConfigurationSource     : No URLs will be polled as dynamic configuration sources.
2018-02-14 11:31:43.241  INFO 9408 --- [           main] c.n.c.sources.URLConfigurationSource     : To enable URLs as dynamic configuration sources, define System property archaius.configurationSource.additionalUrls or make config.properties available on classpath.
2018-02-14 11:31:44.386  WARN 9408 --- [           main] arterDeprecationWarningAutoConfiguration : spring-cloud-starter-eureka is deprecated as of Spring Cloud Netflix 1.4.0, please migrate to spring-cloud-starter-netflix-eureka
2018-02-14 11:31:44.458  INFO 9408 --- [           main] o.s.c.support.DefaultLifecycleProcessor  : Starting beans in phase 0
2018-02-14 11:31:44.471  INFO 9408 --- [           main] p.DataPersistenceServiceApplicationTests : Started DataPersistenceServiceApplicationTests in 6.268 seconds (JVM running for 7.277)
2018-02-14 11:31:44.674  INFO 9408 --- [           main] s.w.s.m.m.a.RequestMappingHandlerAdapter : Looking for @ControllerAdvice: org.springframework.test.web.servlet.setup.StubWebApplicationContext@5ec9eefa
2018-02-14 11:31:44.695  INFO 9408 --- [           main] o.s.mock.web.MockServletContext          : Initializing Spring FrameworkServlet ''
2018-02-14 11:31:44.700  INFO 9408 --- [           main] o.s.t.web.servlet.TestDispatcherServlet  : FrameworkServlet '': initialization started
2018-02-14 11:31:44.701  INFO 9408 --- [           main] o.s.t.web.servlet.TestDispatcherServlet  : FrameworkServlet '': initialization completed in 0 ms
==> 2018-02-14 11:31:44.779  WARN 9408 --- [           main] o.s.web.servlet.PageNotFound             : No mapping found for HTTP request with URI [/info] in DispatcherServlet with name 
2018-02-14 11:31:44.807  INFO 9408 --- [       Thread-5] o.s.w.c.s.GenericWebApplicationContext   : Closing org.springframework.web.context.support.GenericWebApplicationContext@427b5f92: startup date [Wed Feb 14 11:31:39 IST 2018]; parent: org.springframework.context.annotation.AnnotationConfigApplicationContext@1b2abca6

如第二行所示,找不到/info的映射,但是如果你看到一点点上面你可以看到映射被成功拾取,我缺少什么?

1 个答案:

答案 0 :(得分:0)

我找到了解决方案,我使用了mockMvc=MockMvcBuilders.webAppContextSetup(webApplicationContext).build();

而不是standaloneSetup()我使用了webApplicationContext

的自动装配实例
package com.example.persistance;

import static org.junit.Assert.assertNotNull;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.InjectMocks;
import org.mockito.MockitoAnnotations;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringRunner;
import org.springframework.test.context.web.WebAppConfiguration;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
import org.springframework.web.context.WebApplicationContext;

import com.example.controllers.UserController;
import com.example.model.User;
import com.google.gson.Gson;

@RunWith(SpringRunner.class)
@SpringBootTest
@ContextConfiguration(classes = {MockWebConfigurationForTest.class})
public class DataPersistenceServiceApplicationTests {

    @Autowired
    WebApplicationContext webApplicationContext;

    MockMvc mockMvc;

    String mockUserId=TestCaseConstants.UserId.uuidAsString();
    User mockUser;

    @InjectMocks
    private UserController userController;

    @Before
    public void setUpTestData() {
        mockUser=new User();
        mockUser.setId(mockUserId);
        mockUser.setAge("24");
        mockUser.setFirstName("Sujal");
        mockUser.setLastName("Mandal");
        mockUser.setUserName("smandal");
        mockUser.setPasswordHash("ABCDE12345");

        MockitoAnnotations.initMocks(this);
        mockMvc=MockMvcBuilders.webAppContextSetup(webApplicationContext).build();
    }

    @Test
    public void testUserController_getOne() throws Exception {
        Gson gson=new Gson();
        System.err.println("Expected: "+gson.toJson(mockUser));
        String result=mockMvc.perform(get("/users/"+mockUserId)).andReturn().getResponse().getContentAsString();
        System.err.println("Returned: "+result);
        assertNotNull(result);
    }

}