Spock Test中的SpringBootTest RestController结果为404

时间:2018-06-15 18:52:32

标签: spring-mvc spring-boot spring-restcontroller spring-boot-test

给出Controller的以下代码,当我启动spring启动应用程序时,我能够对资源/ foo / id / {id}进行http调用以获取数据。

然而,来自Integration测试的相同调用返回404.调用未触发rest控制器方法。测试不是将http调用转发给其余控制器。我错过了什么?

@RestController
@RequestMapping(“/foo”)
class FooResource {
@RequestMapping(method = RequestMethod.GET, path = “/id/{id}”)
String getData(@PathVariable int id) {
    logger.error("===== FooResource.getData called with {}", id)
     // more code
}
//more code

//Spock test case
@ContextConfiguration
@SpringBootTest(
        webEnvironment = SpringBootTest.WebEnvironment.DEFINED_PORT
)
@EnableWebMvc
@AutoConfigureWebClient
@TestPropertySource(locations = "classpath:application-test.properties")
class IntegrationTest extends Specification {

    @Autowired
    RestTemplate restTemplate 


   @Configuration
   @ImportResource(["classpath*:/test-properties.xml", "classpath*:/springintegration-config.xml"])
   static class Beans {
        @Bean
        MessagingTemplate messagingTemplate() { new MessagingTemplate() }

        @Bean
        ServletWebServerFactory servletWebServerFactory() {
            return new TomcatServletWebServerFactory(9010);
        }

        @Bean
        public RestTemplate restTemplate(RestTemplateBuilder restTemplateBuilder) {
            return restTemplateBuilder
              .setConnectTimeout(30 * 1000)
                .setReadTimeout(30 * 1000)
               .build();
        }
   }

   def ‘foo resource returns the expected data for Id'() {
    given:
    int id = new SecureRandom().nextInt()
    TestRestTemplate restTemplate = new TestRestTemplate();

    when:
    ResponseEntity<String> response = restTemplate.getForEntity("http://localhost:9010/foo/id/1234", String.class)

    then:
    assert response.statusCode == HttpStatus.OK
}

测试用例运行日志包括以下可用的映射

s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped “{[/foo/id/{Id}],methods=[GET]}" onto public java.lang.String com.foo.bar.rest.FooResource.getData(int)
2018-06-15 13:54:38.680 DEBUG 20710 --- [           main] o.s.b.f.s.DefaultListableBeanFactory     : Finished creating instance of bean 'requestMappingHandlerMapping'
2018-06-15 13:54:38.680 DEBUG 20710 --- [           main] o.s.b.f.s.DefaultListableBeanFactory     : Creating shared instance of singleton bean 'mvcPathMatcher'
2018-06-15 13:54:38.681 DEBUG 20710 --- [           main] o.s.b.f.s.DefaultListableBeanFactory     : Creating instance of bean 'mvcPathMatcher'

1 个答案:

答案 0 :(得分:0)

更改Annotation on IntegrationTest类可以解决此问题。

//Spock test case
@SpringBootTest(
        classes = TestConfig.class,
        webEnvironment = SpringBootTest.WebEnvironment.DEFINED_PORT
)
@AutoConfigureWebClient
@TestPropertySource(locations = "classpath:application-test.properties")
class IntegrationTest extends Specification {

    @Autowired
    RestTemplate restTemplate 


   @Configuration
   @ImportResource(["classpath*:/test-properties.xml", "classpath*:/springintegration-config.xml"])
   static class Beans {
        @Bean
        MessagingTemplate messagingTemplate() { new MessagingTemplate() }

        @Bean
        ServletWebServerFactory servletWebServerFactory() {
            return new TomcatServletWebServerFactory(9010);
        }

        @Bean
        public RestTemplate restTemplate(RestTemplateBuilder restTemplateBuilder) {
            return restTemplateBuilder
              .setConnectTimeout(30 * 1000)
                .setReadTimeout(30 * 1000)
               .build();
        }
   }

   def ‘foo resource returns the expected data for Id'() {
    given:
    int id = new SecureRandom().nextInt()
    TestRestTemplate restTemplate = new TestRestTemplate();

    when:
    ResponseEntity<String> response = restTemplate.getForEntity("http://localhost:9010/foo/id/1234", String.class)

    then:
    assert response.statusCode == HttpStatus.OK
}