From 6e26322d0af6382c50d5a4ca3db0975513c53ca3 Mon Sep 17 00:00:00 2001 From: Manu Sridharan Date: Mon, 2 Jan 2023 13:30:20 -0800 Subject: [PATCH] add a multi-level inner type test --- .../com/uber/nullaway/NullAwayCoreTests.java | 21 ++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/nullaway/src/test/java/com/uber/nullaway/NullAwayCoreTests.java b/nullaway/src/test/java/com/uber/nullaway/NullAwayCoreTests.java index 5c9df89f45..5e6d0ec06f 100644 --- a/nullaway/src/test/java/com/uber/nullaway/NullAwayCoreTests.java +++ b/nullaway/src/test/java/com/uber/nullaway/NullAwayCoreTests.java @@ -1083,7 +1083,6 @@ public void typeUseAnnotationOnArray() { .addSourceLines( "Test.java", "package com.uber;", - "import java.util.Set;", "import org.checkerframework.checker.nullness.qual.Nullable;", "class Test {", " // ok only for backwards compat", @@ -1100,4 +1099,24 @@ public void typeUseAnnotationOnArray() { "}") .doTest(); } + + @Test + public void typeUseAnnotationOnInnerMultiLevel() { + defaultCompilationHelper + .addSourceLines( + "Test.java", + "package com.uber;", + "import java.util.Set;", + "import org.checkerframework.checker.nullness.qual.Nullable;", + "class A { class B { class C {} } }", + "class Test {", + " // At some point, we should only treat the last of these declarations", + " // as making the field @Nullable. For now, any of them makes the field", + " // @Nullable.", + " @Nullable A.B.C foo1 = null;", + " A.@Nullable B.C foo2 = null;", + " A.B.@Nullable C foo3 = null;", + "}") + .doTest(); + } }