From 7d08e84f97ea26daaf8475eecbb7ff2c17e7acec Mon Sep 17 00:00:00 2001 From: guoyuqi Date: Tue, 29 Nov 2022 13:57:03 +0800 Subject: [PATCH] =?UTF-8?q?fix(=E6=8E=A5=E5=8F=A3=E6=B5=8B=E8=AF=95):=20?= =?UTF-8?q?=E4=BF=AE=E5=A4=8Dswagger=E6=96=87=E4=BB=B6=E5=AF=BC=E5=85=A5qu?= =?UTF-8?q?ery=E5=8F=82=E6=95=B0=E9=BB=98=E8=AE=A4=E5=80=BC=E5=AF=BC?= =?UTF-8?q?=E5=85=A5=E5=A4=B1=E8=B4=A5=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --user=郭雨琦 https://www.tapd.cn/55049933/bugtrace/bugs/view/1155049933001020352 --- .../request/variable/JsonSchemaItem.java | 2 + .../api/dto/scenario/KeyValue.java | 8 +++ .../api/parse/api/Swagger3Parser.java | 49 ++++++++++++++++--- 3 files changed, 52 insertions(+), 7 deletions(-) diff --git a/api-test/backend/src/main/java/io/metersphere/api/dto/definition/request/variable/JsonSchemaItem.java b/api-test/backend/src/main/java/io/metersphere/api/dto/definition/request/variable/JsonSchemaItem.java index 3e3712197c..1e52a257c0 100644 --- a/api-test/backend/src/main/java/io/metersphere/api/dto/definition/request/variable/JsonSchemaItem.java +++ b/api-test/backend/src/main/java/io/metersphere/api/dto/definition/request/variable/JsonSchemaItem.java @@ -28,6 +28,8 @@ public class JsonSchemaItem { private BigDecimal minimum; private BigDecimal maximum; private String schema; + protected Object defaultValue; + public JsonSchemaItem() { this.mock = new LinkedHashMap<>(); diff --git a/api-test/backend/src/main/java/io/metersphere/api/dto/scenario/KeyValue.java b/api-test/backend/src/main/java/io/metersphere/api/dto/scenario/KeyValue.java index b81862c043..c096c2267f 100644 --- a/api-test/backend/src/main/java/io/metersphere/api/dto/scenario/KeyValue.java +++ b/api-test/backend/src/main/java/io/metersphere/api/dto/scenario/KeyValue.java @@ -41,6 +41,14 @@ public class KeyValue { this.enable = enable; } + public KeyValue(String name, String value, String description, boolean required, Integer min, Integer max) { + this.name = name; + this.value = value; + this.description = description; + this.required = required; + this.min = min; + this.max = max; + } public KeyValue(String name, String value, String description, String contentType) { this(name, value, description, contentType, true); } diff --git a/api-test/backend/src/main/java/io/metersphere/api/parse/api/Swagger3Parser.java b/api-test/backend/src/main/java/io/metersphere/api/parse/api/Swagger3Parser.java index 49ab47752d..3134c70b10 100644 --- a/api-test/backend/src/main/java/io/metersphere/api/parse/api/Swagger3Parser.java +++ b/api-test/backend/src/main/java/io/metersphere/api/parse/api/Swagger3Parser.java @@ -328,12 +328,7 @@ public class Swagger3Parser extends SwaggerAbstractParser { Set refSet = new HashSet<>(); Map infoMap = new HashMap(); - Schema schema = mediaType.getSchema(); - if (StringUtils.isBlank(schema.get$ref()) && schema.getItems() == null && StringUtils.isNotBlank(schema.getType()) && StringUtils.equals(schema.getType(), "string")) { - ObjectSchema objectSchema = new ObjectSchema(); - objectSchema.setExample(schema.getExample()); - schema = objectSchema; - } + Schema schema = getSchema(mediaType.getSchema()); Object bodyData = null; if (!StringUtils.equals(contentType, org.springframework.http.MediaType.APPLICATION_JSON_VALUE)) { bodyData = parseSchemaToJson(schema, refSet, infoMap); @@ -535,6 +530,7 @@ public class Swagger3Parser extends SwaggerAbstractParser { item.setMinLength(schema.getMinLength()); item.setMaximum(schema.getMaximum()); item.setMinimum(schema.getMinimum()); + item.setDefaultValue(schema.getDefault()); return item; } @@ -572,7 +568,46 @@ public class Swagger3Parser extends SwaggerAbstractParser { private void parseQueryParameters(Parameter parameter, List arguments) { QueryParameter queryParameter = (QueryParameter) parameter; - arguments.add(new KeyValue(queryParameter.getName(), String.valueOf(queryParameter.getExample()), getDefaultStringValue(queryParameter.getDescription()), parameter.getRequired())); + Schema schema = getSchema(parameter.getSchema()); + Set refSet = new HashSet<>(); + JsonSchemaItem jsonSchemaItem = parseSchema(schema, refSet); + arguments.add(new KeyValue(queryParameter.getName(), getDefaultValue(queryParameter, jsonSchemaItem), getDefaultStringValue(queryParameter.getDescription()), parameter.getRequired(), getMin(jsonSchemaItem), getMax(jsonSchemaItem))); + } + + private Schema getSchema(Schema schema) { + if (StringUtils.isBlank(schema.get$ref()) && StringUtils.isNotBlank(schema.getType()) && StringUtils.equals(schema.getType(),"string")) { + ObjectSchema objectSchema = new ObjectSchema(); + objectSchema.setExample(schema.getExample()); + schema = objectSchema; + } + return schema; + } + + private Integer getMax(JsonSchemaItem jsonSchemaItem) { + if (jsonSchemaItem != null && jsonSchemaItem.getMaxLength() != null) { + return jsonSchemaItem.getMaxLength(); + } else { + return null; + } + } + + private Integer getMin(JsonSchemaItem jsonSchemaItem) { + if (jsonSchemaItem != null && jsonSchemaItem.getMinLength() != null) { + return jsonSchemaItem.getMinLength(); + } else { + return null; + } + } + + private String getDefaultValue(QueryParameter queryParameter, JsonSchemaItem jsonSchemaItem) { + if (queryParameter.getExample() != null) { + return String.valueOf(queryParameter.getExample()); + } else { + if (jsonSchemaItem != null && jsonSchemaItem.getDefaultValue()!=null) { + return String.valueOf(jsonSchemaItem.getDefaultValue()); + } + return null; + } } /* 导出的 swagger json描述文件样例