diff --git a/error-prone-contrib/src/main/java/tech/picnic/errorprone/refasterrules/ReactorRules.java b/error-prone-contrib/src/main/java/tech/picnic/errorprone/refasterrules/ReactorRules.java index 68650e5b45..e1d8815e60 100644 --- a/error-prone-contrib/src/main/java/tech/picnic/errorprone/refasterrules/ReactorRules.java +++ b/error-prone-contrib/src/main/java/tech/picnic/errorprone/refasterrules/ReactorRules.java @@ -1053,6 +1053,40 @@ Flux after(Flux flux) { } } + /** Prefer {@link Mono#ofType(Class)} over more contrived alternatives. */ + static final class MonoOfType { + @BeforeTemplate + Mono before(Mono mono) { + return mono.filter( + Refaster.anyOf( + Refaster.clazz()::isInstance, + x -> Refaster.clazz().isAssignableFrom(x.getClass()))) + .cast(Refaster.clazz()); + } + + @AfterTemplate + Mono after(Mono mono) { + return mono.ofType(Refaster.clazz()); + } + } + + /** Prefer {@link Flux#ofType(Class)} over more contrived alternatives. */ + static final class FluxOfType { + @BeforeTemplate + Flux before(Flux flux) { + return flux.filter( + Refaster.anyOf( + Refaster.clazz()::isInstance, + x -> Refaster.clazz().isAssignableFrom(x.getClass()))) + .cast(Refaster.clazz()); + } + + @AfterTemplate + Flux after(Flux flux) { + return flux.ofType(Refaster.clazz()); + } + } + /** Prefer {@link Mono#flatMap(Function)} over more contrived alternatives. */ static final class MonoFlatMap { @BeforeTemplate diff --git a/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ReactorRulesTestInput.java b/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ReactorRulesTestInput.java index b10b47f57b..388bab058a 100644 --- a/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ReactorRulesTestInput.java +++ b/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ReactorRulesTestInput.java @@ -364,6 +364,18 @@ Flux testFluxCast() { return Flux.just(1).map(Number.class::cast); } + ImmutableSet> testMonoOfType() { + return ImmutableSet.of( + Mono.just(1).filter(Number.class::isInstance).cast(Number.class), + Mono.just(2).filter(n -> Number.class.isAssignableFrom(n.getClass())).cast(Number.class)); + } + + ImmutableSet> testFluxOfType() { + return ImmutableSet.of( + Flux.just(1).filter(Number.class::isInstance).cast(Number.class), + Flux.just(2).filter(n -> Number.class.isAssignableFrom(n.getClass())).cast(Number.class)); + } + Mono testMonoFlatMap() { return Mono.just("foo").map(Mono::just).flatMap(identity()); } diff --git a/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ReactorRulesTestOutput.java b/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ReactorRulesTestOutput.java index 98279c9060..1caa225341 100644 --- a/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ReactorRulesTestOutput.java +++ b/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ReactorRulesTestOutput.java @@ -357,6 +357,14 @@ Flux testFluxCast() { return Flux.just(1).cast(Number.class); } + ImmutableSet> testMonoOfType() { + return ImmutableSet.of(Mono.just(1).ofType(Number.class), Mono.just(2).ofType(Number.class)); + } + + ImmutableSet> testFluxOfType() { + return ImmutableSet.of(Flux.just(1).ofType(Number.class), Flux.just(2).ofType(Number.class)); + } + Mono testMonoFlatMap() { return Mono.just("foo").flatMap(Mono::just); }