fix(接口测试): 修复下载JMX文件及ZIP包名称问题处理
This commit is contained in:
parent
7ac223d42e
commit
fc598de402
|
@ -49,9 +49,10 @@ public class ApiJmeterFileController {
|
||||||
@GetMapping("download")
|
@GetMapping("download")
|
||||||
public ResponseEntity<byte[]> downloadJmeterFiles(@RequestParam("testId") String testId, @RequestParam("reportId") String reportId, @RequestParam("runMode") String runMode, @RequestParam("testPlanScenarioId") String testPlanScenarioId) {
|
public ResponseEntity<byte[]> downloadJmeterFiles(@RequestParam("testId") String testId, @RequestParam("reportId") String reportId, @RequestParam("runMode") String runMode, @RequestParam("testPlanScenarioId") String testPlanScenarioId) {
|
||||||
byte[] bytes = apiJmeterFileService.downloadJmeterFiles(runMode, testId, reportId, testPlanScenarioId);
|
byte[] bytes = apiJmeterFileService.downloadJmeterFiles(runMode, testId, reportId, testPlanScenarioId);
|
||||||
|
String zipName = reportId + "_" + testId;
|
||||||
return ResponseEntity.ok()
|
return ResponseEntity.ok()
|
||||||
.contentType(MediaType.parseMediaType("application/octet-stream"))
|
.contentType(MediaType.parseMediaType("application/octet-stream"))
|
||||||
.header(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\"" + testId + ".zip\"")
|
.header(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\"" + zipName + ".zip\"")
|
||||||
.body(bytes);
|
.body(bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -82,9 +82,11 @@ public class ApiJmeterFileService {
|
||||||
}
|
}
|
||||||
hashTree = apiAutomationService.generateHashTree(item, reportId, planEnvMap);
|
hashTree = apiAutomationService.generateHashTree(item, reportId, planEnvMap);
|
||||||
}
|
}
|
||||||
return zipFilesToByteArray(reportId, hashTree);
|
String jmxName = reportId + "_" + remoteTestId + ".jmx";
|
||||||
|
return zipFilesToByteArray(jmxName, hashTree);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public byte[] downloadJmx(String runMode, String testId, String reportId, String testPlanScenarioId) {
|
public byte[] downloadJmx(String runMode, String testId, String reportId, String testPlanScenarioId) {
|
||||||
Map<String, String> planEnvMap = new HashMap<>();
|
Map<String, String> planEnvMap = new HashMap<>();
|
||||||
if (StringUtils.isNotEmpty(testPlanScenarioId)) {
|
if (StringUtils.isNotEmpty(testPlanScenarioId)) {
|
||||||
|
@ -222,12 +224,11 @@ public class ApiJmeterFileService {
|
||||||
return multipartFiles;
|
return multipartFiles;
|
||||||
}
|
}
|
||||||
|
|
||||||
private byte[] zipFilesToByteArray(String testId, HashTree hashTree) {
|
private byte[] zipFilesToByteArray(String jmxName, HashTree hashTree) {
|
||||||
String fileName = testId + ".jmx";
|
|
||||||
String jmx = new MsTestPlan().getJmx(hashTree);
|
String jmx = new MsTestPlan().getJmx(hashTree);
|
||||||
Map<String, byte[]> files = new HashMap<>();
|
Map<String, byte[]> files = new HashMap<>();
|
||||||
// 每个测试生成一个文件夹
|
// 每个测试生成一个文件夹
|
||||||
files.put(fileName, jmx.getBytes(StandardCharsets.UTF_8));
|
files.put(jmxName, jmx.getBytes(StandardCharsets.UTF_8));
|
||||||
// 获取JMX使用到的附件
|
// 获取JMX使用到的附件
|
||||||
Map<String, byte[]> multipartFiles = this.getMultipartFiles(hashTree);
|
Map<String, byte[]> multipartFiles = this.getMultipartFiles(hashTree);
|
||||||
if (!com.alibaba.excel.util.CollectionUtils.isEmpty(multipartFiles)) {
|
if (!com.alibaba.excel.util.CollectionUtils.isEmpty(multipartFiles)) {
|
||||||
|
|
Loading…
Reference in New Issue