我正在为rest api spring boot写单元测试。
@RunWith(SpringRunner.class)
@SpringBootTest(classes = WorkflowEngineApiApplication.class, webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
public class ActionControllerTest {
@LocalServerPort
public int port;
private final TestRestTemplate testRestTemplate = new TestRestTemplate();
private final HttpHeaders headers = new HttpHeaders();
private long actionId;
@BeforeClass
public static void init() throws Exception{
String url="/api/v1/actions";
JSONObject action = new JSONObject();
action.put("name", "Name Test");
action.put("actionTypeId", 4L);
action.put("description", null);
action.put("createdBy", 2L);
action.put("processId", 2L);
headers.setContentType(MediaType.APPLICATION_JSON_UTF8);
ResponseEntity<ApiResponse> response = getResponse(url, HttpMethod.POST, action.toString());
}
private static ResponseEntity<ApiResponse> getResponse(String url, HttpMethod method, Object action){
HttpEntity<Object> entity = new HttpEntity<>(action, headers);
return testRestTemplate.exchange(createURL(url), method, entity, ApiResponse.class);
}
/**
* create url http://localhost:...
* @param uri String
* @return String
*/
public static String createURL(String uri) {
return "http://localhost:" + port + uri;
}
}
我想在测试运行之前向Db添加1行。但是当我使用@BeforeClass
静态方法时,port变量必须是静态的,但它不会生成值。它仍然是0。
错误显示:
org.springframework.web.client.ResourceAccessException:I / O错误 POST请求“http://localhost:0/api/v1/actions”
我的问题:有没有办法将@BeforeClass
与webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT
一起使用,这意味着@LocalServerPort
会产生静态值吗?
答案 0 :(得分:1)
我想在测试运行之前向Db添加1行。但是当我使用@BeforeClass和静态方法时,port变量必须是静态的,但它不会生成值。它还是0.错误显示:
所以,我理解的是,你想写下从控制器流向数据库的集成测试。这是我的建议。
@RunWith(SpringRunner.class)
@SpringBootTest
@WebAppConfiguration
@Transactional
public class MyIntTest {
private MockMvc mockMvc;
@Autowired
private WebApplicationContext ctx;
@Before
public void setUp() {
this.mockMvc = MockMvcBuilders.webAppContextSetup(ctx).build();
MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.post(**Your URL").accept(MediaType.APPLICATION_JSON)
.contentType(MediaType.APPLICATION_JSON);
builder.setContent("Your JSON request data");
// This will invoke POST request to "URL"
this.mockMvc.perform(builder);
// If you want to verify your result
MvcResult result = this.mockMvc.perform(builder).andReturn();
// Read response. If its custom class then just change return type.
List responses = getPojoFromMvcResult(result, List.class);
}
public static <T> T getPojoFromMvcResult(MvcResult result, Class<T> valueType) throws IOException {
try {
MockHttpServletResponse response = result.getResponse();
String responseJson = response.getContentAsString();
return convertJsonToObject(responseJson, valueType);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
public static <T> T convertJsonToObject(String content, Class<T> valueType) throws IOException {
return new ObjectMapper().readValue(content, valueType);
}
}