Add support for multiple REST Docs configuration customizers
This commit introduces support for multiple configuration customizers for REST Docs with MockMvc, WebTestClient, and REST Assured. Closes gh-13498pull/14056/merge
parent
6ac6d36395
commit
4d310f0d5a
@ -0,0 +1,99 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012-2018 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.boot.test.autoconfigure.restdocs;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
|
import org.assertj.core.api.Condition;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.test.autoconfigure.web.reactive.WebFluxTest;
|
||||||
|
import org.springframework.boot.test.context.TestConfiguration;
|
||||||
|
import org.springframework.restdocs.templates.TemplateFormats;
|
||||||
|
import org.springframework.restdocs.webtestclient.WebTestClientRestDocumentationConfigurer;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
import org.springframework.test.web.reactive.server.WebTestClient;
|
||||||
|
import org.springframework.util.FileSystemUtils;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
import static org.springframework.restdocs.payload.PayloadDocumentation.fieldWithPath;
|
||||||
|
import static org.springframework.restdocs.payload.PayloadDocumentation.responseFields;
|
||||||
|
import static org.springframework.restdocs.webtestclient.WebTestClientRestDocumentation.document;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Integration tests for {@link RestDocsAutoConfiguration} with {@link WebTestClient}.
|
||||||
|
*
|
||||||
|
* @author Eddú Meléndez
|
||||||
|
*/
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
@WebFluxTest
|
||||||
|
@AutoConfigureRestDocs(uriScheme = "https", uriHost = "api.example.com", uriPort = 443)
|
||||||
|
public class WebTestClientRestDocsAutoConfigurationAdvancedConfigurationIntegrationTests {
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void deleteSnippets() {
|
||||||
|
FileSystemUtils.deleteRecursively(new File("target/generated-snippets"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private WebTestClient webTestClient;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void defaultSnippetsAreWritten() throws Exception {
|
||||||
|
this.webTestClient.get().uri("/").exchange().expectBody()
|
||||||
|
.consumeWith(document("default-snippets"));
|
||||||
|
File defaultSnippetsDir = new File("target/generated-snippets/default-snippets");
|
||||||
|
assertThat(defaultSnippetsDir).exists();
|
||||||
|
assertThat(new File(defaultSnippetsDir, "curl-request.md"))
|
||||||
|
.has(contentContaining("'https://api.example.com/'"));
|
||||||
|
assertThat(new File(defaultSnippetsDir, "http-request.md"))
|
||||||
|
.has(contentContaining("api.example.com"));
|
||||||
|
assertThat(new File(defaultSnippetsDir, "http-response.md")).isFile();
|
||||||
|
assertThat(new File(defaultSnippetsDir, "response-fields.md")).isFile();
|
||||||
|
}
|
||||||
|
|
||||||
|
private Condition<File> contentContaining(String toContain) {
|
||||||
|
return new ContentContainingCondition(toContain);
|
||||||
|
}
|
||||||
|
|
||||||
|
@TestConfiguration
|
||||||
|
public static class CustomizationConfiguration
|
||||||
|
implements RestDocsWebTestClientConfigurationCustomizer {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void customize(WebTestClientRestDocumentationConfigurer configurer) {
|
||||||
|
configurer.snippets().withTemplateFormat(TemplateFormats.markdown());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@TestConfiguration
|
||||||
|
public static class CustomizationConfiguration2
|
||||||
|
implements RestDocsWebTestClientConfigurationCustomizer {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void customize(WebTestClientRestDocumentationConfigurer configurer) {
|
||||||
|
configurer.snippets().withAdditionalDefaults(
|
||||||
|
responseFields(fieldWithPath("_links.self").description("Main URL")));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue