From 2f3076f80a3fc630cf8830156ba70d43db55ca98 Mon Sep 17 00:00:00 2001 From: fit2-zhao Date: Thu, 13 May 2021 10:30:06 +0800 Subject: [PATCH] =?UTF-8?q?fix(=E6=8E=A5=E5=8F=A3=E6=B5=8B=E8=AF=95):=20?= =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E6=96=B0=E7=89=88=E6=9C=AC=E7=8E=AF=E5=A2=83?= =?UTF-8?q?DNS=E4=B8=8D=E8=B5=B7=E4=BD=9C=E7=94=A8=E9=97=AE=E9=A2=98?= =?UTF-8?q?=EF=BC=9B=E4=BF=AE=E5=A4=8D=E7=8E=AF=E5=A2=83=E4=B8=AD=E8=AF=B7?= =?UTF-8?q?=E6=B1=82=E5=A4=B4=E5=8E=86=E5=8F=B2=E6=95=B0=E6=8D=AE=E9=97=AE?= =?UTF-8?q?=E9=A2=98=E3=80=82?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../request/dns/MsDNSCacheManager.java | 7 +++--- .../request/sampler/MsHTTPSamplerProxy.java | 23 ++++++------------- .../api/dto/scenario/HttpConfig.java | 1 + 3 files changed, 12 insertions(+), 19 deletions(-) diff --git a/backend/src/main/java/io/metersphere/api/dto/definition/request/dns/MsDNSCacheManager.java b/backend/src/main/java/io/metersphere/api/dto/definition/request/dns/MsDNSCacheManager.java index 38166128b8..00fb73cec0 100644 --- a/backend/src/main/java/io/metersphere/api/dto/definition/request/dns/MsDNSCacheManager.java +++ b/backend/src/main/java/io/metersphere/api/dto/definition/request/dns/MsDNSCacheManager.java @@ -3,6 +3,7 @@ package io.metersphere.api.dto.definition.request.dns; 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.scenario.HttpConfig; import io.metersphere.api.dto.scenario.KeyValue; import io.metersphere.api.dto.scenario.environment.EnvironmentConfig; import io.metersphere.api.dto.scenario.environment.Host; @@ -40,9 +41,9 @@ public class MsDNSCacheManager extends MsTestElement { samplerHashTree.add(arguments(name, config.getCommonConfig().getVariables())); } - public static void addEnvironmentDNS(HashTree samplerHashTree, String name, EnvironmentConfig config) { - if (config.getCommonConfig().isEnableHost() && CollectionUtils.isNotEmpty(config.getCommonConfig().getHosts())) { - String domain = config.getHttpConfig().getDomain().trim(); + public static void addEnvironmentDNS(HashTree samplerHashTree, String name, EnvironmentConfig config, HttpConfig httpConfig) { + if (config.getCommonConfig().isEnableHost() && CollectionUtils.isNotEmpty(config.getCommonConfig().getHosts()) && httpConfig != null) { + String domain = httpConfig.getDomain().trim(); List hosts = new ArrayList<>(); config.getCommonConfig().getHosts().forEach(host -> { if (StringUtils.isNotBlank(host.getDomain())) { diff --git a/backend/src/main/java/io/metersphere/api/dto/definition/request/sampler/MsHTTPSamplerProxy.java b/backend/src/main/java/io/metersphere/api/dto/definition/request/sampler/MsHTTPSamplerProxy.java index 369b192bb5..7c10a7a095 100644 --- a/backend/src/main/java/io/metersphere/api/dto/definition/request/sampler/MsHTTPSamplerProxy.java +++ b/backend/src/main/java/io/metersphere/api/dto/definition/request/sampler/MsHTTPSamplerProxy.java @@ -197,10 +197,10 @@ public class MsHTTPSamplerProxy extends MsTestElement { } compatible(config); - + HttpConfig httpConfig = null; try { if (config.isEffective(this.getProjectId())) { - HttpConfig httpConfig = getHttpConfig(config.getConfig().get(this.getProjectId()).getHttpConfig(), tree); + httpConfig = getHttpConfig(config.getConfig().get(this.getProjectId()).getHttpConfig()); if (httpConfig == null && !isURL(this.getUrl())) { MSException.throwException("未匹配到环境,请检查环境配置"); } @@ -333,13 +333,11 @@ public class MsHTTPSamplerProxy extends MsTestElement { if (CollectionUtils.isNotEmpty(this.headers)) { setHeader(httpSamplerTree, this.headers); } - - // 通用请求Headers - if (config.isEffective(this.getProjectId()) && config.getConfig().get(this.getProjectId()).getHttpConfig() != null - && CollectionUtils.isNotEmpty(config.getConfig().get(this.getProjectId()).getHttpConfig().getHeaders())) { + // 新版本符合条件 HTTP 请求头 + if (httpConfig != null && CollectionUtils.isNotEmpty(httpConfig.getHeaders())) { if (!this.isCustomizeReq() || this.isRefEnvironment) { // 如果不是自定义请求,或者引用环境则添加环境请求头 - setHeader(httpSamplerTree, config.getConfig().get(this.getProjectId()).getHttpConfig().getHeaders()); + setHeader(httpSamplerTree, httpConfig.getHeaders()); } } @@ -352,7 +350,7 @@ public class MsHTTPSamplerProxy extends MsTestElement { if (config.isEffective(this.getProjectId()) && config.getConfig().get(this.getProjectId()).getCommonConfig() != null && config.getConfig().get(this.getProjectId()).getCommonConfig().isEnableHost()) { MsDNSCacheManager.addEnvironmentVariables(httpSamplerTree, this.getName(), config.getConfig().get(this.getProjectId())); - MsDNSCacheManager.addEnvironmentDNS(httpSamplerTree, this.getName(), config.getConfig().get(this.getProjectId())); + MsDNSCacheManager.addEnvironmentDNS(httpSamplerTree, this.getName(), config.getConfig().get(this.getProjectId()), httpConfig); } if (this.authManager != null) { @@ -559,7 +557,7 @@ public class MsHTTPSamplerProxy extends MsTestElement { * @param httpConfig * @return */ - private HttpConfig getHttpConfig(HttpConfig httpConfig, HashTree tree) { + private HttpConfig getHttpConfig(HttpConfig httpConfig) { boolean isNext = true; if (CollectionUtils.isNotEmpty(httpConfig.getConditions())) { for (HttpConfigCondition item : httpConfig.getConditions()) { @@ -609,13 +607,6 @@ public class MsHTTPSamplerProxy extends MsTestElement { } } } - // HTTP 环境中请求头 - if (httpConfig != null && CollectionUtils.isNotEmpty(httpConfig.getHeaders())) { - if (!this.isCustomizeReq() || this.isRefEnvironment) { - // 如果不是自定义请求,或者引用环境则添加环境请求头 - setHeader(tree, httpConfig.getHeaders()); - } - } return httpConfig; } diff --git a/backend/src/main/java/io/metersphere/api/dto/scenario/HttpConfig.java b/backend/src/main/java/io/metersphere/api/dto/scenario/HttpConfig.java index c168de1cd9..8a4e5a1dd1 100644 --- a/backend/src/main/java/io/metersphere/api/dto/scenario/HttpConfig.java +++ b/backend/src/main/java/io/metersphere/api/dto/scenario/HttpConfig.java @@ -22,6 +22,7 @@ public class HttpConfig { HttpConfig config = new HttpConfig(); config.isMock = this.isMock; BeanUtils.copyBean(config, configCondition); + config.setHeaders(configCondition.getHeaders()); return config; }