fix: 修复mock返回JSON-Schema参数不全的问题、修复JSON-Schema响应参数在文档里不显示的问题
修复mock返回JSON-Schema参数不全的问题、修复JSON-Schema响应参数在文档里不显示的问题
This commit is contained in:
parent
f0b31114a2
commit
b0e81fcc26
|
@ -28,6 +28,7 @@ public class ApiDocumentInfoDTO {
|
||||||
|
|
||||||
private String responseHead;
|
private String responseHead;
|
||||||
private String responseBody;
|
private String responseBody;
|
||||||
|
private Object jsonSchemaResponseBody;
|
||||||
private String responseBodyParamType;
|
private String responseBodyParamType;
|
||||||
private String responseBodyFormData;
|
private String responseBodyFormData;
|
||||||
private String responseBodyStrutureData;
|
private String responseBodyStrutureData;
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package io.metersphere.api.dto.mockconfig.response;
|
package io.metersphere.api.dto.mockconfig.response;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
|
|
||||||
|
@ -19,6 +20,8 @@ public class JsonSchemaReturnObj {
|
||||||
private String title;
|
private String title;
|
||||||
private String type;
|
private String type;
|
||||||
private int maxLength = -1;
|
private int maxLength = -1;
|
||||||
|
private JSONObject properties;
|
||||||
|
private JSONObject items;
|
||||||
|
|
||||||
public String getMockValue() {
|
public String getMockValue() {
|
||||||
if (mock == null) {
|
if (mock == null) {
|
||||||
|
|
|
@ -257,10 +257,32 @@ public class ApiDocumentService {
|
||||||
apiInfoDTO.setResponseBodyParamType(type);
|
apiInfoDTO.setResponseBodyParamType(type);
|
||||||
}
|
}
|
||||||
if (StringUtils.equalsAny(type, "JSON", "XML", "Raw")) {
|
if (StringUtils.equalsAny(type, "JSON", "XML", "Raw")) {
|
||||||
if (bodyObj.containsKey("raw")) {
|
|
||||||
String raw = bodyObj.getString("raw");
|
//判断是否是JsonSchema
|
||||||
apiInfoDTO.setResponseBodyStrutureData(raw);
|
boolean isJsonSchema = false;
|
||||||
|
if (bodyObj.containsKey("format")) {
|
||||||
|
String foramtValue = String.valueOf(bodyObj.get("format"));
|
||||||
|
if (StringUtils.equals("JSON-SCHEMA", foramtValue)) {
|
||||||
|
isJsonSchema = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
if (isJsonSchema) {
|
||||||
|
// apiInfoDTO.setRequestBodyParamType("JSON-SCHEMA");
|
||||||
|
apiInfoDTO.setResponseBodyParamType("JSON-SCHEMA");
|
||||||
|
apiInfoDTO.setJsonSchemaResponseBody(bodyObj);
|
||||||
|
// apiInfoDTO.setJsonSchemaBody(bodyObj);
|
||||||
|
} else {
|
||||||
|
if (bodyObj.containsKey("raw")) {
|
||||||
|
String raw = bodyObj.getString("raw");
|
||||||
|
apiInfoDTO.setResponseBodyStrutureData(raw);
|
||||||
|
//转化jsonObje 或者 jsonArray
|
||||||
|
this.setPreviewData(previewJsonArray, raw);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// if (bodyObj.containsKey("raw")) {
|
||||||
|
// String raw = bodyObj.getString("raw");
|
||||||
|
// apiInfoDTO.setResponseBodyStrutureData(raw);
|
||||||
|
// }
|
||||||
} else if (StringUtils.equalsAny(type, "Form Data", "WWW_FORM")) {
|
} else if (StringUtils.equalsAny(type, "Form Data", "WWW_FORM")) {
|
||||||
if (bodyObj.containsKey("kvs")) {
|
if (bodyObj.containsKey("kvs")) {
|
||||||
JSONArray bodyParamArr = new JSONArray();
|
JSONArray bodyParamArr = new JSONArray();
|
||||||
|
|
|
@ -328,24 +328,7 @@ public class MockConfigService {
|
||||||
if (bodyObj.containsKey("jsonSchema") && bodyObj.getJSONObject("jsonSchema").containsKey("properties")) {
|
if (bodyObj.containsKey("jsonSchema") && bodyObj.getJSONObject("jsonSchema").containsKey("properties")) {
|
||||||
String bodyRetunStr = bodyObj.getJSONObject("jsonSchema").getJSONObject("properties").toJSONString();
|
String bodyRetunStr = bodyObj.getJSONObject("jsonSchema").getJSONObject("properties").toJSONString();
|
||||||
JSONObject bodyReturnObj = JSONObject.parseObject(bodyRetunStr);
|
JSONObject bodyReturnObj = JSONObject.parseObject(bodyRetunStr);
|
||||||
Set<String> keySet = bodyReturnObj.keySet();
|
JSONObject returnObj = this.parseJsonSchema(bodyReturnObj);
|
||||||
JSONObject returnObj = new JSONObject();
|
|
||||||
for (String key : keySet) {
|
|
||||||
try {
|
|
||||||
JsonSchemaReturnObj obj = bodyReturnObj.getObject(key, JsonSchemaReturnObj.class);
|
|
||||||
String values = obj.getMockValue();
|
|
||||||
if (StringUtils.isEmpty(values)) {
|
|
||||||
values = "";
|
|
||||||
} else {
|
|
||||||
try {
|
|
||||||
values = values.startsWith("@") ? ScriptEngineUtils.calculate(values) : values;
|
|
||||||
} catch (Exception e) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
returnObj.put(key, values);
|
|
||||||
} catch (Exception e) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
returnStr = returnObj.toJSONString();
|
returnStr = returnObj.toJSONString();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -422,6 +405,79 @@ public class MockConfigService {
|
||||||
return returnStr;
|
return returnStr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private JSONObject parseJsonSchema(JSONObject bodyReturnObj) {
|
||||||
|
JSONObject returnObj = new JSONObject();
|
||||||
|
if(bodyReturnObj == null){
|
||||||
|
return returnObj;
|
||||||
|
}
|
||||||
|
|
||||||
|
Set<String> keySet = bodyReturnObj.keySet();
|
||||||
|
for (String key : keySet) {
|
||||||
|
try {
|
||||||
|
JsonSchemaReturnObj obj = bodyReturnObj.getObject(key, JsonSchemaReturnObj.class);
|
||||||
|
if(StringUtils.equals("object",obj.getType())) {
|
||||||
|
JSONObject itemObj = this.parseJsonSchema(obj.getProperties());
|
||||||
|
if (!itemObj.isEmpty()) {
|
||||||
|
returnObj.put(key, itemObj);
|
||||||
|
}
|
||||||
|
}else if(StringUtils.equals("array",obj.getType())){
|
||||||
|
if(obj.getItems() != null){
|
||||||
|
JSONObject itemObj = obj.getItems();
|
||||||
|
if(itemObj.containsKey("type")){
|
||||||
|
if(StringUtils.equals("object",itemObj.getString("type"))&& itemObj.containsKey("properties")){
|
||||||
|
JSONObject arrayObj = itemObj.getJSONObject("properties");
|
||||||
|
// Set<String> arrayKeys = arrayObj.keySet();
|
||||||
|
//
|
||||||
|
// JSONObject parseObj = new JSONObject();
|
||||||
|
// for (String arrayKey : arrayKeys) {
|
||||||
|
// JsonSchemaReturnObj arrayItemObj = arrayObj.getObject(arrayKey, JsonSchemaReturnObj.class);
|
||||||
|
// String value = this.getMockValues(arrayItemObj.getMockValue());
|
||||||
|
// parseObj.put(arrayKey,value);
|
||||||
|
// }
|
||||||
|
JSONObject parseObj = this.parseJsonSchema(arrayObj);
|
||||||
|
JSONArray array = new JSONArray();
|
||||||
|
array.add(parseObj);
|
||||||
|
returnObj.put(key, array);
|
||||||
|
}else if(StringUtils.equals("string",itemObj.getString("type"))&& itemObj.containsKey("mock")){
|
||||||
|
JsonSchemaReturnObj arrayObj = JSONObject.toJavaObject(itemObj,JsonSchemaReturnObj.class);
|
||||||
|
String value = this.getMockValues(arrayObj.getMockValue());
|
||||||
|
JSONArray array = new JSONArray();
|
||||||
|
array.add(value);
|
||||||
|
returnObj.put(key, array);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}else {
|
||||||
|
String values = obj.getMockValue();
|
||||||
|
if (StringUtils.isEmpty(values)) {
|
||||||
|
values = "";
|
||||||
|
} else {
|
||||||
|
try {
|
||||||
|
values = values.startsWith("@") ? ScriptEngineUtils.calculate(values) : values;
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
returnObj.put(key, values);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return returnObj;
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getMockValues(String values) {
|
||||||
|
if (StringUtils.isEmpty(values)) {
|
||||||
|
values = "";
|
||||||
|
} else {
|
||||||
|
try {
|
||||||
|
values = values.startsWith("@") ? ScriptEngineUtils.calculate(values) : values;
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return values;
|
||||||
|
}
|
||||||
|
|
||||||
public MockExpectConfigWithBLOBs findMockExpectConfigById(String id) {
|
public MockExpectConfigWithBLOBs findMockExpectConfigById(String id) {
|
||||||
return mockExpectConfigMapper.selectByPrimaryKey(id);
|
return mockExpectConfigMapper.selectByPrimaryKey(id);
|
||||||
}
|
}
|
||||||
|
|
|
@ -104,7 +104,7 @@
|
||||||
</div>
|
</div>
|
||||||
<div v-else>
|
<div v-else>
|
||||||
<el-table border :show-header="false"
|
<el-table border :show-header="false"
|
||||||
:data="getJsonArr(apiInfo.requestHead)" row-key="name" class="test-content document-table">
|
:data="getJsonArr(apiInfo.requestHead)" class="test-content document-table">
|
||||||
<el-table-column prop="name"
|
<el-table-column prop="name"
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
show-overflow-tooltip/>
|
show-overflow-tooltip/>
|
||||||
|
@ -126,7 +126,7 @@
|
||||||
</div>
|
</div>
|
||||||
<div v-else>
|
<div v-else>
|
||||||
<el-table border
|
<el-table border
|
||||||
:data="getJsonArr(apiInfo.urlParams)" row-key="name" class="test-content document-table">
|
:data="getJsonArr(apiInfo.urlParams)" class="test-content document-table">
|
||||||
<el-table-column prop="name"
|
<el-table-column prop="name"
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
min-width="120px"
|
min-width="120px"
|
||||||
|
@ -157,7 +157,7 @@
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<el-table border v-if="formParamTypes.includes(apiInfo.requestBodyParamType)"
|
<el-table border v-if="formParamTypes.includes(apiInfo.requestBodyParamType)"
|
||||||
:data="getJsonArr(apiInfo.requestBodyFormData)" row-key="name"
|
:data="getJsonArr(apiInfo.requestBodyFormData)"
|
||||||
class="test-content document-table">
|
class="test-content document-table">
|
||||||
<el-table-column prop="name"
|
<el-table-column prop="name"
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
@ -224,7 +224,7 @@
|
||||||
<div class="blackFontClass">
|
<div class="blackFontClass">
|
||||||
{{ $t('api_test.definition.document.response_head') }}:
|
{{ $t('api_test.definition.document.response_head') }}:
|
||||||
<el-table border :show-header="false"
|
<el-table border :show-header="false"
|
||||||
:data="getJsonArr(apiInfo.responseHead)" row-key="name" class="test-content document-table">
|
:data="getJsonArr(apiInfo.responseHead)" class="test-content document-table">
|
||||||
<el-table-column prop="name"
|
<el-table-column prop="name"
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
show-overflow-tooltip/>
|
show-overflow-tooltip/>
|
||||||
|
@ -244,7 +244,7 @@
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<el-table border v-if="formParamTypes.includes(apiInfo.responseBodyParamType)"
|
<el-table border v-if="formParamTypes.includes(apiInfo.responseBodyParamType)"
|
||||||
:data="getJsonArr(apiInfo.responseBodyFormData)" row-key="id"
|
:data="getJsonArr(apiInfo.responseBodyFormData)"
|
||||||
class="test-content document-table">
|
class="test-content document-table">
|
||||||
<el-table-column prop="name"
|
<el-table-column prop="name"
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
@ -268,6 +268,9 @@
|
||||||
min-width="120px"
|
min-width="120px"
|
||||||
show-overflow-tooltip/>
|
show-overflow-tooltip/>
|
||||||
</el-table>
|
</el-table>
|
||||||
|
<div v-else-if="apiInfo.responseBodyParamType == 'JSON-SCHEMA'" style="margin-left: 10px">
|
||||||
|
<ms-json-code-edit :body="apiInfo.jsonSchemaResponseBody" ref="jsonCodeEdit"/>
|
||||||
|
</div>
|
||||||
<div v-else class="showDataDiv">
|
<div v-else class="showDataDiv">
|
||||||
<br/>
|
<br/>
|
||||||
<p style="margin: 0px 20px;"
|
<p style="margin: 0px 20px;"
|
||||||
|
@ -282,7 +285,7 @@
|
||||||
<div class="blackFontClass">
|
<div class="blackFontClass">
|
||||||
{{ $t('api_test.definition.document.response_code') }}:
|
{{ $t('api_test.definition.document.response_code') }}:
|
||||||
<el-table border :show-header="false"
|
<el-table border :show-header="false"
|
||||||
:data="getJsonArr(apiInfo.responseCode)" row-key="name" class="test-content document-table">
|
:data="getJsonArr(apiInfo.responseCode)" class="test-content document-table">
|
||||||
<el-table-column prop="name"
|
<el-table-column prop="name"
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
show-overflow-tooltip/>
|
show-overflow-tooltip/>
|
||||||
|
@ -358,6 +361,7 @@ export default {
|
||||||
requestBodyStrutureData: "",
|
requestBodyStrutureData: "",
|
||||||
sharePopoverVisible:false,
|
sharePopoverVisible:false,
|
||||||
jsonSchemaBody: {},
|
jsonSchemaBody: {},
|
||||||
|
JsonSchemaResponseBody:{},
|
||||||
responseHead: "无",
|
responseHead: "无",
|
||||||
responseBody: "",
|
responseBody: "",
|
||||||
responseBodyParamType: "无",
|
responseBodyParamType: "无",
|
||||||
|
@ -427,7 +431,7 @@ export default {
|
||||||
},
|
},
|
||||||
trashEnable() {
|
trashEnable() {
|
||||||
this.initApiDocSimpleList();
|
this.initApiDocSimpleList();
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
formatRowData(dataType, data) {
|
formatRowData(dataType, data) {
|
||||||
|
@ -660,7 +664,10 @@ export default {
|
||||||
handleScroll(){
|
handleScroll(){
|
||||||
if(!this.clickStepFlag){
|
if(!this.clickStepFlag){
|
||||||
//apiDocInfoDiv的总高度,是(每个item的高度+20)数量
|
//apiDocInfoDiv的总高度,是(每个item的高度+20)数量
|
||||||
let apiDocDivScrollTop = this.$refs.apiDocInfoDiv.scrollTop;
|
let apiDocDivScrollTop = 0;
|
||||||
|
if(this.$refs.apiDocInfoDiv&&this.$refs.apiDocInfoDiv.scrollTop){
|
||||||
|
apiDocDivScrollTop = this.$refs.apiDocInfoDiv.scrollTop;
|
||||||
|
}
|
||||||
let apiDocDivClientTop = this.$refs.apiDocInfoDiv.clientHeight;
|
let apiDocDivClientTop = this.$refs.apiDocInfoDiv.clientHeight;
|
||||||
let scrolledHeigh = apiDocDivScrollTop+apiDocDivClientTop;
|
let scrolledHeigh = apiDocDivScrollTop+apiDocDivClientTop;
|
||||||
let lastIndex = 0;
|
let lastIndex = 0;
|
||||||
|
@ -737,7 +744,9 @@ export default {
|
||||||
}else{
|
}else{
|
||||||
this.apiShowArray.shift();
|
this.apiShowArray.shift();
|
||||||
let itemHeight = this.$refs.apiDocInfoDivItem[0].offsetHeight+10;
|
let itemHeight = this.$refs.apiDocInfoDivItem[0].offsetHeight+10;
|
||||||
this.$refs.apiDocInfoDiv.scrollTop = (apiDocDivScrollTop-itemHeight);
|
if(this.$refs.apiDocInfoDiv&&this.$refs.apiDocInfoDiv.scrollTop){
|
||||||
|
this.$refs.apiDocInfoDiv.scrollTop = (apiDocDivScrollTop-itemHeight);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
this.apiStepIndex ++;
|
this.apiStepIndex ++;
|
||||||
}
|
}
|
||||||
|
@ -756,7 +765,9 @@ export default {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.clickStepFlag = true;
|
this.clickStepFlag = true;
|
||||||
this.$refs.apiDocInfoDiv.scrollTop = (apiDocDivClientTop+itemHeightCount);
|
if(this.$refs.apiDocInfoDiv&&this.$refs.apiDocInfoDiv.scrollTop){
|
||||||
|
this.$refs.apiDocInfoDiv.scrollTop = (apiDocDivClientTop+itemHeightCount);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
//检查要展示的api信息节点,和上下个2个及以内的范围内数据有没有查询过。并赋值为showArray
|
//检查要展示的api信息节点,和上下个2个及以内的范围内数据有没有查询过。并赋值为showArray
|
||||||
|
|
Loading…
Reference in New Issue