This commit is contained in:
liqiang-fit2cloud 2022-12-20 10:06:26 +08:00
commit 11673b0a09
10 changed files with 56 additions and 40 deletions

View File

@ -66,6 +66,7 @@ import org.apache.jmeter.protocol.http.control.HeaderManager;
import org.apache.jmeter.protocol.http.sampler.HTTPSamplerProxy; import org.apache.jmeter.protocol.http.sampler.HTTPSamplerProxy;
import org.apache.jmeter.protocol.http.util.HTTPArgument; import org.apache.jmeter.protocol.http.util.HTTPArgument;
import org.apache.jmeter.protocol.http.util.HTTPFileArg; import org.apache.jmeter.protocol.http.util.HTTPFileArg;
import org.apache.jmeter.protocol.java.sampler.BeanShellSampler;
import org.apache.jmeter.protocol.java.sampler.JSR223Sampler; import org.apache.jmeter.protocol.java.sampler.JSR223Sampler;
import org.apache.jmeter.protocol.jdbc.config.DataSourceElement; import org.apache.jmeter.protocol.jdbc.config.DataSourceElement;
import org.apache.jmeter.protocol.jdbc.sampler.JDBCSampler; import org.apache.jmeter.protocol.jdbc.sampler.JDBCSampler;
@ -737,12 +738,21 @@ public class JMeterParser extends ApiImportAbstractParser<ScenarioImport> {
((MsJSR223Processor) elementNode).setScript(jsr223Sampler.getPropertyAsString(ElementConstants.SCRIPT)); ((MsJSR223Processor) elementNode).setScript(jsr223Sampler.getPropertyAsString(ElementConstants.SCRIPT));
((MsJSR223Processor) elementNode).setScriptLanguage(jsr223Sampler.getPropertyAsString("scriptLanguage")); ((MsJSR223Processor) elementNode).setScriptLanguage(jsr223Sampler.getPropertyAsString("scriptLanguage"));
} }
// BeanShell自定义脚本
else if (key instanceof BeanShellSampler) {
BeanShellSampler jsr223Sampler = (BeanShellSampler) key;
elementNode = new MsJSR223Processor();
BeanUtils.copyBean(elementNode, jsr223Sampler);
((MsJSR223Processor) elementNode).setJsrEnable(false);
((MsJSR223Processor) elementNode).setScript(jsr223Sampler.getPropertyAsString(ElementConstants.SCRIPT));
((MsJSR223Processor) elementNode).setScriptLanguage(jsr223Sampler.getPropertyAsString("scriptLanguage"));
}
// 后置脚本 // 后置脚本
else if (key instanceof JSR223PostProcessor) { else if (key instanceof JSR223PostProcessor) {
JSR223PostProcessor jsr223Sampler = (JSR223PostProcessor) key; JSR223PostProcessor jsr223Sampler = (JSR223PostProcessor) key;
elementNode = new MsJSR223PostProcessor(); elementNode = new MsJSR223PostProcessor();
BeanUtils.copyBean(elementNode, jsr223Sampler); BeanUtils.copyBean(elementNode, jsr223Sampler);
((MsJSR223PostProcessor) elementNode).setScript(jsr223Sampler.getPropertyAsString(ElementConstants.SCRIPT)); ((MsJSR223PostProcessor) elementNode).setScript(jsr223Sampler.getPropertyAsString("BeanShellSampler.query"));
((MsJSR223PostProcessor) elementNode).setScriptLanguage(jsr223Sampler.getPropertyAsString("scriptLanguage")); ((MsJSR223PostProcessor) elementNode).setScriptLanguage(jsr223Sampler.getPropertyAsString("scriptLanguage"));
} else if (key instanceof BeanShellPostProcessor) { } else if (key instanceof BeanShellPostProcessor) {
elementNode = getMsTestElement((BeanShellPostProcessor) key); elementNode = getMsTestElement((BeanShellPostProcessor) key);

View File

@ -663,7 +663,7 @@ public class ApiDefinitionImportUtilService {
} }
if (apiDefinition.getLatest()) { if (apiDefinition.getLatest()) {
for (ApiDefinitionWithBLOBs apiDefinitionWithBLOBs : repeatList) { for (ApiDefinitionWithBLOBs apiDefinitionWithBLOBs : repeatList) {
if (apiDefinitionWithBLOBs.getLatest()) { if (apiDefinitionWithBLOBs.getLatest() && !apiDefinition.getId().equalsIgnoreCase(apiDefinitionWithBLOBs.getId())) {
apiDefinitionWithBLOBs.setLatest(false); apiDefinitionWithBLOBs.setLatest(false);
} }
batchMapper.updateByPrimaryKey(apiDefinitionWithBLOBs); batchMapper.updateByPrimaryKey(apiDefinitionWithBLOBs);

View File

@ -621,7 +621,6 @@ public class TestPlanApiCaseService {
List<TestPlanApiCase> testPlanApiCases = testPlanApiCaseMapper.selectByExample(testPlanApiCaseExample); List<TestPlanApiCase> testPlanApiCases = testPlanApiCaseMapper.selectByExample(testPlanApiCaseExample);
TestPlanApiCaseMapper apiCaseMapper = sqlSession.getMapper(TestPlanApiCaseMapper.class); TestPlanApiCaseMapper apiCaseMapper = sqlSession.getMapper(TestPlanApiCaseMapper.class);
if (!CollectionUtils.isEmpty(testPlanApiCases)) { if (!CollectionUtils.isEmpty(testPlanApiCases)) {
Long nextApiOrder = ServiceUtils.getNextOrder(targetPlanId, extTestPlanApiCaseMapper::getLastOrder);
for (TestPlanApiCase apiCase : testPlanApiCases) { for (TestPlanApiCase apiCase : testPlanApiCases) {
TestPlanApiCase api = new TestPlanApiCase(); TestPlanApiCase api = new TestPlanApiCase();
api.setId(UUID.randomUUID().toString()); api.setId(UUID.randomUUID().toString());
@ -631,8 +630,7 @@ public class TestPlanApiCaseService {
api.setCreateTime(System.currentTimeMillis()); api.setCreateTime(System.currentTimeMillis());
api.setUpdateTime(System.currentTimeMillis()); api.setUpdateTime(System.currentTimeMillis());
api.setCreateUser(SessionUtils.getUserId()); api.setCreateUser(SessionUtils.getUserId());
api.setOrder(nextApiOrder); api.setOrder(apiCase.getOrder());
nextApiOrder += 5000;
apiCaseMapper.insert(api); apiCaseMapper.insert(api);
} }
} }

View File

@ -711,7 +711,6 @@ public class TestPlanScenarioCaseService {
List<TestPlanApiScenario> apiScenarios = testPlanApiScenarioMapper.selectByExampleWithBLOBs(testPlanApiScenarioExample); List<TestPlanApiScenario> apiScenarios = testPlanApiScenarioMapper.selectByExampleWithBLOBs(testPlanApiScenarioExample);
TestPlanApiScenarioMapper apiScenarioMapper = sqlSession.getMapper(TestPlanApiScenarioMapper.class); TestPlanApiScenarioMapper apiScenarioMapper = sqlSession.getMapper(TestPlanApiScenarioMapper.class);
if (!CollectionUtils.isEmpty(apiScenarios)) { if (!CollectionUtils.isEmpty(apiScenarios)) {
Long nextScenarioOrder = ServiceUtils.getNextOrder(targetPlanId, extTestPlanScenarioCaseMapper::getLastOrder);
for (TestPlanApiScenario apiScenario : apiScenarios) { for (TestPlanApiScenario apiScenario : apiScenarios) {
TestPlanApiScenario planScenario = new TestPlanApiScenario(); TestPlanApiScenario planScenario = new TestPlanApiScenario();
planScenario.setId(UUID.randomUUID().toString()); planScenario.setId(UUID.randomUUID().toString());
@ -724,8 +723,7 @@ public class TestPlanScenarioCaseService {
planScenario.setCreateTime(System.currentTimeMillis()); planScenario.setCreateTime(System.currentTimeMillis());
planScenario.setUpdateTime(System.currentTimeMillis()); planScenario.setUpdateTime(System.currentTimeMillis());
planScenario.setCreateUser(SessionUtils.getUserId()); planScenario.setCreateUser(SessionUtils.getUserId());
planScenario.setOrder(nextScenarioOrder); planScenario.setOrder(apiScenario.getOrder());
nextScenarioOrder += 5000;
apiScenarioMapper.insert(planScenario); apiScenarioMapper.insert(planScenario);
} }
} }

View File

@ -18,21 +18,18 @@
:content="$t('commons.import')" :content="$t('commons.import')"
@click="importJSON" @click="importJSON"
/> />
<el-popover <el-dropdown @command="handleExportCommand" class="scenario-ext-btn" trigger="hover"
v-permission="['PROJECT_ENVIRONMENT:READ+EXPORT']" v-permission="['PROJECT_ENVIRONMENT:READ+EXPORT']">
placement="bottom"
trigger="hover"
:content="$t('envrionment.export_variable_tip')"
width="300">
<ms-table-button <ms-table-button
style="margin-left: 10px" style="margin-left: 10px"
slot="reference"
v-permission="['PROJECT_ENVIRONMENT:READ+EXPORT']"
icon="el-icon-box" icon="el-icon-box"
:content="$t('commons.export')" :content="$t('commons.export')"
@click="exportJSON"
/> />
</el-popover> <el-dropdown-menu slot="dropdown">
<el-dropdown-item command="exportApi">{{ $t('envrionment.export_variable_tip') }}</el-dropdown-item>
</el-dropdown-menu>
</el-dropdown>
<el-link <el-link
style="margin-left: 10px" style="margin-left: 10px"
@click="batchAdd" @click="batchAdd"
@ -572,6 +569,9 @@ export default {
} }
}); });
}, },
handleExportCommand(command){
this.exportJSON();
}
}, },
created() { created() {
if (this.items.length === 0) { if (this.items.length === 0) {

View File

@ -1,6 +1,6 @@
package io.metersphere.utils; package io.metersphere.utils;
import com.google.gson.Gson; import com.google.gson.GsonBuilder;
import io.metersphere.vo.Condition; import io.metersphere.vo.Condition;
import io.metersphere.vo.ElementCondition; import io.metersphere.vo.ElementCondition;
import net.minidev.json.JSONArray; import net.minidev.json.JSONArray;
@ -106,7 +106,7 @@ public class DocumentUtils {
if (subj == null) { if (subj == null) {
str = "null"; str = "null";
} else if (subj instanceof Map) { } else if (subj instanceof Map) {
str = new Gson().toJson(subj); str = new GsonBuilder().serializeNulls().create().toJson(subj);
} else if (!(subj instanceof Double) && !(subj instanceof Float)) { } else if (!(subj instanceof Double) && !(subj instanceof Float)) {
str = subj.toString(); str = subj.toString();
} else { } else {

View File

@ -511,12 +511,10 @@ public class GroupService {
return; return;
} }
if (StringUtils.equals(group.getType(), UserGroupType.SYSTEM)) { if (!StringUtils.equals(group.getType(), UserGroupType.SYSTEM) && CollectionUtils.isNotEmpty(request.getSourceIds())) {
this.addSystemGroupUser(group, request.getUserIds()); this.addNotSystemGroupUser(group, request.getUserIds(), request.getSourceIds());
} else { } else {
if (CollectionUtils.isNotEmpty(request.getSourceIds())) { LogUtil.warn("no permission to add system group!");
this.addNotSystemGroupUser(group, request.getUserIds(), request.getSourceIds());
}
} }
} }

View File

@ -471,7 +471,13 @@ public class GroupService {
} }
if (StringUtils.equals(group.getType(), UserGroupType.SYSTEM)) { if (StringUtils.equals(group.getType(), UserGroupType.SYSTEM)) {
this.addSystemGroupUser(group, request.getUserIds()); SessionUser user = Objects.requireNonNull(SessionUtils.getUser());
long count = user.getGroups().stream().filter(g -> StringUtils.equals(g.getType(), UserGroupType.SYSTEM)).count();
if (count > 0) {
this.addSystemGroupUser(group, request.getUserIds());
} else {
LogUtil.warn("no permission to add system group!");
}
} else { } else {
if (CollectionUtils.isNotEmpty(request.getSourceIds())) { if (CollectionUtils.isNotEmpty(request.getSourceIds())) {
this.addNotSystemGroupUser(group, request.getUserIds(), request.getSourceIds()); this.addNotSystemGroupUser(group, request.getUserIds(), request.getSourceIds());

View File

@ -808,25 +808,31 @@ public class UserService {
} }
} }
SessionUser user = Objects.requireNonNull(SessionUtils.getUser());
long systemGroupCount = user.getGroups().stream().filter(g -> StringUtils.equals(g.getType(), UserGroupType.SYSTEM)).count();
for (String userId : userIds) { for (String userId : userIds) {
Set<String> set = sourceMap.keySet(); Set<String> set = sourceMap.keySet();
for (String group : set) { for (String group : set) {
Group gp = groupMapper.selectByPrimaryKey(group); Group gp = groupMapper.selectByPrimaryKey(group);
if (gp != null) { if (gp != null) {
if (StringUtils.equals(UserGroupType.SYSTEM, gp.getType())) { if (StringUtils.equals(UserGroupType.SYSTEM, gp.getType())) {
UserGroupExample userGroupExample = new UserGroupExample(); if (systemGroupCount > 0) {
userGroupExample.createCriteria().andGroupIdEqualTo(group).andUserIdEqualTo(userId); UserGroupExample userGroupExample = new UserGroupExample();
List<UserGroup> userGroups = userGroupMapper.selectByExample(userGroupExample); userGroupExample.createCriteria().andGroupIdEqualTo(group).andUserIdEqualTo(userId);
if (CollectionUtils.isEmpty(userGroups)) { List<UserGroup> userGroups = userGroupMapper.selectByExample(userGroupExample);
UserGroup userGroup = new UserGroup(); if (CollectionUtils.isEmpty(userGroups)) {
userGroup.setId(UUID.randomUUID().toString()); UserGroup userGroup = new UserGroup();
userGroup.setGroupId(group); userGroup.setId(UUID.randomUUID().toString());
userGroup.setSourceId("system"); userGroup.setGroupId(group);
userGroup.setUserId(userId); userGroup.setSourceId("system");
userGroup.setUpdateTime(System.currentTimeMillis()); userGroup.setUserId(userId);
userGroup.setCreateTime(System.currentTimeMillis()); userGroup.setUpdateTime(System.currentTimeMillis());
userGroupMapper.insertSelective(userGroup); userGroup.setCreateTime(System.currentTimeMillis());
userGroupMapper.insertSelective(userGroup);
}
} }
} else { } else {
// 组织工作空间项目 // 组织工作空间项目
UserGroupExample userGroupExample = new UserGroupExample(); UserGroupExample userGroupExample = new UserGroupExample();

View File

@ -19,9 +19,9 @@
</span> </span>
<span v-if="report.endTime || report.createTime"> <span v-if="report.endTime || report.createTime">
<span style="margin-left: 10px">{{ $t('report.test_start_time') }}</span> <span style="margin-left: 10px">{{ $t('report.test_start_time') }}</span>
<span class="time"> {{ report.createTime | timestampFormatDate }}</span> <span class="time"> {{ report.createTime | datetimeFormat }}</span>
<span style="margin-left: 10px">{{ $t('report.test_end_time') }}</span> <span style="margin-left: 10px">{{ $t('report.test_end_time') }}</span>
<span class="time"> {{ report.endTime | timestampFormatDate }}</span> <span class="time"> {{ report.endTime | datetimeFormat }}</span>
</span> </span>
<div style="float: right"> <div style="float: right">
<el-button v-if="!isPlan && (!debug || exportFlag) && !isTemplate && !isUi" <el-button v-if="!isPlan && (!debug || exportFlag) && !isTemplate && !isUi"