fix(接口自动化): 修复导入jmeter文件处理x-www-form-urlencoded 类型问题
This commit is contained in:
parent
2d7073c199
commit
723133d0a0
|
@ -80,6 +80,7 @@ import java.lang.reflect.Field;
|
||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
public class MsJmeterParser extends ApiImportAbstractParser<ScenarioImport> {
|
public class MsJmeterParser extends ApiImportAbstractParser<ScenarioImport> {
|
||||||
private final String ENV_NAME = "导入数据环境";
|
private final String ENV_NAME = "导入数据环境";
|
||||||
|
@ -202,6 +203,16 @@ public class MsJmeterParser extends ApiImportAbstractParser<ScenarioImport> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String getBodyType(List<KeyValue> headers) {
|
||||||
|
if (CollectionUtils.isNotEmpty(headers)) {
|
||||||
|
List<KeyValue> keyValues = headers.stream().filter(keyValue -> keyValue.getName().equals("Content-Type") && keyValue.getValue().equals("application/x-www-form-urlencoded")).collect(Collectors.toList());
|
||||||
|
if (CollectionUtils.isNotEmpty(keyValues)) {
|
||||||
|
return keyValues.get(0).getValue();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
private void convertHttpSampler(MsHTTPSamplerProxy samplerProxy, Object key) {
|
private void convertHttpSampler(MsHTTPSamplerProxy samplerProxy, Object key) {
|
||||||
try {
|
try {
|
||||||
HTTPSamplerProxy source = (HTTPSamplerProxy) key;
|
HTTPSamplerProxy source = (HTTPSamplerProxy) key;
|
||||||
|
@ -212,6 +223,19 @@ public class MsJmeterParser extends ApiImportAbstractParser<ScenarioImport> {
|
||||||
samplerProxy.setArguments(new ArrayList<KeyValue>() {{
|
samplerProxy.setArguments(new ArrayList<KeyValue>() {{
|
||||||
this.add(new KeyValue());
|
this.add(new KeyValue());
|
||||||
}});
|
}});
|
||||||
|
// 处理HTTP协议的请求头
|
||||||
|
if (headerMap.containsKey(key.hashCode())) {
|
||||||
|
List<KeyValue> keyValues = new LinkedList<>();
|
||||||
|
headerMap.get(key.hashCode()).forEach(item -> {
|
||||||
|
HeaderManager headerManager = (HeaderManager) item;
|
||||||
|
if (headerManager.getHeaders() != null) {
|
||||||
|
for (int i = 0; i < headerManager.getHeaders().size(); i++) {
|
||||||
|
keyValues.add(new KeyValue(headerManager.getHeader(i).getName(), headerManager.getHeader(i).getValue()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
samplerProxy.setHeaders(keyValues);
|
||||||
|
}
|
||||||
// 初始化body
|
// 初始化body
|
||||||
Body body = new Body();
|
Body body = new Body();
|
||||||
body.init();
|
body.init();
|
||||||
|
@ -226,11 +250,15 @@ public class MsJmeterParser extends ApiImportAbstractParser<ScenarioImport> {
|
||||||
List<BodyFile> files = new LinkedList<>();
|
List<BodyFile> files = new LinkedList<>();
|
||||||
BodyFile file = new BodyFile();
|
BodyFile file = new BodyFile();
|
||||||
file.setId(arg.getParamName());
|
file.setId(arg.getParamName());
|
||||||
file.setName(arg.getPath());
|
String fileName = arg.getPath();
|
||||||
|
if (fileName.indexOf("/") != -1) {
|
||||||
|
fileName = fileName.substring(fileName.lastIndexOf("/") + 1);
|
||||||
|
}
|
||||||
|
file.setName(fileName);
|
||||||
files.add(file);
|
files.add(file);
|
||||||
|
|
||||||
KeyValue keyValue = new KeyValue(arg.getParamName(), arg.getParamName());
|
KeyValue keyValue = new KeyValue(arg.getParamName(), arg.getParamName());
|
||||||
keyValue.setContentType(arg.getProperty("HTTPArgument.content_type").toString());
|
keyValue.setContentType(arg.getMimeType());
|
||||||
keyValue.setType("file");
|
keyValue.setType("file");
|
||||||
keyValue.setFiles(files);
|
keyValue.setFiles(files);
|
||||||
keyValues.add(keyValue);
|
keyValues.add(keyValue);
|
||||||
|
@ -242,6 +270,7 @@ public class MsJmeterParser extends ApiImportAbstractParser<ScenarioImport> {
|
||||||
samplerProxy.setResponseTimeout(source.getResponseTimeout() + "");
|
samplerProxy.setResponseTimeout(source.getResponseTimeout() + "");
|
||||||
samplerProxy.setPort(source.getPropertyAsString("HTTPSampler.port"));
|
samplerProxy.setPort(source.getPropertyAsString("HTTPSampler.port"));
|
||||||
samplerProxy.setDomain(source.getDomain());
|
samplerProxy.setDomain(source.getDomain());
|
||||||
|
String bodyType = this.getBodyType(samplerProxy.getHeaders());
|
||||||
if (source.getArguments() != null) {
|
if (source.getArguments() != null) {
|
||||||
if (source.getPostBodyRaw()) {
|
if (source.getPostBodyRaw()) {
|
||||||
samplerProxy.getBody().setType(Body.RAW);
|
samplerProxy.getBody().setType(Body.RAW);
|
||||||
|
@ -249,6 +278,17 @@ public class MsJmeterParser extends ApiImportAbstractParser<ScenarioImport> {
|
||||||
samplerProxy.getBody().setRaw(v);
|
samplerProxy.getBody().setRaw(v);
|
||||||
});
|
});
|
||||||
samplerProxy.getBody().initKvs();
|
samplerProxy.getBody().initKvs();
|
||||||
|
} else if (StringUtils.isNotEmpty(bodyType)) {
|
||||||
|
samplerProxy.getBody().setType(Body.WWW_FROM);
|
||||||
|
source.getArguments().getArgumentsAsMap().forEach((k, v) -> {
|
||||||
|
KeyValue keyValue = new KeyValue(k, v);
|
||||||
|
samplerProxy.getBody().getKvs().add(keyValue);
|
||||||
|
});
|
||||||
|
} else if (samplerProxy.getBody() != null && samplerProxy.getBody().getType().equals(Body.FORM_DATA)) {
|
||||||
|
source.getArguments().getArgumentsAsMap().forEach((k, v) -> {
|
||||||
|
KeyValue keyValue = new KeyValue(k, v);
|
||||||
|
samplerProxy.getBody().getKvs().add(keyValue);
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
List<KeyValue> keyValues = new LinkedList<>();
|
List<KeyValue> keyValues = new LinkedList<>();
|
||||||
source.getArguments().getArgumentsAsMap().forEach((k, v) -> {
|
source.getArguments().getArgumentsAsMap().forEach((k, v) -> {
|
||||||
|
@ -269,19 +309,7 @@ public class MsJmeterParser extends ApiImportAbstractParser<ScenarioImport> {
|
||||||
}
|
}
|
||||||
samplerProxy.setId(UUID.randomUUID().toString());
|
samplerProxy.setId(UUID.randomUUID().toString());
|
||||||
samplerProxy.setType("HTTPSamplerProxy");
|
samplerProxy.setType("HTTPSamplerProxy");
|
||||||
// 处理HTTP协议的请求头
|
|
||||||
if (headerMap.containsKey(key.hashCode())) {
|
|
||||||
List<KeyValue> keyValues = new LinkedList<>();
|
|
||||||
headerMap.get(key.hashCode()).forEach(item -> {
|
|
||||||
HeaderManager headerManager = (HeaderManager) item;
|
|
||||||
if (headerManager.getHeaders() != null) {
|
|
||||||
for (int i = 0; i < headerManager.getHeaders().size(); i++) {
|
|
||||||
keyValues.add(new KeyValue(headerManager.getHeader(i).getName(), headerManager.getHeader(i).getValue()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
samplerProxy.setHeaders(keyValues);
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
@ -387,28 +415,20 @@ public class MsJmeterParser extends ApiImportAbstractParser<ScenarioImport> {
|
||||||
// JDBC 数据池
|
// JDBC 数据池
|
||||||
if (key instanceof DataSourceElement) {
|
if (key instanceof DataSourceElement) {
|
||||||
DataSourceElement dataSourceElement = (DataSourceElement) key;
|
DataSourceElement dataSourceElement = (DataSourceElement) key;
|
||||||
|
DatabaseConfig newConfig = new DatabaseConfig();
|
||||||
|
newConfig.setUsername(dataSourceElement.getPropertyAsString("username"));
|
||||||
|
newConfig.setPassword(dataSourceElement.getPropertyAsString("password"));
|
||||||
|
newConfig.setDriver(dataSourceElement.getPropertyAsString("driver"));
|
||||||
|
newConfig.setDbUrl(dataSourceElement.getPropertyAsString("dbUrl"));
|
||||||
|
newConfig.setName(dataSourceElement.getPropertyAsString("dataSource"));
|
||||||
|
newConfig.setPoolMax(dataSourceElement.getPropertyAsInt("poolMax"));
|
||||||
|
newConfig.setTimeout(dataSourceElement.getPropertyAsInt("timeout"));
|
||||||
if (dataPools != null && dataPools.getDataSources() != null && dataPools.getDataSources().containsKey(dataSourceElement.getPropertyAsString("dataSource"))) {
|
if (dataPools != null && dataPools.getDataSources() != null && dataPools.getDataSources().containsKey(dataSourceElement.getPropertyAsString("dataSource"))) {
|
||||||
DatabaseConfig config = dataPools.getDataSources().get(dataSourceElement.getPropertyAsString("dataSource"));
|
DatabaseConfig config = dataPools.getDataSources().get(dataSourceElement.getPropertyAsString("dataSource"));
|
||||||
DatabaseConfig newConfig = new DatabaseConfig();
|
|
||||||
newConfig.setUsername(dataSourceElement.getPropertyAsString("username"));
|
|
||||||
newConfig.setPassword(dataSourceElement.getPropertyAsString("password"));
|
|
||||||
newConfig.setDriver(dataSourceElement.getPropertyAsString("driver"));
|
|
||||||
newConfig.setDbUrl(dataSourceElement.getPropertyAsString("dbUrl"));
|
|
||||||
newConfig.setName(dataSourceElement.getPropertyAsString("dataSource"));
|
|
||||||
newConfig.setPoolMax(dataSourceElement.getPropertyAsInt("poolMax"));
|
|
||||||
newConfig.setTimeout(dataSourceElement.getPropertyAsInt("timeout"));
|
|
||||||
newConfig.setId(config.getId());
|
newConfig.setId(config.getId());
|
||||||
dataPools.getDataSources().put(dataSourceElement.getPropertyAsString("dataSource"), newConfig);
|
dataPools.getDataSources().put(dataSourceElement.getPropertyAsString("dataSource"), newConfig);
|
||||||
} else {
|
} else {
|
||||||
DatabaseConfig newConfig = new DatabaseConfig();
|
|
||||||
newConfig.setId(UUID.randomUUID().toString());
|
newConfig.setId(UUID.randomUUID().toString());
|
||||||
newConfig.setUsername(dataSourceElement.getPropertyAsString("username"));
|
|
||||||
newConfig.setPassword(dataSourceElement.getPropertyAsString("password"));
|
|
||||||
newConfig.setDriver(dataSourceElement.getPropertyAsString("driver"));
|
|
||||||
newConfig.setDbUrl(dataSourceElement.getPropertyAsString("dbUrl"));
|
|
||||||
newConfig.setName(dataSourceElement.getPropertyAsString("dataSource"));
|
|
||||||
newConfig.setPoolMax(dataSourceElement.getPropertyAsInt("poolMax"));
|
|
||||||
newConfig.setTimeout(dataSourceElement.getPropertyAsInt("timeout"));
|
|
||||||
if (dataPools.getDataSources() == null) {
|
if (dataPools.getDataSources() == null) {
|
||||||
dataPools.setDataSources(new HashMap<>());
|
dataPools.setDataSources(new HashMap<>());
|
||||||
}
|
}
|
||||||
|
@ -744,12 +764,12 @@ public class MsJmeterParser extends ApiImportAbstractParser<ScenarioImport> {
|
||||||
countController.setInputVal(foreachController.getInputValString());
|
countController.setInputVal(foreachController.getInputValString());
|
||||||
countController.setReturnVal(foreachController.getReturnValString());
|
countController.setReturnVal(foreachController.getReturnValString());
|
||||||
((MsLoopController) elementNode).setForEachController(countController);
|
((MsLoopController) elementNode).setForEachController(countController);
|
||||||
}else if(key instanceof TransactionController){
|
} else if (key instanceof TransactionController) {
|
||||||
TransactionController transactionController = (TransactionController) key;
|
TransactionController transactionController = (TransactionController) key;
|
||||||
elementNode = new MsTransactionController();
|
elementNode = new MsTransactionController();
|
||||||
elementNode.setName(transactionController.getName());
|
elementNode.setName(transactionController.getName());
|
||||||
((MsTransactionController)elementNode).setGenerateParentSample(transactionController.isGenerateParentSample());
|
((MsTransactionController) elementNode).setGenerateParentSample(transactionController.isGenerateParentSample());
|
||||||
((MsTransactionController)elementNode).setIncludeTimers(transactionController.isIncludeTimers());
|
((MsTransactionController) elementNode).setIncludeTimers(transactionController.isIncludeTimers());
|
||||||
}
|
}
|
||||||
// 平台不能识别的Jmeter步骤
|
// 平台不能识别的Jmeter步骤
|
||||||
else {
|
else {
|
||||||
|
|
Loading…
Reference in New Issue