fix(接口测试): 修复包含excel文件的请求执行失败问题
--bug=1015442 --user=赵勇 【接口测试】执行带excel文件的接口会报错 https://www.tapd.cn/55049933/s/1213910
This commit is contained in:
parent
458b5e9301
commit
dea49feebd
|
@ -210,7 +210,7 @@
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.alibaba</groupId>
|
<groupId>com.alibaba</groupId>
|
||||||
<artifactId>easyexcel</artifactId>
|
<artifactId>easyexcel</artifactId>
|
||||||
<version>2.2.10</version>
|
<version>3.1.1</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
package io.metersphere.api.controller;
|
package io.metersphere.api.controller;
|
||||||
|
|
||||||
import io.metersphere.api.jmeter.JMeterThreadUtils;
|
import io.metersphere.api.jmeter.JMeterThreadUtils;
|
||||||
import io.metersphere.api.service.ApiJmeterFileService;
|
import io.metersphere.api.service.ApiJMeterFileService;
|
||||||
import org.springframework.http.HttpHeaders;
|
import org.springframework.http.HttpHeaders;
|
||||||
import org.springframework.http.MediaType;
|
import org.springframework.http.MediaType;
|
||||||
import org.springframework.http.ResponseEntity;
|
import org.springframework.http.ResponseEntity;
|
||||||
|
@ -12,10 +12,10 @@ import java.util.UUID;
|
||||||
|
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping("/api/jmeter")
|
@RequestMapping("/api/jmeter")
|
||||||
public class ApiJmeterFileController {
|
public class ApiJMeterFileController {
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private ApiJmeterFileService apiJmeterFileService;
|
private ApiJMeterFileService apiJmeterFileService;
|
||||||
|
|
||||||
@GetMapping("stop/{name}")
|
@GetMapping("stop/{name}")
|
||||||
public String stop(@PathVariable String name) {
|
public String stop(@PathVariable String name) {
|
|
@ -501,34 +501,27 @@ public class ESBParser extends EsbAbstractParser {
|
||||||
|
|
||||||
private String getCellValue(Cell cell) {
|
private String getCellValue(Cell cell) {
|
||||||
String returnCellValue = "";
|
String returnCellValue = "";
|
||||||
int cellType = cell.getCellType();
|
if (cell.getCellType() == CellType.BLANK) {
|
||||||
switch (cellType) {
|
returnCellValue = "";
|
||||||
case Cell.CELL_TYPE_BLANK:
|
} else if (cell.getCellType() == CellType.BOOLEAN) {
|
||||||
returnCellValue = "";
|
returnCellValue = String.valueOf(cell.getBooleanCellValue());
|
||||||
break;
|
} else if (cell.getCellType() == CellType.ERROR) {
|
||||||
case Cell.CELL_TYPE_BOOLEAN:
|
returnCellValue = "";
|
||||||
returnCellValue = String.valueOf(cell.getBooleanCellValue());
|
} else if (cell.getCellType() == CellType.NUMERIC) {
|
||||||
break;
|
returnCellValue = getValueOfNumericCell(cell);
|
||||||
case Cell.CELL_TYPE_ERROR:
|
} else if (cell.getCellType() == CellType.FORMULA) {
|
||||||
returnCellValue = "";
|
try {
|
||||||
break;
|
|
||||||
case Cell.CELL_TYPE_NUMERIC:
|
|
||||||
returnCellValue = getValueOfNumericCell(cell);
|
returnCellValue = getValueOfNumericCell(cell);
|
||||||
break;
|
} catch (IllegalStateException e) {
|
||||||
case Cell.CELL_TYPE_FORMULA:
|
|
||||||
try {
|
try {
|
||||||
returnCellValue = getValueOfNumericCell(cell);
|
returnCellValue = cell.getRichStringCellValue().toString();
|
||||||
} catch (IllegalStateException e) {
|
} catch (IllegalStateException e2) {
|
||||||
try {
|
|
||||||
returnCellValue = cell.getRichStringCellValue().toString();
|
|
||||||
} catch (IllegalStateException e2) {
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e);
|
|
||||||
}
|
}
|
||||||
break;
|
} catch (Exception e) {
|
||||||
default:
|
LogUtil.error(e);
|
||||||
returnCellValue = cell.getRichStringCellValue().getString();
|
}
|
||||||
|
} else {
|
||||||
|
returnCellValue = cell.getRichStringCellValue().getString();
|
||||||
}
|
}
|
||||||
if (returnCellValue == null) {
|
if (returnCellValue == null) {
|
||||||
returnCellValue = "";
|
returnCellValue = "";
|
||||||
|
|
|
@ -35,7 +35,7 @@ import java.util.zip.ZipEntry;
|
||||||
import java.util.zip.ZipOutputStream;
|
import java.util.zip.ZipOutputStream;
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
public class ApiJmeterFileService {
|
public class ApiJMeterFileService {
|
||||||
@Resource
|
@Resource
|
||||||
private ApiCaseSerialService apiCaseSerialService;
|
private ApiCaseSerialService apiCaseSerialService;
|
||||||
@Resource
|
@Resource
|
||||||
|
@ -123,7 +123,7 @@ public class ApiJmeterFileService {
|
||||||
Map<String, byte[]> files = new HashMap<>();
|
Map<String, byte[]> files = new HashMap<>();
|
||||||
// 获取JAR
|
// 获取JAR
|
||||||
Map<String, byte[]> jarFiles = this.getJar();
|
Map<String, byte[]> jarFiles = this.getJar();
|
||||||
if (!com.alibaba.excel.util.CollectionUtils.isEmpty(jarFiles)) {
|
if (!MapUtils.isEmpty(jarFiles)) {
|
||||||
for (String k : jarFiles.keySet()) {
|
for (String k : jarFiles.keySet()) {
|
||||||
byte[] v = jarFiles.get(k);
|
byte[] v = jarFiles.get(k);
|
||||||
files.put(k, v);
|
files.put(k, v);
|
||||||
|
@ -136,7 +136,7 @@ public class ApiJmeterFileService {
|
||||||
Map<String, byte[]> files = new HashMap<>();
|
Map<String, byte[]> files = new HashMap<>();
|
||||||
// 获取JAR
|
// 获取JAR
|
||||||
Map<String, byte[]> jarFiles = this.getPlugJar();
|
Map<String, byte[]> jarFiles = this.getPlugJar();
|
||||||
if (!com.alibaba.excel.util.CollectionUtils.isEmpty(jarFiles)) {
|
if (!MapUtils.isEmpty(jarFiles)) {
|
||||||
for (String k : jarFiles.keySet()) {
|
for (String k : jarFiles.keySet()) {
|
||||||
byte[] v = jarFiles.get(k);
|
byte[] v = jarFiles.get(k);
|
||||||
files.put(k, v);
|
files.put(k, v);
|
|
@ -4,7 +4,7 @@ package io.metersphere.performance.controller;
|
||||||
import io.metersphere.commons.utils.WeakConcurrentHashMap;
|
import io.metersphere.commons.utils.WeakConcurrentHashMap;
|
||||||
import io.metersphere.controller.handler.annotation.NoResultHolder;
|
import io.metersphere.controller.handler.annotation.NoResultHolder;
|
||||||
import io.metersphere.performance.dto.ZipDTO;
|
import io.metersphere.performance.dto.ZipDTO;
|
||||||
import io.metersphere.performance.service.JmeterFileService;
|
import io.metersphere.performance.service.JMeterFileService;
|
||||||
import org.springframework.http.HttpHeaders;
|
import org.springframework.http.HttpHeaders;
|
||||||
import org.springframework.http.MediaType;
|
import org.springframework.http.MediaType;
|
||||||
import org.springframework.http.ResponseEntity;
|
import org.springframework.http.ResponseEntity;
|
||||||
|
@ -20,9 +20,9 @@ import java.util.stream.Collectors;
|
||||||
|
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping("jmeter")
|
@RequestMapping("jmeter")
|
||||||
public class JmeterFileController {
|
public class JMeterFileController {
|
||||||
@Resource
|
@Resource
|
||||||
private JmeterFileService jmeterFileService;
|
private JMeterFileService jmeterFileService;
|
||||||
private final WeakConcurrentHashMap<String, List<Double>> readyMap = new WeakConcurrentHashMap<>(30 * 60 * 1000);// 默认保留30分钟
|
private final WeakConcurrentHashMap<String, List<Double>> readyMap = new WeakConcurrentHashMap<>(30 * 60 * 1000);// 默认保留30分钟
|
||||||
|
|
||||||
@GetMapping("ping")
|
@GetMapping("ping")
|
|
@ -1,6 +1,5 @@
|
||||||
package io.metersphere.performance.service;
|
package io.metersphere.performance.service;
|
||||||
|
|
||||||
import com.alibaba.excel.util.CollectionUtils;
|
|
||||||
import io.metersphere.base.domain.LoadTestReportWithBLOBs;
|
import io.metersphere.base.domain.LoadTestReportWithBLOBs;
|
||||||
import io.metersphere.base.mapper.LoadTestReportMapper;
|
import io.metersphere.base.mapper.LoadTestReportMapper;
|
||||||
import io.metersphere.base.mapper.ext.ExtLoadTestReportMapper;
|
import io.metersphere.base.mapper.ext.ExtLoadTestReportMapper;
|
||||||
|
@ -10,6 +9,7 @@ import io.metersphere.performance.dto.ZipDTO;
|
||||||
import io.metersphere.performance.engine.EngineContext;
|
import io.metersphere.performance.engine.EngineContext;
|
||||||
import io.metersphere.performance.engine.EngineFactory;
|
import io.metersphere.performance.engine.EngineFactory;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
import org.springframework.util.CollectionUtils;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
|
@ -23,7 +23,7 @@ import java.util.zip.ZipOutputStream;
|
||||||
|
|
||||||
// 非事务运行
|
// 非事务运行
|
||||||
@Service
|
@Service
|
||||||
public class JmeterFileService {
|
public class JMeterFileService {
|
||||||
@Resource
|
@Resource
|
||||||
private ExtLoadTestReportMapper extLoadTestReportMapper;
|
private ExtLoadTestReportMapper extLoadTestReportMapper;
|
||||||
@Resource
|
@Resource
|
Loading…
Reference in New Issue