feat(接口设置环境变量): 修复部分接口无法设置环境变量的问题,修复环境变量值等号结尾被舍弃的问题
修复部分接口无法设置环境变量的问题,修复环境变量值等号结尾被舍弃的问题
This commit is contained in:
parent
4e15bf4c29
commit
8f2066b36f
|
@ -108,7 +108,7 @@ public abstract class MsTestElement {
|
|||
@JSONField(ordinal = 13)
|
||||
private boolean isMockEnvironment;
|
||||
@JSONField(ordinal = 14)
|
||||
private String useEnviroment;
|
||||
private String useEnvironment;
|
||||
private MsTestElement parent;
|
||||
|
||||
private static final String BODY_FILE_DIR = FileUtils.BODY_FILE_DIR;
|
||||
|
|
|
@ -36,17 +36,17 @@ public class MsJSR223Processor extends MsTestElement {
|
|||
@Override
|
||||
public void toHashTree(HashTree tree, List<MsTestElement> hashTree, ParameterConfig config) {
|
||||
//替换Metersphere环境变量
|
||||
if(StringUtils.isEmpty(this.getUseEnviroment())){
|
||||
if(StringUtils.isEmpty(this.getUseEnvironment())){
|
||||
if(config.getConfig() != null){
|
||||
if(config.getProjectId() != null){
|
||||
String evnId = config.getConfig().get(config.getProjectId()).getApiEnvironmentid();
|
||||
this.setUseEnviroment(evnId);
|
||||
this.setUseEnvironment(evnId);
|
||||
}else {
|
||||
Collection<EnvironmentConfig> evnConfigList = config.getConfig().values();
|
||||
if(evnConfigList!=null && !evnConfigList.isEmpty()){
|
||||
for (EnvironmentConfig configItem : evnConfigList) {
|
||||
String evnId = configItem.getApiEnvironmentid();
|
||||
this.setUseEnviroment(evnId);
|
||||
this.setUseEnvironment(evnId);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -54,7 +54,7 @@ public class MsJSR223Processor extends MsTestElement {
|
|||
|
||||
}
|
||||
}
|
||||
script = StringUtils.replace(script, RunningParamKeys.API_ENVIRONMENT_ID,"\""+RunningParamKeys.RUNNING_PARAMS_PREFIX+this.getUseEnviroment()+".\"");
|
||||
script = StringUtils.replace(script, RunningParamKeys.API_ENVIRONMENT_ID,"\""+RunningParamKeys.RUNNING_PARAMS_PREFIX+this.getUseEnvironment()+".\"");
|
||||
|
||||
// 非导出操作,且不是启用状态则跳过执行
|
||||
if (!config.isOperating() && !this.isEnable()) {
|
||||
|
|
|
@ -32,17 +32,17 @@ public class MsJSR223PostProcessor extends MsTestElement {
|
|||
|
||||
@Override
|
||||
public void toHashTree(HashTree tree, List<MsTestElement> hashTree, ParameterConfig config) {
|
||||
if(StringUtils.isEmpty(this.getUseEnviroment())){
|
||||
if(StringUtils.isEmpty(this.getUseEnvironment())){
|
||||
if(config.getConfig() != null){
|
||||
if(config.getProjectId() != null){
|
||||
String evnId = config.getConfig().get(config.getProjectId()).getApiEnvironmentid();
|
||||
this.setUseEnviroment(evnId);
|
||||
this.setUseEnvironment(evnId);
|
||||
}else {
|
||||
Collection<EnvironmentConfig> evnConfigList = config.getConfig().values();
|
||||
if(evnConfigList!=null && !evnConfigList.isEmpty()){
|
||||
for (EnvironmentConfig configItem : evnConfigList) {
|
||||
String evnId = configItem.getApiEnvironmentid();
|
||||
this.setUseEnviroment(evnId);
|
||||
this.setUseEnvironment(evnId);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -50,7 +50,7 @@ public class MsJSR223PostProcessor extends MsTestElement {
|
|||
}
|
||||
}
|
||||
//替换Metersphere环境变量
|
||||
script = StringUtils.replace(script,RunningParamKeys.API_ENVIRONMENT_ID,"\""+RunningParamKeys.RUNNING_PARAMS_PREFIX+this.getUseEnviroment()+".\"");
|
||||
script = StringUtils.replace(script,RunningParamKeys.API_ENVIRONMENT_ID,"\""+RunningParamKeys.RUNNING_PARAMS_PREFIX+this.getUseEnvironment()+".\"");
|
||||
|
||||
// 非导出操作,且不是启用状态则跳过执行
|
||||
if (!config.isOperating() && !this.isEnable()) {
|
||||
|
|
|
@ -32,17 +32,17 @@ public class MsJSR223PreProcessor extends MsTestElement {
|
|||
|
||||
@Override
|
||||
public void toHashTree(HashTree tree, List<MsTestElement> hashTree, ParameterConfig config) {
|
||||
if(StringUtils.isEmpty(this.getUseEnviroment())){
|
||||
if(StringUtils.isEmpty(this.getUseEnvironment())){
|
||||
if(config.getConfig() != null){
|
||||
if(config.getProjectId() != null){
|
||||
String evnId = config.getConfig().get(config.getProjectId()).getApiEnvironmentid();
|
||||
this.setUseEnviroment(evnId);
|
||||
this.setUseEnvironment(evnId);
|
||||
}else {
|
||||
Collection<EnvironmentConfig> evnConfigList = config.getConfig().values();
|
||||
if(evnConfigList!=null && !evnConfigList.isEmpty()){
|
||||
for (EnvironmentConfig configItem : evnConfigList) {
|
||||
String evnId = configItem.getApiEnvironmentid();
|
||||
this.setUseEnviroment(evnId);
|
||||
this.setUseEnvironment(evnId);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -50,7 +50,7 @@ public class MsJSR223PreProcessor extends MsTestElement {
|
|||
}
|
||||
}
|
||||
//替换Metersphere环境变量
|
||||
script = StringUtils.replace(script,RunningParamKeys.API_ENVIRONMENT_ID,"\""+RunningParamKeys.RUNNING_PARAMS_PREFIX+this.getUseEnviroment()+".\"");
|
||||
script = StringUtils.replace(script,RunningParamKeys.API_ENVIRONMENT_ID,"\""+RunningParamKeys.RUNNING_PARAMS_PREFIX+this.getUseEnvironment()+".\"");
|
||||
|
||||
// 非导出操作,且不是启用状态则跳过执行
|
||||
if (!config.isOperating() && !this.isEnable()) {
|
||||
|
|
|
@ -252,7 +252,7 @@ public class MsHTTPSamplerProxy extends MsTestElement {
|
|||
|
||||
if (CollectionUtils.isNotEmpty(hashTree)) {
|
||||
for (MsTestElement el : hashTree) {
|
||||
el.setUseEnviroment(useEnvironment);
|
||||
el.setUseEnvironment(useEnvironment);
|
||||
el.toHashTree(httpSamplerTree, el.getHashTree(), config);
|
||||
}
|
||||
}
|
||||
|
@ -265,6 +265,10 @@ public class MsHTTPSamplerProxy extends MsTestElement {
|
|||
|
||||
private HttpConfig getHttpConfig(ParameterConfig config) {
|
||||
if (config.isEffective(this.getProjectId())) {
|
||||
String useEvnId = config.getConfig().get(this.getProjectId()).getApiEnvironmentid();
|
||||
if(StringUtils.isNotEmpty(useEvnId) && !StringUtils.equals(useEvnId,this.getUseEnvironment())){
|
||||
this.setUseEnvironment(useEvnId);
|
||||
}
|
||||
return getHttpConfig(config.getConfig().get(this.getProjectId()).getHttpConfig());
|
||||
}
|
||||
return null;
|
||||
|
|
|
@ -10,6 +10,7 @@ import java.util.stream.Collectors;
|
|||
|
||||
@Data
|
||||
public class HttpConfig {
|
||||
private String apiEnvironmentid;
|
||||
private String socket;
|
||||
private String domain;
|
||||
private String protocol = "https";
|
||||
|
|
|
@ -102,8 +102,9 @@ public class ApiEnvironmentRunningParamService {
|
|||
String envId = envAndKeyArr[0];
|
||||
String [] keyArr = ArrayUtils.remove(envAndKeyArr,0);
|
||||
String key = StringUtils.join(keyArr,".");
|
||||
String [] valueArr = ArrayUtils.remove(envItem,0);
|
||||
String value = StringUtils.join(valueArr,"=");
|
||||
// String [] valueArr = ArrayUtils.remove(envItem,0);
|
||||
// String value = StringUtils.join(valueArr,"=");
|
||||
String value = StringUtils.substring(env,jmeterVarKey.length()+1);
|
||||
if(StringUtils.isNoneEmpty(envId,key,value)){
|
||||
this.addParam(envId,key,value);
|
||||
}
|
||||
|
|
|
@ -49,6 +49,7 @@ import {saveScenario} from "@/business/components/api/automation/api-automation"
|
|||
this.runId = response.data;
|
||||
this.$emit('runRefresh', {});
|
||||
});
|
||||
alert("123");
|
||||
},
|
||||
}
|
||||
}
|
||||
|
|
|
@ -888,6 +888,7 @@ export default {
|
|||
promise.then(() => {
|
||||
let sign = this.$refs.envPopover.checkEnv(this.isFullUrl);
|
||||
if (!sign) {
|
||||
this.buttonIsLoading = false;
|
||||
return;
|
||||
}
|
||||
//调试时不再保存
|
||||
|
|
|
@ -43,7 +43,7 @@
|
|||
},
|
||||
{
|
||||
title: this.$t('api_test.request.processor.param_environment_set_global_variable'),
|
||||
value: 'vars.put(${__metersphere_env_id}+"key","value");\n'+'vars.put("key","value");',
|
||||
value: 'vars.put(${__metersphere_env_id}+"key","value");\n'+'vars.put("key","value")',
|
||||
},
|
||||
{
|
||||
title: this.$t('api_test.request.processor.code_add_report_length'),
|
||||
|
|
Loading…
Reference in New Issue