From 27ecaff4cddb92843ef7bd8c6c09d37ad3b31147 Mon Sep 17 00:00:00 2001 From: fit2-zhao Date: Tue, 18 May 2021 19:14:20 +0800 Subject: [PATCH] =?UTF-8?q?fix(=E6=8E=A5=E5=8F=A3=E6=B5=8B=E8=AF=95):=20?= =?UTF-8?q?=E6=8E=A5=E5=8F=A3=E8=87=AA=E5=8A=A8=E5=8C=96=E4=B8=8A=E4=BC=A0?= =?UTF-8?q?=E7=9A=84jmx=E4=B8=AD=E5=8C=85=E5=90=ABcsv=E5=BC=95=E7=94=A8?= =?UTF-8?q?=E6=97=B6=EF=BC=8C=E8=B7=AF=E5=BE=84=E6=9C=AA=E8=87=AA=E5=8A=A8?= =?UTF-8?q?=E4=BF=AE=E6=94=B9=E9=97=AE=E9=A2=98=E4=BF=AE=E5=A4=8D?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../request/unknown/MsJmeterElement.java | 33 ++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) diff --git a/backend/src/main/java/io/metersphere/api/dto/definition/request/unknown/MsJmeterElement.java b/backend/src/main/java/io/metersphere/api/dto/definition/request/unknown/MsJmeterElement.java index e5f2027080..ac9a146c93 100644 --- a/backend/src/main/java/io/metersphere/api/dto/definition/request/unknown/MsJmeterElement.java +++ b/backend/src/main/java/io/metersphere/api/dto/definition/request/unknown/MsJmeterElement.java @@ -3,6 +3,8 @@ package io.metersphere.api.dto.definition.request.unknown; import com.alibaba.fastjson.annotation.JSONType; import io.metersphere.api.dto.definition.request.MsTestElement; import io.metersphere.api.dto.definition.request.ParameterConfig; +import io.metersphere.api.dto.definition.request.variable.ScenarioVariable; +import io.metersphere.api.dto.scenario.request.BodyFile; import io.metersphere.commons.exception.MSException; import io.metersphere.commons.utils.FileUtils; import io.metersphere.commons.utils.LogUtil; @@ -21,6 +23,7 @@ import java.io.ByteArrayInputStream; import java.io.File; import java.io.InputStream; import java.util.List; +import java.util.stream.Collectors; /** * 暂时存放所有未知的Jmeter Element对象 @@ -61,7 +64,14 @@ public class MsJmeterElement extends MsTestElement { if (!config.isOperating() && scriptWrapper instanceof CSVDataSet) { String path = ((CSVDataSet) scriptWrapper).getPropertyAsString("filename"); if (!new File(path).exists()) { - MSException.throwException(StringUtils.isEmpty(((CSVDataSet) scriptWrapper).getName()) ? "CSVDataSet" : ((CSVDataSet) scriptWrapper).getName() + ":[ CSV文件不存在 ]"); + // 检查场景变量中的csv文件是否存在 + String pathArr[] = path.split("\\/"); + String csvPath = this.getCSVPath(config, pathArr[pathArr.length - 1]); + if (StringUtils.isNotEmpty(csvPath)) { + ((CSVDataSet) scriptWrapper).setProperty("filename", csvPath); + } else { + MSException.throwException(StringUtils.isEmpty(((CSVDataSet) scriptWrapper).getName()) ? "CSVDataSet" : ((CSVDataSet) scriptWrapper).getName() + ":[ CSV文件不存在 ]"); + } } } if (CollectionUtils.isNotEmpty(hashTree)) { @@ -79,6 +89,27 @@ public class MsJmeterElement extends MsTestElement { } } + private String getCSVPath(ParameterConfig config, String name) { + if (CollectionUtils.isNotEmpty(config.getVariables())) { + List list = config.getVariables().stream().filter(ScenarioVariable::isCSVValid).collect(Collectors.toList()); + if (CollectionUtils.isNotEmpty(list)) { + for (ScenarioVariable item : list) { + if (CollectionUtils.isNotEmpty(item.getFiles())) { + List names = item.getFiles().stream().map(BodyFile::getName).collect(Collectors.toList()); + if (CollectionUtils.isNotEmpty(names) && names.contains(name)) { + if (!config.isOperating() && !new File(FileUtils.BODY_FILE_DIR + "/" + item.getFiles().get(0).getId() + "_" + item.getFiles().get(0).getName()).exists()) { + MSException.throwException(StringUtils.isEmpty(item.getName()) ? "CSVDataSet" : item.getName() + ":[ CSV文件不存在 ]"); + } else { + return FileUtils.BODY_FILE_DIR + "/" + item.getFiles().get(0).getId() + "_" + item.getFiles().get(0).getName(); + } + } + } + } + } + } + return null; + } + public static InputStream getStrToStream(String sInputString) { if (StringUtils.isNotEmpty(sInputString)) { try {