Make the Kotlin bean registration API even more idiomatic
Put the lambda parameter at the end and use a function
instead of a supplier to be able to register beans like this:
val context = GenericApplicationContext()
context.registerBean(Foo::class)
context.registerBean{ Bar(it.getBean(Foo::class)) }
Issue: SPR-15118
This commit is contained in:
parent
715274e327
commit
c5cfd8c8fc
|
|
@ -34,15 +34,15 @@ object GenericApplicationContextExtension {
|
|||
* @see GenericApplicationContext.registerBean(Class<T>, Supplier<T>, BeanDefinitionCustomizer...)
|
||||
*/
|
||||
inline fun <reified T : Any> GenericApplicationContext.registerBean(
|
||||
crossinline supplier: () -> T, vararg customizers: BeanDefinitionCustomizer) {
|
||||
registerBean(T::class.java, Supplier { supplier.invoke() }, *customizers)
|
||||
vararg customizers: BeanDefinitionCustomizer, crossinline function: (GenericApplicationContext) -> T) {
|
||||
registerBean(T::class.java, Supplier { function.invoke(this) }, *customizers)
|
||||
}
|
||||
|
||||
/**
|
||||
* @see GenericApplicationContext.registerBean(String, Class<T>, Supplier<T>, BeanDefinitionCustomizer...)
|
||||
*/
|
||||
inline fun <reified T : Any> GenericApplicationContext.registerBean(name: String,
|
||||
crossinline supplier: () -> T, vararg customizers: BeanDefinitionCustomizer) {
|
||||
registerBean(name, T::class.java, Supplier { supplier.invoke() }, *customizers)
|
||||
vararg customizers: BeanDefinitionCustomizer, crossinline function: (GenericApplicationContext) -> T) {
|
||||
registerBean(name, T::class.java, Supplier { function.invoke(this) }, *customizers)
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -26,7 +26,7 @@ class GenericApplicationContextExtensionTests {
|
|||
@Test
|
||||
fun registerBeanWithSupplier() {
|
||||
val context = GenericApplicationContext()
|
||||
context.registerBean({ BeanA() })
|
||||
context.registerBean { BeanA() }
|
||||
context.refresh()
|
||||
assertNotNull(context.getBean(BeanA::class))
|
||||
}
|
||||
|
|
@ -34,11 +34,33 @@ class GenericApplicationContextExtensionTests {
|
|||
@Test
|
||||
fun registerBeanWithNameAndSupplier() {
|
||||
val context = GenericApplicationContext()
|
||||
context.registerBean("a", { BeanA() })
|
||||
context.registerBean("a") { BeanA() }
|
||||
context.refresh()
|
||||
assertNotNull(context.getBean("a"))
|
||||
}
|
||||
|
||||
@Test
|
||||
fun registerBeanWithFunction() {
|
||||
val context = GenericApplicationContext()
|
||||
context.registerBean(BeanA::class)
|
||||
context.registerBean { BeanB(it.getBean(BeanA::class)) }
|
||||
context.refresh()
|
||||
assertNotNull(context.getBean(BeanA::class))
|
||||
assertNotNull(context.getBean(BeanB::class))
|
||||
}
|
||||
|
||||
@Test
|
||||
fun registerBeanWithNameAndFunction() {
|
||||
val context = GenericApplicationContext()
|
||||
context.registerBean("a", BeanA::class)
|
||||
context.registerBean("b") { BeanB(it.getBean(BeanA::class)) }
|
||||
context.refresh()
|
||||
assertNotNull(context.getBean("a"))
|
||||
assertNotNull(context.getBean("b"))
|
||||
}
|
||||
|
||||
internal class BeanA
|
||||
|
||||
internal class BeanB(val a: BeanA)
|
||||
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue