Commit 9f8c58b2 authored by Stephane Nicoll's avatar Stephane Nicoll

Merge pull request #25532 from katielevy1

* pr/25532:
  Polish contribution
  Polish KotlinConstructorParametersBinderTests

Closes gh-25532
parents e1ad2cda bac10164
/* /*
* Copyright 2012-2019 the original author or authors. * Copyright 2012-2021 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
...@@ -46,6 +46,10 @@ public class MockConfigurationPropertySource implements IterableConfigurationPro ...@@ -46,6 +46,10 @@ public class MockConfigurationPropertySource implements IterableConfigurationPro
OriginTrackedValue.of(value, MockOrigin.of(origin))); OriginTrackedValue.of(value, MockOrigin.of(origin)));
} }
public MockConfigurationPropertySource(Map<String, String> configs) {
configs.forEach(this::put);
}
public void put(String name, String value) { public void put(String name, String value) {
put(ConfigurationPropertyName.of(name), value); put(ConfigurationPropertyName.of(name), value);
} }
......
...@@ -16,12 +16,12 @@ class KotlinConstructorParametersBinderTests { ...@@ -16,12 +16,12 @@ class KotlinConstructorParametersBinderTests {
@Test @Test
fun `Bind to class should create bound bean`() { fun `Bind to class should create bound bean`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource(mapOf("foo.int-value" to "12",
source.put("foo.int-value", "12") "foo.int-value" to "12",
source.put("foo.long-value", "34") "foo.long-value" to "34",
source.put("foo.boolean-value", "true") "foo.boolean-value" to "true",
source.put("foo.string-value", "foo") "foo.string-value" to "foo",
source.put("foo.enum-value", "foo-bar") "foo.enum-value" to "foo-bar"))
val binder = Binder(source) val binder = Binder(source)
val bean = binder.bind("foo", Bindable.of(ExampleValueBean::class.java)).get() val bean = binder.bind("foo", Bindable.of(ExampleValueBean::class.java)).get()
assertThat(bean.intValue).isEqualTo(12) assertThat(bean.intValue).isEqualTo(12)
...@@ -33,12 +33,11 @@ class KotlinConstructorParametersBinderTests { ...@@ -33,12 +33,11 @@ class KotlinConstructorParametersBinderTests {
@Test @Test
fun `Bind to class when has no prefix should create bound bean`() { fun `Bind to class when has no prefix should create bound bean`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource(mapOf("int-value" to "12",
source.put("int-value", "12") "long-value" to "34",
source.put("long-value", "34") "boolean-value" to "true",
source.put("boolean-value", "true") "string-value" to "foo",
source.put("string-value", "foo") "enum-value" to "foo-bar"))
source.put("enum-value", "foo-bar")
val binder = Binder(source) val binder = Binder(source)
val bean = binder.bind(ConfigurationPropertyName.of(""), val bean = binder.bind(ConfigurationPropertyName.of(""),
Bindable.of(ExampleValueBean::class.java)).get() Bindable.of(ExampleValueBean::class.java)).get()
...@@ -51,25 +50,24 @@ class KotlinConstructorParametersBinderTests { ...@@ -51,25 +50,24 @@ class KotlinConstructorParametersBinderTests {
@Test @Test
fun `Bind to data class should create bound bean`() { fun `Bind to data class should create bound bean`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource(mapOf("foo.int-value" to "12",
source.put("foo.int-value", "12") "foo.long-value" to "34",
source.put("foo.long-value", "34") "foo.boolean-value" to "true",
source.put("foo.boolean-value", "true") "foo.string-value" to "foo",
source.put("foo.string-value", "foo") "foo.enum-value" to "foo-bar"))
source.put("foo.enum-value", "foo-bar")
val binder = Binder(source) val binder = Binder(source)
val bean = binder.bind("foo", Bindable.of(ExampleDataClassBean::class.java)).get() val bean = binder.bind("foo", Bindable.of(ExampleDataClassBean::class.java)).get()
assertThat(bean.intValue).isEqualTo(12) val expectedBean = ExampleDataClassBean(intValue = 12,
assertThat(bean.longValue).isEqualTo(34) longValue = 34,
assertThat(bean.booleanValue).isTrue() booleanValue = true,
assertThat(bean.stringValue).isEqualTo("foo") stringValue = "foo",
assertThat(bean.enumValue).isEqualTo(ExampleEnum.FOO_BAR) enumValue = ExampleEnum.FOO_BAR)
assertThat(bean).isEqualTo(expectedBean)
} }
@Test @Test
fun `Bind to class with multiple constructors and primary constructor should bind`() { fun `Bind to class with multiple constructors and primary constructor should bind`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource("foo.int-value", "12")
source.put("foo.int-value", "12")
val binder = Binder(source) val binder = Binder(source)
val bindable = binder.bind("foo", Bindable.of( val bindable = binder.bind("foo", Bindable.of(
MultipleConstructorsWithPrimaryConstructorBean::class.java)) MultipleConstructorsWithPrimaryConstructorBean::class.java))
...@@ -79,8 +77,7 @@ class KotlinConstructorParametersBinderTests { ...@@ -79,8 +77,7 @@ class KotlinConstructorParametersBinderTests {
@Test @Test
fun `Bind to class with multiple constructors should not bind`() { fun `Bind to class with multiple constructors should not bind`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource("foo.int-value", "12")
source.put("foo.int-value", "12")
val binder = Binder(source) val binder = Binder(source)
val bindable = binder.bind("foo", Bindable.of( val bindable = binder.bind("foo", Bindable.of(
MultipleConstructorsBean::class.java)) MultipleConstructorsBean::class.java))
...@@ -89,8 +86,7 @@ class KotlinConstructorParametersBinderTests { ...@@ -89,8 +86,7 @@ class KotlinConstructorParametersBinderTests {
@Test @Test
fun `Bind to class with only default constructor should not bind`() { fun `Bind to class with only default constructor should not bind`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource("foo.int-value", "12")
source.put("foo.int-value", "12")
val binder = Binder(source) val binder = Binder(source)
val bindable = binder.bind("foo", Bindable.of( val bindable = binder.bind("foo", Bindable.of(
DefaultConstructorBean::class.java)) DefaultConstructorBean::class.java))
...@@ -99,11 +95,10 @@ class KotlinConstructorParametersBinderTests { ...@@ -99,11 +95,10 @@ class KotlinConstructorParametersBinderTests {
@Test @Test
fun `Bind to class should bind nested`() { fun `Bind to class should bind nested`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource(mapOf("foo.value-bean.int-value" to "123",
source.put("foo.value-bean.int-value", "123") "foo.value-bean.long-value" to "34",
source.put("foo.value-bean.long-value", "34") "foo.value-bean.boolean-value" to "true",
source.put("foo.value-bean.boolean-value", "true") "foo.value-bean.string-value" to "foo"))
source.put("foo.value-bean.string-value", "foo")
val binder = Binder(source) val binder = Binder(source)
val bean = binder.bind("foo", Bindable.of(ExampleNestedBean::class.java)).get() val bean = binder.bind("foo", Bindable.of(ExampleNestedBean::class.java)).get()
assertThat(bean.valueBean.intValue).isEqualTo(123) assertThat(bean.valueBean.intValue).isEqualTo(123)
...@@ -115,8 +110,7 @@ class KotlinConstructorParametersBinderTests { ...@@ -115,8 +110,7 @@ class KotlinConstructorParametersBinderTests {
@Test @Test
fun `Bind to class with no value for optional should use null`() { fun `Bind to class with no value for optional should use null`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource("foo.string-value", "foo")
source.put("foo.string-value", "foo")
val binder = Binder(source) val binder = Binder(source)
val bean = binder.bind("foo", Bindable.of( val bean = binder.bind("foo", Bindable.of(
ExampleValueBean::class.java)).get() ExampleValueBean::class.java)).get()
...@@ -129,8 +123,7 @@ class KotlinConstructorParametersBinderTests { ...@@ -129,8 +123,7 @@ class KotlinConstructorParametersBinderTests {
@Test @Test
fun `Bind to class with no value for primitive should use default value`() { fun `Bind to class with no value for primitive should use default value`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource("foo.string-value", "foo")
source.put("foo.string-value", "foo")
val binder = Binder(source) val binder = Binder(source)
val bean = binder.bind("foo", Bindable.of( val bean = binder.bind("foo", Bindable.of(
ExamplePrimitiveDefaultBean::class.java)).get() ExamplePrimitiveDefaultBean::class.java)).get()
...@@ -143,17 +136,15 @@ class KotlinConstructorParametersBinderTests { ...@@ -143,17 +136,15 @@ class KotlinConstructorParametersBinderTests {
@Test @Test
fun `Bind to class with no value and default value should return unbound`() { fun `Bind to class with no value and default value should return unbound`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource("foo.string-value", "foo")
source.put("foo.string-value", "foo")
val binder = Binder(source) val binder = Binder(source)
assertThat(binder.bind("foo", Bindable.of( assertThat(binder.bind("foo", Bindable.of(
ExampleDefaultValueBean::class.java)).isBound()).isFalse(); ExampleDefaultValueBean::class.java)).isBound).isFalse()
} }
@Test @Test
fun `Bind or create to class with no value and default value should return default value`() { fun `Bind or create to class with no value and default value should return default value`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource("foo.string-value", "foo")
source.put("foo.string-value", "foo")
val binder = Binder(source) val binder = Binder(source)
val bean = binder.bindOrCreate("foo", Bindable.of( val bean = binder.bindOrCreate("foo", Bindable.of(
ExampleDefaultValueBean::class.java)) ExampleDefaultValueBean::class.java))
...@@ -164,39 +155,45 @@ class KotlinConstructorParametersBinderTests { ...@@ -164,39 +155,45 @@ class KotlinConstructorParametersBinderTests {
@Test @Test
fun `Bind to data class with no value should use default value`() { fun `Bind to data class with no value should use default value`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource("foo.enum-value", "foo-bar")
source.put("foo.enum-value", "foo-bar")
val binder = Binder(source) val binder = Binder(source)
val bean = binder.bind("foo", Bindable.of(ExampleDataClassBean::class.java)).get() val bean = binder.bind("foo", Bindable.of(ExampleDataClassBean::class.java)).get()
assertThat(bean.intValue).isEqualTo(5) val expectedBean = ExampleDataClassBean(intValue = 5,
assertThat(bean.longValue).isEqualTo(42) longValue = 42,
assertThat(bean.booleanValue).isFalse() booleanValue = false,
assertThat(bean.stringValue).isEqualTo("my data") stringValue = "my data",
assertThat(bean.enumValue).isEqualTo(ExampleEnum.FOO_BAR) enumValue = ExampleEnum.FOO_BAR)
assertThat(bean).isEqualTo(expectedBean)
} }
@Test @Test
fun `Bind to data class with generics`() { fun `Bind to data class with generics`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource("foo.value.bar", "baz")
source.put("foo.value.bar", "baz")
val binder = Binder(source) val binder = Binder(source)
val type = ResolvableType.forClassWithGenerics(Map::class.java, String::class.java, val type = ResolvableType.forClassWithGenerics(Map::class.java, String::class.java,
String::class.java) String::class.java)
val bean = binder.bind("foo", Bindable val bean = binder.bind("foo", Bindable
.of<GenericValue<Map<String, String>>>(ResolvableType.forClassWithGenerics(GenericValue::class.java, type))) .of<GenericValue<Map<String, String>>>(ResolvableType.forClassWithGenerics(GenericValue::class.java, type)))
.get() .get()
assertThat(bean.value.get("bar")).isEqualTo("baz"); assertThat(bean.value["bar"]).isEqualTo("baz")
} }
@Test @Test
fun `Bind to named constructor parameter`() { fun `Bind to named constructor parameter`() {
val source = MockConfigurationPropertySource() val source = MockConfigurationPropertySource("foo.string-value", "test")
source.put("foo.string-value", "test")
val binder = Binder(source) val binder = Binder(source)
val bean = binder.bind("foo", Bindable.of(ExampleNamedParameterBean::class.java)).get() val bean = binder.bind("foo", Bindable.of(ExampleNamedParameterBean::class.java)).get()
assertThat(bean.stringDataValue).isEqualTo("test") assertThat(bean.stringDataValue).isEqualTo("test")
} }
@Test
fun `Bind to singleton object`() {
val source = MockConfigurationPropertySource("foo.string-value", "test")
val binder = Binder(source)
val bean = binder.bind("foo", Bindable.of(ExampleSingletonBean::class.java)).get()
assertThat(bean.stringValue).isEqualTo("test")
}
class ExampleValueBean(val intValue: Int?, val longValue: Long?, class ExampleValueBean(val intValue: Int?, val longValue: Long?,
val booleanValue: Boolean?, val stringValue: String?, val booleanValue: Boolean?, val stringValue: String?,
val enumValue: ExampleEnum?) val enumValue: ExampleEnum?)
...@@ -244,4 +241,8 @@ class KotlinConstructorParametersBinderTests { ...@@ -244,4 +241,8 @@ class KotlinConstructorParametersBinderTests {
val value: T val value: T
) )
object ExampleSingletonBean {
var stringValue: String? = null
}
} }
\ No newline at end of file
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