Junit for RestController-断言错误

时间:2018-10-16 07:16:39

标签: java spring spring-boot junit

我创建了一个rest api,并通过邮递员进行了测试,并能够获得预期的成功响应。现在,我已经为上述api创建了Junit测试用例,但是在执行过程中却得到了“ java.lang.AssertionError:预期状态:<200>,但是是:<415>”。无法弄清楚为什么会发生此异常。

我对Mockito和MockMVC都是陌生的,所以我们将不胜感激。

下面是我的测试班

package com.example.demo.hystricks;

import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;

import java.io.Serializable;
import java.time.Instant;
import java.time.LocalDateTime;
import java.time.ZoneId;

import org.apache.commons.lang.SerializationUtils;
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.boot.test.mock.mockito.MockBean;
import org.springframework.http.MediaType;
import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.RequestBuilder;
import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;
import org.springframework.test.web.servlet.result.MockMvcResultHandlers;
import org.springframework.test.web.servlet.setup.MockMvcBuilders;

import com.example.demo.DemoController;
import com.example.demo.DemoService;
import com.example.demo.InputModel;

@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes = DemoController.class)
public class DemoControllerTest {

private MockMvc mockMvc;

@InjectMocks
private DemoController demoController;

@MockBean
private DemoService demoService;

@MockBean
private MappingJackson2HttpMessageConverter mappingJackson2HttpMessageConverter;

@Before
public void setUp() {

    MockitoAnnotations.initMocks(this);
    DemoController demoController = new DemoController(demoService);
    this.mockMvc = MockMvcBuilders
            .standaloneSetup(demoController).
            setMessageConverters(mappingJackson2HttpMessageConverter).build();

}

@Test
public void postData() throws Exception {

    InputModel inputModel = new InputModel("12345","Test","CSC",getEventTime());
    System.out.println("before api....");
    RequestBuilder requestBuilder  = MockMvcRequestBuilders.post("/demoService")
            .accept(MediaType.APPLICATION_JSON)
            .content(inputModel.toString())
            .contentType(MediaType.APPLICATION_JSON);
    mockMvc.perform(requestBuilder)
    .andDo(MockMvcResultHandlers.print())
    .andExpect(status().isOk());
    System.out.println("after api....");
}

private LocalDateTime getEventTime() {

    Instant instant = Instant.ofEpochMilli(Instant.now().toEpochMilli());
    LocalDateTime eventTimestamp = LocalDateTime.ofInstant(instant, ZoneId.systemDefault());
    return eventTimestamp;
}

}

我的休息控制器

@RestController
public class DemoController {

private static final Logger LOGGER = LoggerFactory.getLogger(DemoController.class);

public final DemoService demoService;

public DemoController(DemoService demoService) {
    this.demoService = demoService;
}

@RequestMapping(value = "demoService",method = RequestMethod.POST)
public ResponseEntity<String> postData(
        @RequestBody InputModel inputModel){

    LOGGER.info("DemoService Entered successfully");
    demoService.postData(inputModel.getId(),inputModel.getName(),
            inputModel.getDepartment(), inputModel.getJoinDate());
    LOGGER.info("DemoService Exited successfully");
    return new ResponseEntity<String>("success",HttpStatus.OK) ;
}

}

api之前的控制台消息:

>2018-10-16 12:15:49.391  WARN 6200 --- [           main] .w.s.m.s.DefaultHandlerExceptionResolver : Resolved [org.springframework.web.HttpMediaTypeNotSupportedException: Content type 'application/json' not supported]
2018-10-16 12:15:49.437  INFO 6200 --- [       Thread-3] o.s.w.c.s.GenericWebApplicationContext   : Closing org.springframework.web.context.support.GenericWebApplicationContext@5023bb8b: startup date [Tue Oct 16 12:15:48 IST 2018]; parent: org.springframework.context.annotation.AnnotationConfigApplicationContext@76a4ebf2

失败堆栈跟踪:

>java.lang.AssertionError: Status expected:<200> but was:<415>
at org.springframework.test.util.AssertionErrors.fail(AssertionErrors.java:55)
at org.springframework.test.util.AssertionErrors.assertEquals(AssertionErrors.java:82)
at org.springframework.test.web.servlet.result.StatusResultMatchers.lambda$matcher$9(StatusResultMatchers.java:619)
at org.springframework.test.web.servlet.MockMvc$1.andExpect(MockMvc.java:178)
at com.example.demo.hystricks.DemoControllerTest.postData(DemoControllerTest.java:68)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.springframework.test.context.junit4.statements.RunBeforeTestExecutionCallbacks.evaluate(RunBeforeTestExecutionCallbacks.java:73)
at org.springframework.test.context.junit4.statements.RunAfterTestExecutionCallbacks.evaluate(RunAfterTestExecutionCallbacks.java:83)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:75)
at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:86)
at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:84)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:251)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:97)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:70)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:190)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:678)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)

1 个答案:

答案 0 :(得分:1)

问题在此行上:

 @MockBean
 private MappingJackson2HttpMessageConverter mappingJackson2HttpMessageConverter;

您正在嘲笑此转换器。使用new代替创建实例:

this.mockMvc = MockMvcBuilders
        .standaloneSetup(controller).
        setMessageConverters(new MappingJackson2HttpMessageConverter()).build();

或者正如M. Dienum正确提到的那样,您可以从setUp()方法中删除以下两行,它将起作用:

DemoController demoController = new DemoController(demoService);
this.mockMvc = MockMvcBuilders
        .standaloneSetup(demoController).
        setMessageConverters(mappingJackson2HttpMessageConverter).build();

完成所有这些操作后,如果遇到400错误,则您的toString()方法无法生成有效的json。