fix(接口测试): 优化设置环境变量参数的代码

优化设置环境变量参数的代码
This commit is contained in:
song-tianyang 2022-03-07 12:44:23 +08:00 committed by CountryBuilder
parent bf51986a61
commit 9f4eb2a1fa
1 changed files with 76 additions and 35 deletions

View File

@ -5,13 +5,16 @@ import com.alibaba.fastjson.JSONObject;
import io.metersphere.base.domain.ApiTestEnvironmentWithBLOBs;
import io.metersphere.base.mapper.ApiTestEnvironmentMapper;
import io.metersphere.utils.LoggerUtil;
import org.apache.commons.collections.MapUtils;
import org.apache.commons.lang3.ArrayUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import javax.annotation.Resource;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* @author song.tianyang
@ -23,29 +26,42 @@ public class ApiEnvironmentRunningParamService {
@Resource
ApiTestEnvironmentMapper testEnvironmentMapper;
public void addParam(String environmentId, String key, String value) {
if (StringUtils.isEmpty(key)) {
public void addParam(String environmentId, Map<String,String> varMap) {
if (MapUtils.isEmpty(varMap)) {
return;
}
ApiTestEnvironmentWithBLOBs environment = testEnvironmentMapper.selectByPrimaryKey(environmentId);
if (environment == null) {
return;
}
boolean envNeedUpdate = false;
try {
JSONObject configObj = JSONObject.parseObject(environment.getConfig());
if (configObj.containsKey("commonConfig")) {
JSONObject commonConfig = configObj.getJSONObject("commonConfig");
if (commonConfig.containsKey("variables")) {
JSONArray variables = commonConfig.getJSONArray("variables");
for (Map.Entry<String, String> entry: varMap.entrySet()){
String key = entry.getKey();
String value = entry.getValue();
boolean contains = false;
for (int i = 0; i < variables.size(); i++) {
JSONObject jsonObj = variables.getJSONObject(i);
if (jsonObj.containsKey("name") && StringUtils.equals(jsonObj.getString("name"), key)) {
contains = true;
if(jsonObj.containsKey("value") && StringUtils.equals(jsonObj.getString("value"), value)){
break;
}else {
envNeedUpdate = true;
jsonObj.put("value", value);
}
}
}
if (!contains) {
envNeedUpdate = true;
JSONObject itemObj = new JSONObject();
itemObj.put("name", key);
itemObj.put("value", value);
@ -58,39 +74,49 @@ public class ApiEnvironmentRunningParamService {
}
commonConfig.put("variables", variables);
}
}
} else {
JSONArray variables = new JSONArray();
for (Map.Entry<String, String> entry: varMap.entrySet()){
String key = entry.getKey();
String value = entry.getValue();
JSONObject itemObj = new JSONObject();
itemObj.put("name", key);
itemObj.put("value", value);
itemObj.put("enable", true);
variables.add(itemObj);
}
JSONObject emptyObj = new JSONObject();
emptyObj.put("enable", true);
variables.add(itemObj);
variables.add(emptyObj);
commonConfig.put("variables", variables);
}
} else {
JSONObject commonConfig = new JSONObject();
JSONArray variables = new JSONArray();
for (Map.Entry<String, String> entry: varMap.entrySet()) {
String key = entry.getKey();
String value = entry.getValue();
JSONObject itemObj = new JSONObject();
itemObj.put("name", key);
itemObj.put("value", value);
itemObj.put("enable", true);
variables.add(itemObj);
}
JSONObject emptyObj = new JSONObject();
emptyObj.put("enable", true);
variables.add(itemObj);
variables.add(emptyObj);
commonConfig.put("variables", variables);
configObj.put("commonConfig", commonConfig);
}
if(envNeedUpdate){
environment.setConfig(configObj.toJSONString());
testEnvironmentMapper.updateByPrimaryKeyWithBLOBs(environment);
}
} catch (Exception ex) {
LoggerUtil.error("设置环境变量异常:" + ex.getMessage());
}
@ -98,6 +124,7 @@ public class ApiEnvironmentRunningParamService {
public void parseEvn(String envStr) {
String[] envStringArr = envStr.split("\n");
Map<String, Map<String,String>> envVarsMap = new HashMap<>();
for (String env : envStringArr) {
if (StringUtils.contains(env, "=")) {
String[] envItem = env.split("=");
@ -110,7 +137,12 @@ public class ApiEnvironmentRunningParamService {
String key = StringUtils.join(keyArr, ".");
String value = StringUtils.substring(env, jmeterVarKey.length() + 1);
if (StringUtils.isNoneEmpty(envId, key, value)) {
this.addParam(envId, key, value);
if(envVarsMap.containsKey(envId)){
envVarsMap.get(envId).put(key,value);
}else {
Map<String,String> varMap = new HashMap<>();
varMap.put(key,value);
envVarsMap.put(envId,varMap);
}
}
}
@ -118,6 +150,15 @@ public class ApiEnvironmentRunningParamService {
}
}
if(MapUtils.isNotEmpty(envVarsMap)){
for (Map.Entry<String, Map<String, String>> entry: envVarsMap.entrySet()){
String envId = entry.getKey();
Map<String,String> vars = entry.getValue();
this.addParam(envId, vars);
}
}
}
public void parseEnvironment(List<String> evnStrList) {
for (String evnStr : evnStrList) {
this.parseEvn(evnStr);