我正在尝试模拟我的 Controller 调用的方法,如下所示:
@Post(value = "/blah", produces = MediaType.APPLICATION_JSON, consumes = MediaType.APPLICATION_JSON)
@Transactional
public HttpResponse<Object> createBlah(HttpHeaders httpHeaders,
@Body @Valid CreateBlahRequest createBlahRequest) {
HttpResponse<Object> createBlahResponse;
(...)
createBlahService(...) // what i am trying to mock
return HttpUtils.getResponse(HttpStatus.CREATED, createBlahResponse.body());
}
在我的测试中,我正在测试如下所示:
@Mock
public BlahController blahController;
public HttpResponse<Object> resp = HttpResponse.created((Object) new AccountResponse()).status(HttpStatus.OK);
@BeforeAll
public void configureAppContext() {
Application.APPLICATION_CONTEXT = applicationContext;
MockitoAnnotations.initMocks(this);
}
@Test
void createBlah(){
MutableHttpRequest<CreateBlahRequest> request = HttpRequest
.POST("/blah", createBlahRequest)
.header("requestId", "1");
when(blahController.createBlah(eq(request.getHeaders()), eq(createBlahRequest))).thenReturn(resp);
HttpResponse<CreateBlahRequest> blahRes = client.toBlocking().exchange(request, CreateBlahRequest.class);
}
但是,当客户端调用 Controller 时,它似乎与我的测试内部的(何时)不匹配,它继续按原样运行。如果有人能就此提出一些建议,我们将不胜感激。
最佳答案
对于看到此内容的任何人,我必须注入(inject)该方法调用的类。 在 Controller 中,它调用另一个服务类,所以我像这样模拟它:
@Inject
public BlahService BlahService;
@MockBean(BlahService.class)
public BlahService blahService(){
return Mockito.mock(BlahService.class);
}
效果很好。
关于java - Mockito 在测试中没有模拟来自 Controller 的功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60195744/