From 870d16a0b67b6cf334d1d1be0e38fe012af683be Mon Sep 17 00:00:00 2001 From: Guillaume Toison <86775455+gtoison@users.noreply.github.com> Date: Fri, 16 Dec 2022 08:40:05 +0000 Subject: [PATCH] Prevent `NestedOptionals` from throwing an NPE (#412) Previously, a `NullPointerException` was thrown if during compilation the `java.util.Optional` class was not loaded at all. --- .../errorprone/bugpatterns/NestedOptionals.java | 9 ++++++--- .../bugpatterns/NestedOptionalsTest.java | 15 +++++++++++++++ 2 files changed, 21 insertions(+), 3 deletions(-) diff --git a/error-prone-contrib/src/main/java/tech/picnic/errorprone/bugpatterns/NestedOptionals.java b/error-prone-contrib/src/main/java/tech/picnic/errorprone/bugpatterns/NestedOptionals.java index b736d5a050..8fe464fd09 100644 --- a/error-prone-contrib/src/main/java/tech/picnic/errorprone/bugpatterns/NestedOptionals.java +++ b/error-prone-contrib/src/main/java/tech/picnic/errorprone/bugpatterns/NestedOptionals.java @@ -41,8 +41,11 @@ public NestedOptionals() {} @Override public Description matchMethodInvocation(MethodInvocationTree tree, VisitorState state) { - return state.getTypes().isSubtype(ASTHelpers.getType(tree), OPTIONAL_OF_OPTIONAL.get(state)) - ? describeMatch(tree) - : Description.NO_MATCH; + Type type = OPTIONAL_OF_OPTIONAL.get(state); + if (type == null || !state.getTypes().isSubtype(ASTHelpers.getType(tree), type)) { + return Description.NO_MATCH; + } + + return describeMatch(tree); } } diff --git a/error-prone-contrib/src/test/java/tech/picnic/errorprone/bugpatterns/NestedOptionalsTest.java b/error-prone-contrib/src/test/java/tech/picnic/errorprone/bugpatterns/NestedOptionalsTest.java index d5154cf554..5cebca69e5 100644 --- a/error-prone-contrib/src/test/java/tech/picnic/errorprone/bugpatterns/NestedOptionalsTest.java +++ b/error-prone-contrib/src/test/java/tech/picnic/errorprone/bugpatterns/NestedOptionalsTest.java @@ -39,4 +39,19 @@ void identification() { "}") .doTest(); } + + @Test + void identificationOptionalTypeNotLoaded() { + compilationTestHelper + .addSourceLines( + "A.java", + "import java.time.Duration;", + "", + "class A {", + " void m() {", + " Duration.ofSeconds(1);", + " }", + "}") + .doTest(); + } }