问题描述
我在使用 Spring Docs 记录可选响应字段时遇到问题。
我的测试代码:
mockmvc.perform(get("/foo").accept(MediaType.APPLICATION_JSON))
.andExpect(status().isOk())
.andDo(document("foo",responseFields(
fieldWithPath("success").description("Indicates request successful or not."),fieldWithPath("message").description("Message.").optional()
)));
我的回答:
{
"success" : true
}
错误:
org.springframework.restdocs.payload.FieldTyperequiredException: 无法确定字段“消息”的类型,因为它不存在 在有效载荷中。请提供类型使用 FieldDescriptor.type(对象类型)。
Spring REST Docs 文档说明 (https://docs.spring.io/spring-restdocs/docs/2.0.5.RELEASE/reference/html5/#documenting-your-api-request-response-payloads-fields)
那我做错了什么?
解决方法
虽然 df.select(df.url,F.explode(F.from_json(df.json,"array<string>")))
.select("url",F.from_json((F.col("col")),"array<string>").alias("col"))
.select("url",F.col("col").getItem(0),F.col("col").getItem(1))
.show(truncate=False)
+-------------+-------------+------+
|url |col[0] |col[1]|
+-------------+-------------+------+
|https://url.a|1572393600000|1.0 |
|https://url.a|1572480000000|1.007 |
|https://url.b|1572825600000|1.002 |
|https://url.b|1572912000000|1.0 |
+-------------+-------------+------+
字段被标记为可选,但 REST Docs 仍然希望为您记录它。该文档的一部分是字段的类型。响应中缺少该字段,因此 REST Docs 无法自动猜测它。相反,您需要使用 message
方法告诉它:
type