From f7b11210227d91d4f67bb6f967456b4c9b2d4745 Mon Sep 17 00:00:00 2001 From: Stephan Schroevers Date: Sun, 3 Nov 2024 11:28:23 +0100 Subject: [PATCH] Write down current thinking --- .../errorprone/refasterrules/ReactorRules.java | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) 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 f71729bb24e..9f0daab1bab 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 @@ -1772,9 +1772,15 @@ StepVerifier.FirstStep after(Flux flux) { * Prefer {@link StepVerifier.LastStep#verify()} over a dangling {@link * StepVerifier#verifyThenAssertThat()}. */ - // XXX: This rule may break existing code. We want to explicitly nudge towards using {@link - // StepVerifier.Step#assertNext(Consumer)} or {@link StepVerifier.Step#expectNext(Object)} - // together with {@link Step#verifyComplete()}. + // XXX: Application of this rule (and several others in this class) will cause invalid code if the + // result of the rewritten expression is dereferenced. Consider introducing a bug checker that + // identifies rules that change the return type of an expression and annotates them accordingly. + // The associated annotation can then be used to instruct an annotation processor to generate + // corresponding `void` rules that match only statements. This would allow the `Refaster` check to + // conditionally skip "not fully safe" rules. This allows conditionally flagging more dubious + // code, at the risk of compilation failures. With this rule, for example, we want to explicitly + // nudge users towards `StepVerifier.Step#assertNext(Consumer)` or + // `StepVerifier.Step#expectNext(Object)`, together with `Step#verifyComplete()`. static final class StepVerifierVerify { @BeforeTemplate StepVerifier.Assertions before(StepVerifier stepVerifier) {