RestDocs对请求参数进行了双重文档

时间:2016-08-24 13:26:13

标签: spring-boot spring-restdocs

使用RestDocs版本1.1.1.RELEASE和SpringBoot 1.4.0.RELEASE,使用" httpRequest"记录为双倍。

以下代码:

@RunWith(SpringRunner.class)
@WebMvcTest(ProductResource.class)
@AutoConfigureRestDocs("target/generated-snippets")
public class ProductResourceDocumentation {

private static final String PROPERTY_ID_VALUE = "d7612";
private static final String SALES_MARKET_VALUE = "999";
private static final String SEASON_VALUE = "2016";
private static final String SECTIONS_VALUE = "buildings";
private static final String SHOW_DESCRIPTIONS_VALUE = "false";
private static final String STRING = "string";
private static final Integer NUMBER = 1;
private static final String NOT_FOUND = "404 Not Found";
private static final String BAD_REQUEST = "400 Bad Request";

private RestDocumentationResultHandler documentationResultHandler;

@MockBean
private ProductHandler productHandler;

@Autowired
private MockMvc mockMvc;

@Before
public void setup() {
    this.documentationResultHandler = document("{class-name}/{method-name}", preprocessRequest(prettyPrint()), preprocessResponse(prettyPrint()));
}

@Test
public void listProducts() throws Exception {
    Product product = getBasicProductsRepresentation();
    when(productHandler.getProduct(PROPERTY_ID_VALUE, SALES_MARKET_VALUE, SEASON_VALUE, null, null)).thenReturn(product);

    mockMvc.perform(RestDocumentationRequestBuilders.get("/products/{propertyId}", PROPERTY_ID_VALUE)
            .param("salesMarket", SALES_MARKET_VALUE)
            .param("season", SEASON_VALUE))
            .andDo(print())
            .andExpect(status().isOk())
            .andExpect(jsonPath("$.propertyID", is(PROPERTY_ID_VALUE)))
            .andExpect(jsonPath("$.season", is(SEASON_VALUE)))
            .andDo(documentationResultHandler.document(
                    pathParameters(
                            parameterWithName("propertyId").description(PATH_PARAM__PROPERTY_ID)
                    ),
                    requestParameters(
                            parameterWithName("salesMarket").description(REQUEST_PARAM__SALES_MARKET),
                            parameterWithName("season").description(REQUEST_PARAM__SEASON)
                    ),
                    httpRequest(), httpResponse()
            ));
}

制作以下文件(" salesMarket = 999& season = 2016"记录两次):

GET /products/d7612?    salesMarket=999&season=2016&salesMarket=999&season=2016 HTTP/1.1

有没有人经历过类似的事情或者知道问题是什么?

2 个答案:

答案 0 :(得分:0)

a bug已在1.1.2.RELEASE中修复。升级将解决问题。升级时请确保获得spring-restdocs-mockmvcspring-restdocs-core的1.1.2。后一个模块是修复的地方。

答案 1 :(得分:0)

当我们将查询参数(参见下面的块)设置为空字符串(“”)时,我们得到“双重文档”:

GET /Thing/OtherThing/Foo/?thinger=FOO&block=&bla=5&block= HTTP/1.1

我们使用Spring Boot 1.5.2和Spring REST Docs 1.1.2.RELEASE。