build: API添加一个单元测试模版

This commit is contained in:
fit2-zhao 2023-06-01 10:45:31 +08:00 committed by fit2-zhao
parent 3aec662775
commit 805682d92b
2 changed files with 37 additions and 15 deletions

View File

@ -2,12 +2,11 @@ package io.metersphere.api.controller;
import io.metersphere.api.dto.ApiDefinitionDTO; import io.metersphere.api.dto.ApiDefinitionDTO;
import io.metersphere.api.service.ApiDefinitionService; import io.metersphere.api.service.ApiDefinitionService;
import io.metersphere.validation.groups.Created;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import org.springframework.http.MediaType; import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.PostMapping; import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.*;
import org.springframework.web.bind.annotation.RequestPart;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile; import org.springframework.web.multipart.MultipartFile;
import java.util.List; import java.util.List;
@ -19,9 +18,9 @@ public class ApiDefinitionController {
@Resource @Resource
private ApiDefinitionService apiDefinitionService; private ApiDefinitionService apiDefinitionService;
@PostMapping(value = "/create", consumes = {MediaType.MULTIPART_FORM_DATA_VALUE}) @PostMapping(value = "/add", consumes = MediaType.APPLICATION_JSON_VALUE)
public ApiDefinitionDTO create(@RequestPart("request") ApiDefinitionDTO request, public ApiDefinitionDTO create(@Validated({Created.class}) @RequestBody ApiDefinitionDTO request,
@RequestPart(value = "files", required = false) List<MultipartFile> bodyFiles) { @RequestParam(value = "files") List<MultipartFile> bodyFiles) {
return apiDefinitionService.create(request, bodyFiles); return apiDefinitionService.create(request, bodyFiles);
} }
} }

View File

@ -1,9 +1,10 @@
package io.metersphere.api.controller; package io.metersphere.api.controller;
import com.fasterxml.jackson.databind.ObjectMapper;
import io.metersphere.api.dto.ApiDefinitionDTO; import io.metersphere.api.dto.ApiDefinitionDTO;
import io.metersphere.sdk.util.LogUtils; import io.metersphere.sdk.util.LogUtils;
import io.metersphere.utils.JsonUtils;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import org.junit.Before;
import org.junit.jupiter.api.MethodOrderer; import org.junit.jupiter.api.MethodOrderer;
import org.junit.jupiter.api.Order; import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
@ -16,6 +17,8 @@ import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.request.MockMvcRequestBuilders; import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;
import org.springframework.test.web.servlet.result.MockMvcResultMatchers; import org.springframework.test.web.servlet.result.MockMvcResultMatchers;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.jsonPath;
@SpringBootTest @SpringBootTest
@TestMethodOrder(MethodOrderer.OrderAnnotation.class) @TestMethodOrder(MethodOrderer.OrderAnnotation.class)
@ -25,24 +28,44 @@ public class ApiDefinitionControllerTests {
private MockMvc mockMvc; private MockMvc mockMvc;
private final static String prefix = "/api/definition"; private final static String prefix = "/api/definition";
@Before
public void init() {
LogUtils.info("init base api test");
}
@Test @Test
@Order(1) @Order(1)
public void testCreate() throws Exception { public void testCreate() throws Exception {
LogUtils.info("create api test"); LogUtils.info("create api test");
// 创建一个 MockMultipartFile 对象用于模拟文件上传 // 创建一个 MockMultipartFile 对象用于模拟文件上传
MockMultipartFile file = new MockMultipartFile("files", "test.txt", "application/octet-stream", "Test content".getBytes()); MockMultipartFile file = new MockMultipartFile("files", "files", MediaType.APPLICATION_OCTET_STREAM_VALUE, "Test content".getBytes());
// 创建一个 ApiDefinitionDTO 对象用于模拟请求的一部分 // 创建一个 ApiDefinitionDTO 对象用于模拟请求的一部分
ApiDefinitionDTO request = new ApiDefinitionDTO(); ApiDefinitionDTO request = new ApiDefinitionDTO();
// 补充属性内容 // 补充属性内容
request.setId("test-api-id"); request.setId("test-api-id");
request.setCreateUser("test-user");
request.setCreateTime(System.currentTimeMillis());
request.setUpdateUser("test-api-id");
request.setUpdateTime(System.currentTimeMillis());
request.setProjectId("test-project-id");
request.setName("test-api-name");
request.setMethod("test-api-method");
request.setPath("test-api-path");
request.setProtocol("test-api-protocol");
request.setPos(1l);
request.setLatest(true);
request.setSyncEnable(true);
request.setStatus("test-api-status");
request.setVersionId("test-api-version");
request.setDeleted(false);
mockMvc.perform(MockMvcRequestBuilders.multipart(prefix + "/create") mockMvc.perform(MockMvcRequestBuilders.multipart(prefix + "/add")
.file(file) .file(file)
.contentType(MediaType.MULTIPART_FORM_DATA) .contentType(MediaType.APPLICATION_JSON_VALUE)
.param("request", new ObjectMapper().writeValueAsString(request))) .content(JsonUtils.toJSONString(request)))
.andExpect(MockMvcResultMatchers.status().is(400)); .andExpect(MockMvcResultMatchers.status().isOk())
//.andExpect(MockMvcResultMatchers.content().contentType(MediaType.APPLICATION_JSON)) .andExpect(MockMvcResultMatchers.content().contentType(MediaType.APPLICATION_JSON))
//.andExpect(MockMvcResultMatchers.jsonPath("$.id").value("test-api-id")); .andExpect(jsonPath("$.data.id").value("test-api-id"));
} }
} }