This commit adds support for `@Scheduled` annotation on reactive methods and Kotlin suspending functions. Reactive methods are methods that return a `Publisher` or a subclass of `Publisher`. The `ReactiveAdapterRegistry` is used to support many implementations, such as `Flux`, `Mono`, `Flow`, `Single`, etc. Methods should not take any argument and published values will be ignored, as they are already with synchronous support. This is implemented in `ScheduledAnnotationReactiveSupport`, which "converts" Publishers to `Runnable`. This strategy keeps track of active Subscriptions in the `ScheduledAnnotationBeanPostProcessor`, in order to cancel them all in case of shutdown. The existing scheduling support for tasks is reused, aligning the triggering behavior with the existing support: cron, fixedDelay and fixedRate are all supported strategies. If the `Publisher` errors, the exception is logged at warn level and otherwise ignored. As a result new `Runnable` instances will be created for each execution and scheduling will continue. The only difference with synchronous support is that error signals will not be thrown by those `Runnable` tasks and will not be made available to the `org.springframework.util.ErrorHandler` contract. This is due to the asynchronous and lazy nature of Publishers. Closes gh-23533 Closes gh-28515
55 lines
2.4 KiB
Groovy
55 lines
2.4 KiB
Groovy
plugins {
|
|
id 'org.springframework.build.runtimehints-agent'
|
|
}
|
|
|
|
description = "Spring Context"
|
|
|
|
apply plugin: "kotlin"
|
|
|
|
dependencies {
|
|
api(project(":spring-aop"))
|
|
api(project(":spring-beans"))
|
|
api(project(":spring-core"))
|
|
api(project(":spring-expression"))
|
|
optional(project(":spring-instrument"))
|
|
optional("jakarta.annotation:jakarta.annotation-api")
|
|
optional("jakarta.ejb:jakarta.ejb-api")
|
|
optional("jakarta.enterprise.concurrent:jakarta.enterprise.concurrent-api")
|
|
optional("jakarta.inject:jakarta.inject-api")
|
|
optional("jakarta.interceptor:jakarta.interceptor-api")
|
|
optional("jakarta.validation:jakarta.validation-api")
|
|
optional("javax.money:money-api")
|
|
optional("org.aspectj:aspectjweaver")
|
|
optional("org.apache.groovy:groovy")
|
|
optional("org.apache-extras.beanshell:bsh")
|
|
optional("org.crac:crac")
|
|
optional("org.hibernate:hibernate-validator")
|
|
optional("org.jetbrains.kotlin:kotlin-reflect")
|
|
optional("org.jetbrains.kotlin:kotlin-stdlib")
|
|
optional("org.reactivestreams:reactive-streams")
|
|
optional("io.projectreactor:reactor-core")
|
|
testImplementation(project(":spring-core-test"))
|
|
testImplementation(testFixtures(project(":spring-aop")))
|
|
testImplementation(testFixtures(project(":spring-beans")))
|
|
testImplementation(testFixtures(project(":spring-core")))
|
|
testImplementation("io.projectreactor:reactor-core")
|
|
testImplementation("org.apache.groovy:groovy-jsr223")
|
|
testImplementation("org.apache.groovy:groovy-xml")
|
|
testImplementation("org.apache.commons:commons-pool2")
|
|
testImplementation("org.awaitility:awaitility")
|
|
testImplementation("jakarta.inject:jakarta.inject-tck")
|
|
testImplementation("org.jetbrains.kotlinx:kotlinx-coroutines-core")
|
|
testImplementation("org.jetbrains.kotlinx:kotlinx-coroutines-reactor")
|
|
testImplementation("io.reactivex.rxjava3:rxjava")
|
|
testRuntimeOnly("jakarta.xml.bind:jakarta.xml.bind-api")
|
|
testRuntimeOnly("org.glassfish:jakarta.el")
|
|
// Substitute for javax.management:jmxremote_optional:1.0.1_04 (not available on Maven Central)
|
|
testRuntimeOnly("org.glassfish.external:opendmk_jmxremote_optional_jar")
|
|
testRuntimeOnly("org.javamoney:moneta")
|
|
testRuntimeOnly("org.junit.vintage:junit-vintage-engine") // for @Inject TCK
|
|
testFixturesApi("org.junit.jupiter:junit-jupiter-api")
|
|
testFixturesImplementation(testFixtures(project(":spring-beans")))
|
|
testFixturesImplementation("com.google.code.findbugs:jsr305")
|
|
testFixturesImplementation("org.assertj:assertj-core")
|
|
}
|