fix(接口测试): 场景执行选mock环境,执行出错
This commit is contained in:
parent
05f4965813
commit
9c00d8d309
|
@ -201,33 +201,12 @@ public class EnvironmentService extends MoveNodeService {
|
||||||
environmentInfoDTO.setMock(environment.getMock());
|
environmentInfoDTO.setMock(environment.getMock());
|
||||||
BeanUtils.copyBean(environmentInfoDTO, environment);
|
BeanUtils.copyBean(environmentInfoDTO, environment);
|
||||||
environmentInfoDTO.setConfig(getEnvironmentConfig(environmentId));
|
environmentInfoDTO.setConfig(getEnvironmentConfig(environmentId));
|
||||||
if (BooleanUtils.isTrue(environment.getMock())) {
|
|
||||||
SystemParameterService systemParameterService = CommonBeanFactory.getBean(SystemParameterService.class);
|
SystemParameterService systemParameterService = CommonBeanFactory.getBean(SystemParameterService.class);
|
||||||
if (systemParameterService != null) {
|
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
||||||
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
String baseUrl = baseSystemConfigDTO.getUrl();
|
||||||
String baseUrl = baseSystemConfigDTO.getUrl();
|
|
||||||
if (StringUtils.isNotEmpty(baseUrl)) {
|
handleMockEnv(baseUrl, environment, environmentInfoDTO);
|
||||||
Project project = projectMapper.selectByPrimaryKey(environment.getProjectId());
|
|
||||||
String domain = baseUrl.replace(HTTP, StringUtils.EMPTY).replace(HTTPS, StringUtils.EMPTY);
|
|
||||||
String protocol = baseUrl.substring(0, baseUrl.indexOf(domain) -3 );
|
|
||||||
if (environmentInfoDTO.getConfig() != null && CollectionUtils.isNotEmpty(environmentInfoDTO.getConfig().getHttpConfig())) {
|
|
||||||
environmentInfoDTO.getConfig().getHttpConfig().getFirst().setId(IDGenerator.nextStr());
|
|
||||||
environmentInfoDTO.getConfig().getHttpConfig().getFirst().setProtocol(protocol);
|
|
||||||
environmentInfoDTO.getConfig().getHttpConfig().getFirst().setHostname(StringUtils.join(domain, MOCK_EVN_SOCKET, project.getNum()));
|
|
||||||
environmentInfoDTO.getConfig().getHttpConfig().getFirst().setUrl(StringUtils.join(baseUrl, MOCK_EVN_SOCKET, project.getNum()));
|
|
||||||
} else {
|
|
||||||
List<HttpConfig> httpConfigs = new ArrayList<>();
|
|
||||||
HttpConfig httpConfig = new HttpConfig();
|
|
||||||
httpConfig.setId(IDGenerator.nextStr());
|
|
||||||
httpConfig.setProtocol(protocol);
|
|
||||||
httpConfig.setHostname(StringUtils.join(domain, MOCK_EVN_SOCKET, project.getNum()));
|
|
||||||
httpConfig.setUrl(StringUtils.join(baseUrl, MOCK_EVN_SOCKET, project.getNum()));
|
|
||||||
httpConfigs.add(httpConfig);
|
|
||||||
environmentInfoDTO.getConfig().setHttpConfig(httpConfigs);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return environmentInfoDTO;
|
return environmentInfoDTO;
|
||||||
}
|
}
|
||||||
|
@ -466,17 +445,45 @@ public class EnvironmentService extends MoveNodeService {
|
||||||
environmentInfo.setConfig(JSON.parseObject(new String(environmentBlob.getConfig()), EnvironmentConfig.class));
|
environmentInfo.setConfig(JSON.parseObject(new String(environmentBlob.getConfig()), EnvironmentConfig.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (BooleanUtils.isTrue(environment.getMock())) {
|
handleMockEnv(baseUrl, environment, environmentInfo, projectMap);
|
||||||
if (StringUtils.isNotEmpty(baseUrl)) {
|
|
||||||
Long projectNum = projectMap.get(environment.getProjectId()).getNum();
|
|
||||||
environmentInfo.getConfig().getHttpConfig().getFirst().setHostname(StringUtils.join(baseUrl, MOCK_EVN_SOCKET, projectNum));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
environmentInfos.add(environmentInfo);
|
environmentInfos.add(environmentInfo);
|
||||||
}
|
}
|
||||||
return environmentInfos;
|
return environmentInfos;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void handleMockEnv(String baseUrl, Environment environment, EnvironmentInfoDTO environmentInfo) {
|
||||||
|
if (BooleanUtils.isTrue(environment.getMock())) {
|
||||||
|
Project project = projectMapper.selectByPrimaryKey(environment.getProjectId());
|
||||||
|
handleMockEnv(baseUrl, environment, environmentInfo, Map.of(project.getId(), project));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void handleMockEnv(String baseUrl, Environment environment, EnvironmentInfoDTO environmentInfo, Map<String, Project> projectMap) {
|
||||||
|
if (BooleanUtils.isTrue(environment.getMock())) {
|
||||||
|
if (StringUtils.isNotEmpty(baseUrl)) {
|
||||||
|
Project project = projectMap.get(environment.getProjectId());
|
||||||
|
String domain = baseUrl.replace(HTTP, StringUtils.EMPTY).replace(HTTPS, StringUtils.EMPTY);
|
||||||
|
String protocol = baseUrl.substring(0, baseUrl.indexOf(domain) - 3);
|
||||||
|
if (environmentInfo.getConfig() != null && CollectionUtils.isNotEmpty(environmentInfo.getConfig().getHttpConfig())) {
|
||||||
|
environmentInfo.getConfig().getHttpConfig().getFirst().setId(IDGenerator.nextStr());
|
||||||
|
environmentInfo.getConfig().getHttpConfig().getFirst().setProtocol(protocol);
|
||||||
|
environmentInfo.getConfig().getHttpConfig().getFirst().setHostname(StringUtils.join(domain, MOCK_EVN_SOCKET, project.getNum()));
|
||||||
|
environmentInfo.getConfig().getHttpConfig().getFirst().setUrl(StringUtils.join(baseUrl, MOCK_EVN_SOCKET, project.getNum()));
|
||||||
|
} else {
|
||||||
|
List<HttpConfig> httpConfigs = new ArrayList<>();
|
||||||
|
HttpConfig httpConfig = new HttpConfig();
|
||||||
|
httpConfig.setId(IDGenerator.nextStr());
|
||||||
|
httpConfig.setProtocol(protocol);
|
||||||
|
httpConfig.setHostname(StringUtils.join(domain, MOCK_EVN_SOCKET, project.getNum()));
|
||||||
|
httpConfig.setUrl(StringUtils.join(baseUrl, MOCK_EVN_SOCKET, project.getNum()));
|
||||||
|
httpConfigs.add(httpConfig);
|
||||||
|
environmentInfo.getConfig().setHttpConfig(httpConfigs);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private List<Project> getProjects(List<String> projectIds) {
|
private List<Project> getProjects(List<String> projectIds) {
|
||||||
if (CollectionUtils.isEmpty(projectIds)) {
|
if (CollectionUtils.isEmpty(projectIds)) {
|
||||||
return Collections.emptyList();
|
return Collections.emptyList();
|
||||||
|
|
Loading…
Reference in New Issue