From e09cc166c7db0d375d1ef8c7bebf8d8297b02898 Mon Sep 17 00:00:00 2001 From: David Schlosnagle Date: Mon, 8 Jul 2024 19:39:57 -0400 Subject: [PATCH] Propagate @SuppressWarnings on @Instrument types (#1976) Propagate @SuppressWarnings on @Instrument types --- changelog/@unreleased/pr-1976.v2.yml | 5 ++ .../TritiumAnnotationProcessorStrategy.java | 11 ++- .../tritium/examples/DeprecatedType.java | 31 ++++++++ .../processor/TritiumProcessorTest.java | 6 ++ .../InstrumentedDeprecatedType.java.generated | 71 +++++++++++++++++++ 5 files changed, 122 insertions(+), 2 deletions(-) create mode 100644 changelog/@unreleased/pr-1976.v2.yml create mode 100644 tritium-processor/src/test/java/com/palantir/tritium/examples/DeprecatedType.java create mode 100644 tritium-processor/src/test/resources/com/palantir/tritium/examples/InstrumentedDeprecatedType.java.generated diff --git a/changelog/@unreleased/pr-1976.v2.yml b/changelog/@unreleased/pr-1976.v2.yml new file mode 100644 index 000000000..9ebff5851 --- /dev/null +++ b/changelog/@unreleased/pr-1976.v2.yml @@ -0,0 +1,5 @@ +type: fix +fix: + description: Propagate @SuppressWarnings on @Instrument types + links: + - https://github.com/palantir/tritium/pull/1976 diff --git a/tritium-processor/src/main/java/com/palantir/tritium/processor/TritiumAnnotationProcessorStrategy.java b/tritium-processor/src/main/java/com/palantir/tritium/processor/TritiumAnnotationProcessorStrategy.java index f2d99d7d6..daa1161ef 100644 --- a/tritium-processor/src/main/java/com/palantir/tritium/processor/TritiumAnnotationProcessorStrategy.java +++ b/tritium-processor/src/main/java/com/palantir/tritium/processor/TritiumAnnotationProcessorStrategy.java @@ -27,6 +27,7 @@ import com.palantir.tritium.event.InvocationContext; import com.palantir.tritium.event.InvocationEventHandler; import com.palantir.tritium.metrics.registry.TaggedMetricRegistry; +import com.squareup.javapoet.AnnotationSpec; import com.squareup.javapoet.ClassName; import com.squareup.javapoet.CodeBlock; import com.squareup.javapoet.FieldSpec; @@ -188,11 +189,17 @@ public List additionalFields(AdditionalFieldsArguments arguments) { @Override public void customize(CustomizeArguments arguments, TypeSpec.Builder generatedType) { - if (isDeprecated(arguments.type().type())) { + TypeElement type = arguments.type().type(); + if (isDeprecated(type)) { generatedType.addAnnotation(Deprecated.class); } - TypeName annotatedTypeName = TypeName.get(arguments.type().type().asType()); + SuppressWarnings suppressWarnings = type.getAnnotation(SuppressWarnings.class); + if (suppressWarnings != null) { + generatedType.addAnnotation(AnnotationSpec.get(suppressWarnings)); + } + + TypeName annotatedTypeName = TypeName.get(type.asType()); List instrumentedMethods = instrumentedMethods(arguments.type()); if (!instrumentedMethods.isEmpty()) { diff --git a/tritium-processor/src/test/java/com/palantir/tritium/examples/DeprecatedType.java b/tritium-processor/src/test/java/com/palantir/tritium/examples/DeprecatedType.java new file mode 100644 index 000000000..7d17e23d1 --- /dev/null +++ b/tritium-processor/src/test/java/com/palantir/tritium/examples/DeprecatedType.java @@ -0,0 +1,31 @@ +/* + * (c) Copyright 2024 Palantir Technologies Inc. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.palantir.tritium.examples; + +import com.palantir.tritium.annotations.Instrument; + +@Instrument +@SuppressWarnings("deprecation") +public interface DeprecatedType { + + Foo foo(); + + @Deprecated + interface Foo { + String bar(); + } +} diff --git a/tritium-processor/src/test/java/com/palantir/tritium/processor/TritiumProcessorTest.java b/tritium-processor/src/test/java/com/palantir/tritium/processor/TritiumProcessorTest.java index ee231d31d..4a6ecf3fd 100644 --- a/tritium-processor/src/test/java/com/palantir/tritium/processor/TritiumProcessorTest.java +++ b/tritium-processor/src/test/java/com/palantir/tritium/processor/TritiumProcessorTest.java @@ -34,6 +34,7 @@ import com.palantir.tritium.examples.DelegateToRunnable; import com.palantir.tritium.examples.DelegateToRunnableMethod; import com.palantir.tritium.examples.DeprecatedMethod; +import com.palantir.tritium.examples.DeprecatedType; import com.palantir.tritium.examples.Empty; import com.palantir.tritium.examples.HasDefaultMethod; import com.palantir.tritium.examples.HasToString; @@ -114,6 +115,11 @@ public void testDeprecatedInterface() { assertTestFileCompileAndMatches(TEST_CLASSES_BASE_DIR, com.palantir.tritium.examples.DeprecatedInterface.class); } + @Test + public void testDeprecatedType() { + assertTestFileCompileAndMatches(TEST_CLASSES_BASE_DIR, DeprecatedType.class); + } + @Test public void testEmptyInterface() { assertTestFileCompileAndMatches(TEST_CLASSES_BASE_DIR, Empty.class); diff --git a/tritium-processor/src/test/resources/com/palantir/tritium/examples/InstrumentedDeprecatedType.java.generated b/tritium-processor/src/test/resources/com/palantir/tritium/examples/InstrumentedDeprecatedType.java.generated new file mode 100644 index 000000000..da14552e4 --- /dev/null +++ b/tritium-processor/src/test/resources/com/palantir/tritium/examples/InstrumentedDeprecatedType.java.generated @@ -0,0 +1,71 @@ +package com.palantir.tritium.examples; + +import com.palantir.tritium.annotations.internal.InstrumentationBuilder; +import com.palantir.tritium.api.event.InstrumentationFilter; +import com.palantir.tritium.event.Handlers; +import com.palantir.tritium.event.InvocationContext; +import com.palantir.tritium.event.InvocationEventHandler; +import com.palantir.tritium.metrics.registry.TaggedMetricRegistry; +import java.lang.reflect.Method; +import java.util.Objects; +import javax.annotation.processing.Generated; + +@Generated("com.palantir.tritium.processor.TritiumAnnotationProcessor") +@SuppressWarnings("deprecation") +public final class InstrumentedDeprecatedType implements DeprecatedType { + private static final Method FOO_ed3d1cab; + + static { + try { + FOO_ed3d1cab = DeprecatedType.class.getMethod("foo"); + } catch (NoSuchMethodException e) { + throw new RuntimeException(e); + } + } + + private final DeprecatedType delegate; + + private final InvocationEventHandler handler; + + private final InstrumentationFilter filter; + + private InstrumentedDeprecatedType( + DeprecatedType delegate, InvocationEventHandler handler, InstrumentationFilter filter) { + this.delegate = Objects.requireNonNull(delegate, "delegate"); + this.handler = Objects.requireNonNull(handler, "handler"); + this.filter = Objects.requireNonNull(filter, "filter"); + } + + @Override + public DeprecatedType.Foo foo() { + InvocationContext _invocationContext = this.handler.isEnabled() + ? Handlers.pre(this.handler, this.filter, this, FOO_ed3d1cab, new Object[] {}) + : Handlers.disabled(); + try { + DeprecatedType.Foo _result = this.delegate.foo(); + Handlers.onSuccess(this.handler, _invocationContext, _result); + return _result; + } catch (Throwable _throwable) { + Handlers.onFailure(this.handler, _invocationContext, _throwable); + throw _throwable; + } + } + + @Override + public String toString() { + return "InstrumentedDeprecatedType{" + this.delegate + "}"; + } + + public static InstrumentationBuilder builder(DeprecatedType delegate) { + return new InstrumentationBuilder( + DeprecatedType.class, delegate, InstrumentedDeprecatedType::new); + } + + public static DeprecatedType trace(DeprecatedType delegate) { + return InstrumentationBuilder.trace(DeprecatedType.class, delegate, InstrumentedDeprecatedType::new); + } + + public static DeprecatedType instrument(DeprecatedType delegate, TaggedMetricRegistry registry) { + return builder(delegate).withTaggedMetrics(registry).withTracing().build(); + } +}