Commit 6729e56f authored by Andy Wilkinson's avatar Andy Wilkinson

Merge branch '2.0.x'

parents ac77fc9d e74b084c
...@@ -189,6 +189,11 @@ ...@@ -189,6 +189,11 @@
<artifactId>logback-classic</artifactId> <artifactId>logback-classic</artifactId>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency>
<groupId>com.fasterxml.jackson.module</groupId>
<artifactId>jackson-module-parameter-names</artifactId>
<scope>test</scope>
</dependency>
<dependency> <dependency>
<groupId>com.h2database</groupId> <groupId>com.h2database</groupId>
<artifactId>h2</artifactId> <artifactId>h2</artifactId>
......
...@@ -30,6 +30,7 @@ import org.springframework.boot.autoconfigure.SpringBootApplication; ...@@ -30,6 +30,7 @@ import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.test.autoconfigure.OverrideAutoConfiguration; import org.springframework.boot.test.autoconfigure.OverrideAutoConfiguration;
import org.springframework.boot.test.autoconfigure.core.AutoConfigureCache; import org.springframework.boot.test.autoconfigure.core.AutoConfigureCache;
import org.springframework.boot.test.autoconfigure.filter.TypeExcludeFilters; import org.springframework.boot.test.autoconfigure.filter.TypeExcludeFilters;
import org.springframework.boot.test.autoconfigure.json.AutoConfigureJson;
import org.springframework.boot.test.context.SpringBootTest; import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.boot.test.mock.mockito.MockBean; import org.springframework.boot.test.mock.mockito.MockBean;
import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.ComponentScan;
...@@ -79,6 +80,7 @@ import org.springframework.test.web.reactive.server.WebTestClient; ...@@ -79,6 +80,7 @@ import org.springframework.test.web.reactive.server.WebTestClient;
@OverrideAutoConfiguration(enabled = false) @OverrideAutoConfiguration(enabled = false)
@TypeExcludeFilters(WebFluxTypeExcludeFilter.class) @TypeExcludeFilters(WebFluxTypeExcludeFilter.class)
@AutoConfigureCache @AutoConfigureCache
@AutoConfigureJson
@AutoConfigureWebFlux @AutoConfigureWebFlux
@AutoConfigureWebTestClient @AutoConfigureWebTestClient
@ImportAutoConfiguration @ImportAutoConfiguration
......
...@@ -94,6 +94,7 @@ org.springframework.boot.test.autoconfigure.web.reactive.WebTestClientAutoConfig ...@@ -94,6 +94,7 @@ org.springframework.boot.test.autoconfigure.web.reactive.WebTestClientAutoConfig
# AutoConfigureWebFlux auto-configuration imports # AutoConfigureWebFlux auto-configuration imports
org.springframework.boot.test.autoconfigure.web.reactive.AutoConfigureWebFlux=\ org.springframework.boot.test.autoconfigure.web.reactive.AutoConfigureWebFlux=\
org.springframework.boot.autoconfigure.http.codec.CodecsAutoConfiguration,\
org.springframework.boot.autoconfigure.context.MessageSourceAutoConfiguration,\ org.springframework.boot.autoconfigure.context.MessageSourceAutoConfiguration,\
org.springframework.boot.autoconfigure.validation.ValidationAutoConfiguration,\ org.springframework.boot.autoconfigure.validation.ValidationAutoConfiguration,\
org.springframework.boot.autoconfigure.web.reactive.WebFluxAutoConfiguration org.springframework.boot.autoconfigure.web.reactive.WebFluxAutoConfiguration
......
/*
* 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.web.reactive.webclient;
import org.springframework.boot.test.autoconfigure.web.reactive.WebFluxTest;
/**
* Example POJO used with {@link WebFluxTest} tests.
*
* @author Andy Wilkinson
*/
public class ExamplePojo {
private final String alpha;
private final String bravo;
public ExamplePojo(String alpha, String bravo) {
this.alpha = alpha;
this.bravo = bravo;
}
public String getAlpha() {
return this.alpha;
}
public String getBravo() {
return this.bravo;
}
}
/*
* Copyright 2012-2017 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.web.reactive.webclient;
import reactor.core.publisher.Mono;
import org.springframework.boot.test.autoconfigure.web.reactive.WebFluxTest;
import org.springframework.http.MediaType;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* Example {@link Controller} used with {@link WebFluxTest} tests.
*
* @author Andy Wilkinson
*/
@RestController
public class JsonController {
@GetMapping(value = "/json", produces = MediaType.APPLICATION_JSON_VALUE)
public Mono<ExamplePojo> json() {
return Mono.just(new ExamplePojo("a", "b"));
}
}
...@@ -55,4 +55,9 @@ public class WebFluxTestAllControllersIntegrationTests { ...@@ -55,4 +55,9 @@ public class WebFluxTestAllControllersIntegrationTests {
this.webClient.get().uri("/one/error").exchange().expectStatus().isBadRequest(); this.webClient.get().uri("/one/error").exchange().expectStatus().isBadRequest();
} }
@Test
public void shouldFindJsonController() {
this.webClient.get().uri("/json").exchange().expectStatus().isOk();
}
} }
...@@ -25,6 +25,7 @@ import org.springframework.boot.autoconfigure.validation.ValidationAutoConfigura ...@@ -25,6 +25,7 @@ import org.springframework.boot.autoconfigure.validation.ValidationAutoConfigura
import org.springframework.boot.test.autoconfigure.web.reactive.WebFluxTest; import org.springframework.boot.test.autoconfigure.web.reactive.WebFluxTest;
import org.springframework.context.ApplicationContext; import org.springframework.context.ApplicationContext;
import org.springframework.test.context.junit4.SpringRunner; import org.springframework.test.context.junit4.SpringRunner;
import org.springframework.test.web.reactive.server.WebTestClient;
import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThat;
import static org.springframework.boot.test.autoconfigure.AutoConfigurationImportedCondition.importedAutoConfiguration; import static org.springframework.boot.test.autoconfigure.AutoConfigurationImportedCondition.importedAutoConfiguration;
...@@ -53,4 +54,11 @@ public class WebFluxTestAutoConfigurationIntegrationTests { ...@@ -53,4 +54,11 @@ public class WebFluxTestAutoConfigurationIntegrationTests {
.has(importedAutoConfiguration(ValidationAutoConfiguration.class)); .has(importedAutoConfiguration(ValidationAutoConfiguration.class));
} }
@Test
public void whatever() {
WebTestClient client = this.applicationContext.getBean(WebTestClient.class);
System.out.println(client);
}
} }
/*
* 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.web.reactive.webclient;
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.security.test.context.support.WithMockUser;
import org.springframework.test.context.junit4.SpringRunner;
import org.springframework.test.web.reactive.server.WebTestClient;
/**
* Tests for {@link WebFluxTest} to validate the {@link WebTestClient WebTestClient's}
* codecs are customized.
*
* @author Andy Wilkinson
*/
@RunWith(SpringRunner.class)
@WithMockUser
@WebFluxTest(controllers = JsonController.class)
public class WebFluxTestWebTestClientCodecCustomizationIntegrationTests {
@Autowired
private WebTestClient webClient;
@Test
public void shouldBeAbleToCreatePojoViaParametersModule() {
this.webClient.get().uri("/json").exchange().expectStatus().isOk()
.expectBody(ExamplePojo.class);
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment