我知道以前曾问过这类问题,我尝试了其中给出的许多答案,但都做得不好,所以有人可以帮我解决这个问题
它是我的Controller类
@RestController
@RequestMapping("/admin")
public class ABController {
@PutMapping("/train/{trainId}/{status}")
public ResponseEntity updateTrainstatus(@PathVariable String trainId, @PathVariable String status) {
return feignClient.updateTrainstatus(trainId, status);
}
}
它是我的测试控制器类
private final String UPDATE_TRAIN_URI = "/admin/train?trainId=train100&status=approved";
@Test
public void testJsonController() throws Exception {
String trainId = "train100";
String status = "approved";
MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.put(UPDATE_TRAIN_URI)
.contentType(MediaType.APPLICATION_JSON_VALUE).accept(MediaType.APPLICATION_JSON).characterEncoding("UTF-8");
this.mockMvc.perform(builder).andExpect(MockMvcResultMatchers.status().isOk())
.andExpect(MockMvcResultMatchers.content().string("Train status"))
.andDo(MockMvcResultHandlers.print());
}
答案 0 :(得分:1)
您的项目可能已配置了spring安全性。比控制器需要一些身份验证-例如请求标头中的jwt令牌。在测试中,您的请求没有有效值,而不是您收到403禁止状态