fix (接口测试): 修复设置了参数默认值后,test执行无法修改问题
--bug=1008159 --user=赵勇 【接口测试】接口定义,设置了参数默认值后,test执行的时候无法修改 https://www.tapd.cn/55049933/s/1074611
This commit is contained in:
parent
c9a9b257fc
commit
4e80e2485f
|
@ -3,7 +3,7 @@ package io.metersphere.api.dto.scenario;
|
||||||
import com.alibaba.fastjson.JSONObject;
|
import com.alibaba.fastjson.JSONObject;
|
||||||
import com.alibaba.fastjson.serializer.SerializerFeature;
|
import com.alibaba.fastjson.serializer.SerializerFeature;
|
||||||
import io.metersphere.api.dto.scenario.request.BodyFile;
|
import io.metersphere.api.dto.scenario.request.BodyFile;
|
||||||
import io.metersphere.commons.json.JSONSchemaGenerator;
|
import io.metersphere.commons.json.JSONSchemaRunTest;
|
||||||
import io.metersphere.commons.utils.FileUtils;
|
import io.metersphere.commons.utils.FileUtils;
|
||||||
import io.metersphere.jmeter.utils.ScriptEngineUtils;
|
import io.metersphere.jmeter.utils.ScriptEngineUtils;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
@ -87,7 +87,7 @@ public class Body {
|
||||||
if (StringUtils.isNotBlank(this.type) && StringUtils.equals(this.type, "JSON")) {
|
if (StringUtils.isNotBlank(this.type) && StringUtils.equals(this.type, "JSON")) {
|
||||||
if(StringUtils.isNotEmpty(this.format) && this.getJsonSchema() != null
|
if(StringUtils.isNotEmpty(this.format) && this.getJsonSchema() != null
|
||||||
&& "JSON-SCHEMA".equals(this.format)) {
|
&& "JSON-SCHEMA".equals(this.format)) {
|
||||||
this.raw = JSONSchemaGenerator.getJson(com.alibaba.fastjson.JSON.toJSONString(this.getJsonSchema()));
|
this.raw = JSONSchemaRunTest.getJson(com.alibaba.fastjson.JSON.toJSONString(this.getJsonSchema()));
|
||||||
} else { // json 文本也支持 mock 参数
|
} else { // json 文本也支持 mock 参数
|
||||||
try {
|
try {
|
||||||
JSONObject jsonObject = com.alibaba.fastjson.JSON.parseObject(this.getRaw());
|
JSONObject jsonObject = com.alibaba.fastjson.JSON.parseObject(this.getRaw());
|
||||||
|
|
|
@ -0,0 +1,229 @@
|
||||||
|
package io.metersphere.commons.json;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import com.google.gson.*;
|
||||||
|
import io.metersphere.commons.utils.LogUtil;
|
||||||
|
import io.metersphere.jmeter.utils.ScriptEngineUtils;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
|
||||||
|
import java.util.LinkedList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map.Entry;
|
||||||
|
|
||||||
|
public class JSONSchemaRunTest {
|
||||||
|
|
||||||
|
private static void generator(String json, JSONObject obj) {
|
||||||
|
analyzeSchema(json, obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void analyzeSchema(String json, JSONObject rootObj) {
|
||||||
|
try {
|
||||||
|
Gson gson = new Gson();
|
||||||
|
JsonElement element = gson.fromJson(json, JsonElement.class);
|
||||||
|
JsonObject rootElement = element.getAsJsonObject();
|
||||||
|
analyzeRootSchemaElement(rootElement, rootObj);
|
||||||
|
} catch (Exception e) {
|
||||||
|
LogUtil.error(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void analyzeRootSchemaElement(JsonObject rootElement, JSONObject rootObj) {
|
||||||
|
if (rootElement.has("type") || rootElement.has("allOf")) {
|
||||||
|
analyzeObject(rootElement, rootObj);
|
||||||
|
}
|
||||||
|
if (rootElement.has("definitions")) {
|
||||||
|
analyzeDefinitions(rootElement);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void analyzeObject(JsonObject object, JSONObject rootObj) {
|
||||||
|
if (object.has("allOf")) {
|
||||||
|
JsonArray allOfArray = object.get("allOf").getAsJsonArray();
|
||||||
|
for (JsonElement allOfElement : allOfArray) {
|
||||||
|
JsonObject allOfElementObj = allOfElement.getAsJsonObject();
|
||||||
|
if (allOfElementObj.has("properties")) {
|
||||||
|
JsonObject propertiesObj = allOfElementObj.get("properties").getAsJsonObject();
|
||||||
|
for (Entry<String, JsonElement> entry : propertiesObj.entrySet()) {
|
||||||
|
String propertyKey = entry.getKey();
|
||||||
|
JsonObject propertyObj = propertiesObj.get(propertyKey).getAsJsonObject();
|
||||||
|
analyzeProperty(rootObj, propertyKey, propertyObj);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (object.has("properties")) {
|
||||||
|
JsonObject propertiesObj = object.get("properties").getAsJsonObject();
|
||||||
|
for (Entry<String, JsonElement> entry : propertiesObj.entrySet()) {
|
||||||
|
String propertyKey = entry.getKey();
|
||||||
|
JsonObject propertyObj = propertiesObj.get(propertyKey).getAsJsonObject();
|
||||||
|
analyzeProperty(rootObj, propertyKey, propertyObj);
|
||||||
|
}
|
||||||
|
} else if (object.has("type") && object.get("type").getAsString().equals("array")) {
|
||||||
|
analyzeProperty(rootObj, "MS-OBJECT", object);
|
||||||
|
} else if (object.has("type") && !object.get("type").getAsString().equals("object")) {
|
||||||
|
analyzeProperty(rootObj, object.getAsString(), object);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void analyzeProperty(JSONObject concept, String propertyName, JsonObject object) {
|
||||||
|
if (object.has("type")) {
|
||||||
|
String propertyObjType = null;
|
||||||
|
if (object.get("type") instanceof JsonPrimitive) {
|
||||||
|
propertyObjType = object.get("type").getAsString();
|
||||||
|
} else if (object.get("type") instanceof JsonArray) {
|
||||||
|
JsonArray typeArray = (JsonArray) object.get("type").getAsJsonArray();
|
||||||
|
propertyObjType = typeArray.get(0).getAsString();
|
||||||
|
if (typeArray.size() > 1) {
|
||||||
|
if (typeArray.get(1).getAsString().equals("null")) {
|
||||||
|
// 暂不处理,后续使用时再加
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (propertyObjType.equals("string") || propertyObjType.equals("enum")) {
|
||||||
|
concept.put(propertyName, getValue(object));
|
||||||
|
} else if (propertyObjType.equals("integer") || propertyObjType.equals("number")) {
|
||||||
|
// 先设置空值
|
||||||
|
concept.put(propertyName, 0);
|
||||||
|
try {
|
||||||
|
if (object.has("mock") && object.get("mock").getAsJsonObject() != null && StringUtils.isNotEmpty(object.get("mock").getAsJsonObject().get("mock").getAsString())) {
|
||||||
|
Number value = object.get("mock").getAsJsonObject().get("mock").getAsNumber();
|
||||||
|
if (value.toString().indexOf(".") == -1) {
|
||||||
|
concept.put(propertyName, value.intValue());
|
||||||
|
} else {
|
||||||
|
concept.put(propertyName, value.floatValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
String value = ScriptEngineUtils.buildFunctionCallString(object.get("mock").getAsJsonObject().get("mock").getAsString());
|
||||||
|
concept.put(propertyName, value);
|
||||||
|
}
|
||||||
|
} else if (propertyObjType.equals("boolean")) {
|
||||||
|
// 先设置空值
|
||||||
|
concept.put(propertyName, false);
|
||||||
|
try {
|
||||||
|
if (object.has("mock") && object.get("mock").getAsJsonObject() != null && StringUtils.isNotEmpty(object.get("mock").getAsJsonObject().get("mock").getAsString())) {
|
||||||
|
String value = ScriptEngineUtils.buildFunctionCallString(object.get("mock").getAsJsonObject().get("mock").toString());
|
||||||
|
if (StringUtils.isNotEmpty(value)) {
|
||||||
|
if (value.indexOf("\"") != -1) {
|
||||||
|
value = value.replaceAll("\"", "");
|
||||||
|
}
|
||||||
|
concept.put(propertyName, Boolean.valueOf(value));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
concept.put(propertyName, false);
|
||||||
|
}
|
||||||
|
} else if (propertyObjType.equals("array")) {
|
||||||
|
// 先设置空值
|
||||||
|
List<Object> array = new LinkedList<>();
|
||||||
|
|
||||||
|
JsonArray jsonArray = new JsonArray();
|
||||||
|
if (object.has("items")) {
|
||||||
|
if (object.get("items").isJsonArray()) {
|
||||||
|
jsonArray = object.get("items").getAsJsonArray();
|
||||||
|
} else {
|
||||||
|
JsonObject itemsObject = object.get("items").getAsJsonObject();
|
||||||
|
array.add(itemsObject);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < jsonArray.size(); i++) {
|
||||||
|
JsonObject itemsObject = jsonArray.get(i).getAsJsonObject();
|
||||||
|
if (object.has("items")) {
|
||||||
|
if (itemsObject.has("mock") && itemsObject.get("mock").getAsJsonObject() != null && StringUtils.isNotEmpty(itemsObject.get("mock").getAsJsonObject().get("mock").getAsString())) {
|
||||||
|
try {
|
||||||
|
int value = itemsObject.get("mock").getAsJsonObject().get("mock").getAsInt();
|
||||||
|
array.add(value);
|
||||||
|
} catch (Exception e) {
|
||||||
|
String value = ScriptEngineUtils.buildFunctionCallString(itemsObject.get("mock").getAsJsonObject().get("mock").getAsString());
|
||||||
|
array.add(value);
|
||||||
|
}
|
||||||
|
} else if (itemsObject.has("type") && (itemsObject.has("enum") || itemsObject.get("type").getAsString().equals("string"))) {
|
||||||
|
array.add(getValue(itemsObject));
|
||||||
|
} else if (itemsObject.has("type") && itemsObject.get("type").getAsString().equals("number")) {
|
||||||
|
if (itemsObject.has("mock") && itemsObject.get("mock").getAsJsonObject() != null && StringUtils.isNotEmpty(itemsObject.get("mock").getAsJsonObject().get("mock").getAsString())) {
|
||||||
|
String value = ScriptEngineUtils.buildFunctionCallString(itemsObject.get("mock").getAsJsonObject().get("mock").getAsString());
|
||||||
|
array.add(value);
|
||||||
|
} else {
|
||||||
|
array.add(0);
|
||||||
|
}
|
||||||
|
} else if (itemsObject.has("properties")) {
|
||||||
|
JSONObject propertyConcept = new JSONObject(true);
|
||||||
|
JsonObject propertiesObj = itemsObject.get("properties").getAsJsonObject();
|
||||||
|
for (Entry<String, JsonElement> entry : propertiesObj.entrySet()) {
|
||||||
|
String propertyKey = entry.getKey();
|
||||||
|
JsonObject propertyObj = propertiesObj.get(propertyKey).getAsJsonObject();
|
||||||
|
analyzeProperty(propertyConcept, propertyKey, propertyObj);
|
||||||
|
}
|
||||||
|
array.add(propertyConcept);
|
||||||
|
|
||||||
|
} else if (itemsObject.has("type") && itemsObject.get("type") instanceof JsonPrimitive) {
|
||||||
|
JSONObject newJsonObj = new JSONObject();
|
||||||
|
analyzeProperty(newJsonObj, propertyName + "_item", itemsObject);
|
||||||
|
array.add(newJsonObj.get(propertyName + "_item"));
|
||||||
|
}
|
||||||
|
} else if (object.has("items") && object.get("items").isJsonArray()) {
|
||||||
|
JsonArray itemsObjectArray = object.get("items").getAsJsonArray();
|
||||||
|
array.add(itemsObjectArray);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
concept.put(propertyName, array);
|
||||||
|
} else if (propertyObjType.equals("object")) {
|
||||||
|
JSONObject obj = new JSONObject();
|
||||||
|
concept.put(propertyName, obj);
|
||||||
|
analyzeObject(object, obj);
|
||||||
|
} else if (StringUtils.equalsIgnoreCase(propertyObjType, "null")) {
|
||||||
|
concept.put(propertyName, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Object getValue(JsonObject object) {
|
||||||
|
try {
|
||||||
|
if (object.has("mock") && object.get("mock").getAsJsonObject() != null && StringUtils.isNotEmpty(object.get("mock").getAsJsonObject().get("mock").getAsString()) && StringUtils.isNotEmpty(object.get("mock").getAsJsonObject().get("mock").getAsString())) {
|
||||||
|
String value = ScriptEngineUtils.buildFunctionCallString(object.get("mock").getAsJsonObject().get("mock").getAsString());
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
return object.get("mock").getAsJsonObject().get("mock");
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void analyzeDefinitions(JsonObject object) {
|
||||||
|
JsonObject definitionsObj = object.get("definitions").getAsJsonObject();
|
||||||
|
for (Entry<String, JsonElement> entry : definitionsObj.entrySet()) {
|
||||||
|
String definitionKey = entry.getKey();
|
||||||
|
JsonObject definitionObj = definitionsObj.get(definitionKey).getAsJsonObject();
|
||||||
|
JSONObject obj = new JSONObject();
|
||||||
|
analyzeRootSchemaElement(definitionObj, obj);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private static String formerJson(String jsonSchema) {
|
||||||
|
try {
|
||||||
|
JSONObject root = new JSONObject(true);
|
||||||
|
generator(jsonSchema, root);
|
||||||
|
// 格式化返回
|
||||||
|
Gson gson = new GsonBuilder().serializeNulls().setPrettyPrinting().disableHtmlEscaping().create();
|
||||||
|
if (root.get("MS-OBJECT") != null) {
|
||||||
|
return gson.toJson(root.get("MS-OBJECT"));
|
||||||
|
}
|
||||||
|
return gson.toJson(root);
|
||||||
|
} catch (Exception e) {
|
||||||
|
return jsonSchema;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String getJson(String jsonSchema) {
|
||||||
|
try {
|
||||||
|
if (StringUtils.isEmpty(jsonSchema)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return formerJson(jsonSchema);
|
||||||
|
} catch (Exception ex) {
|
||||||
|
return jsonSchema;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue