From 790a9ec1549e6b616ab1529bdf6d0f360f92b718 Mon Sep 17 00:00:00 2001 From: Manu Sridharan Date: Fri, 6 Oct 2023 12:32:58 -0700 Subject: [PATCH] Build NullAway with JSpecify mode enabled (#841) This will give us a bit better test coverage as we continue to implement JSpecify. With one small fix to an assertion check, now NullAway can build itself in JSpecify mode without crashing! --- nullaway/build.gradle | 1 + .../src/main/java/com/uber/nullaway/GenericsChecks.java | 8 +++++--- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/nullaway/build.gradle b/nullaway/build.gradle index 019cb8b5ff..83f7e62e21 100644 --- a/nullaway/build.gradle +++ b/nullaway/build.gradle @@ -168,6 +168,7 @@ tasks.register('buildWithNullAway', JavaCompile) { option("NullAway:CheckOptionalEmptiness") option("NullAway:AcknowledgeRestrictiveAnnotations") option("NullAway:CheckContracts") + option("NullAway:JSpecifyMode") } // Make sure the jar has already been built dependsOn 'jar' diff --git a/nullaway/src/main/java/com/uber/nullaway/GenericsChecks.java b/nullaway/src/main/java/com/uber/nullaway/GenericsChecks.java index 0d814a7bc1..ce31aebbef 100644 --- a/nullaway/src/main/java/com/uber/nullaway/GenericsChecks.java +++ b/nullaway/src/main/java/com/uber/nullaway/GenericsChecks.java @@ -36,6 +36,7 @@ import java.util.List; import java.util.Map; import javax.annotation.Nullable; +import javax.lang.model.type.ExecutableType; /** Methods for performing checks related to generic types and nullability. */ public final class GenericsChecks { @@ -737,9 +738,10 @@ private static Type getTypeForSymbol(Symbol symbol, VisitorState state) { private static Nullness getGenericMethodReturnTypeNullness( Symbol.MethodSymbol method, Type enclosingType, VisitorState state, Config config) { Type overriddenMethodType = state.getTypes().memberType(enclosingType, method); - if (!(overriddenMethodType instanceof Type.MethodType)) { - throw new RuntimeException("expected method type but instead got " + overriddenMethodType); - } + verify( + overriddenMethodType instanceof ExecutableType, + "expected ExecutableType but instead got %s", + overriddenMethodType.getClass()); return getTypeNullness(overriddenMethodType.getReturnType(), config); }