fix(接口测试): swagger导入的接口参数做修改时变更记录有误

--bug=1026740 --user=宋昌昌 【接口测试】接口导入后-删除query参数-变更记录显示未变更的参数 https://www.tapd.cn/55049933/s/1385246,
--bug=1026741 --user=宋昌昌 【接口测试】导入swagger文件覆盖同一接口-变更记录未生成文件导入变更记录 https://www.tapd.cn/55049933/s/1385245
This commit is contained in:
song-cc-rock 2023-06-25 18:54:09 +08:00 committed by fit2-zhao
parent b19867358b
commit 4a4d6835f0
3 changed files with 53 additions and 7 deletions

View File

@ -128,6 +128,8 @@ public abstract class ApiImportAbstractParser<T> implements ApiImportParser<T> {
apiDefinition.setUserId(SessionUtils.getUserId()); apiDefinition.setUserId(SessionUtils.getUserId());
apiDefinition.setCreateUser(SessionUtils.getUserId()); apiDefinition.setCreateUser(SessionUtils.getUserId());
} }
// set default remark of import api to empty string rather then null
apiDefinition.setRemark(StringUtils.EMPTY);
return apiDefinition; return apiDefinition;
} }

View File

@ -17,6 +17,7 @@ import io.metersphere.log.vo.api.DefinitionReference;
import org.apache.commons.collections4.CollectionUtils; import org.apache.commons.collections4.CollectionUtils;
import org.apache.commons.collections4.MapUtils; import org.apache.commons.collections4.MapUtils;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.json.JSONArray;
import org.json.JSONObject; import org.json.JSONObject;
import java.util.*; import java.util.*;
@ -222,7 +223,7 @@ public class ApiTestDefinitionDiffUtilImpl implements ApiDefinitionDiffUtil {
if (!StringUtils.equals(headerNew, headerOld)) { if (!StringUtils.equals(headerNew, headerOld)) {
String patch = jsonDiff.diff(headerOld, headerNew); String patch = jsonDiff.diff(headerOld, headerNew);
String diffPatch = jsonDiff.apply(headerNew, patch); String diffPatch = jsonDiff.apply(headerNew, patch);
if (StringUtils.isNotBlank(diffPatch)) { if (StringUtils.isNotBlank(diffPatch) && !isDiffPatchRootEmpty(diffPatch)) {
diffMap.put("header", diffPatch); diffMap.put("header", diffPatch);
} }
} }
@ -234,7 +235,7 @@ public class ApiTestDefinitionDiffUtilImpl implements ApiDefinitionDiffUtil {
if (!StringUtils.equals(statusCodeNew, statusCodeOld)) { if (!StringUtils.equals(statusCodeNew, statusCodeOld)) {
String patch = jsonDiff.diff(statusCodeOld, statusCodeNew); String patch = jsonDiff.diff(statusCodeOld, statusCodeNew);
String diff = jsonDiff.apply(statusCodeNew, patch); String diff = jsonDiff.apply(statusCodeNew, patch);
if (StringUtils.isNotBlank(diff)) { if (StringUtils.isNotBlank(diff) && !isDiffPatchRootEmpty(diff)) {
diffMap.put(STATUS_CODE, diff); diffMap.put(STATUS_CODE, diff);
} }
} }
@ -246,7 +247,7 @@ public class ApiTestDefinitionDiffUtilImpl implements ApiDefinitionDiffUtil {
if (!StringUtils.equals(bodyStrNew, bodyStrOld)) { if (!StringUtils.equals(bodyStrNew, bodyStrOld)) {
String patch = jsonDiff.diff(bodyStrOld, bodyStrNew); String patch = jsonDiff.diff(bodyStrOld, bodyStrNew);
String diff = jsonDiff.apply(bodyStrNew, patch); String diff = jsonDiff.apply(bodyStrNew, patch);
if (StringUtils.isNotBlank(diff)) { if (StringUtils.isNotBlank(diff) && !isDiffPatchRootEmpty(diff) && !isBodyDiffPatchEmpty(diff)) {
diffMap.put(BODY, diff); diffMap.put(BODY, diff);
} }
} }
@ -266,7 +267,7 @@ public class ApiTestDefinitionDiffUtilImpl implements ApiDefinitionDiffUtil {
if (!StringUtils.equals(bodyFormNew, bodyFormOld)) { if (!StringUtils.equals(bodyFormNew, bodyFormOld)) {
String patch = jsonDiff.diff(bodyFormOld, bodyFormNew); String patch = jsonDiff.diff(bodyFormOld, bodyFormNew);
String diff = jsonDiff.apply(bodyFormNew, patch); String diff = jsonDiff.apply(bodyFormNew, patch);
if (StringUtils.isNotBlank(diff)) { if (StringUtils.isNotBlank(diff) && !isDiffPatchRootEmpty(diff)) {
diffMap.put(BODY_FORM, diff); diffMap.put(BODY_FORM, diff);
} }
} }
@ -414,4 +415,50 @@ public class ApiTestDefinitionDiffUtilImpl implements ApiDefinitionDiffUtil {
} }
} }
} }
/**
* is diff-patch root element empty
* @param diffPatch json-string
* @return true: empty, false: not empty
*/
private static boolean isDiffPatchRootEmpty(String diffPatch) {
JSONObject jsonObject = JSONUtil.parseObject(diffPatch);
if (jsonObject.isEmpty()) {
return true;
}
if (!jsonObject.has("root")) {
return false;
}
Object root = jsonObject.get("root");
if (root == null) {
return true;
}
if (root instanceof String) {
return StringUtils.isEmpty((String) root);
}
if (root instanceof List) {
return CollectionUtils.isEmpty((List) root);
}
if (root instanceof Map) {
return ((Map) root).isEmpty();
}
if (root instanceof JSONArray) {
return ((JSONArray) root).isEmpty();
}
return false;
}
/**
* is body's diff-patch empty
* @param bodyDiff body's diff-patch
* @return true: empty, false: not empty
*/
private static boolean isBodyDiffPatchEmpty(String bodyDiff) {
JSONObject jsonObject = JSONUtil.parseObject(bodyDiff);
if (jsonObject.isEmpty()) {
return true;
}
return !jsonObject.has("form") && !jsonObject.has("jsonSchema") && !jsonObject.has("++jsonSchema")
&& !jsonObject.has("raw_1") && !jsonObject.has("raw_2");
}
} }

View File

@ -288,9 +288,6 @@ export default {
this.items.splice(i, 1); this.items.splice(i, 1);
} }
} }
if (this.items.length === 0 || this.items[this.items.length - 1].name) {
this.items.push(new KeyValue({ enable: true, name: '', value: '' }));
}
} }
}, },
}; };