Merge branch '2.4.x'

Closes gh-24655
pull/24660/head
Phillip Webb 4 years ago
commit bd3dd0a526

@ -1,5 +1,5 @@
/* /*
* Copyright 2012-2019 the original author or authors. * Copyright 2012-2021 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -18,8 +18,14 @@ package org.springframework.boot.actuate.endpoint.invoke.reflect;
import java.lang.reflect.Parameter; import java.lang.reflect.Parameter;
import javax.annotation.Nonnull;
import javax.annotation.meta.When;
import org.springframework.boot.actuate.endpoint.invoke.OperationParameter; import org.springframework.boot.actuate.endpoint.invoke.OperationParameter;
import org.springframework.core.annotation.MergedAnnotation;
import org.springframework.core.annotation.MergedAnnotations;
import org.springframework.lang.Nullable; import org.springframework.lang.Nullable;
import org.springframework.util.ClassUtils;
import org.springframework.util.ObjectUtils; import org.springframework.util.ObjectUtils;
/** /**
@ -29,6 +35,8 @@ import org.springframework.util.ObjectUtils;
*/ */
class OperationMethodParameter implements OperationParameter { class OperationMethodParameter implements OperationParameter {
private static final boolean jsr305Present = ClassUtils.isPresent("javax.annotation.Nonnull", null);
private final String name; private final String name;
private final Parameter parameter; private final Parameter parameter;
@ -55,7 +63,10 @@ class OperationMethodParameter implements OperationParameter {
@Override @Override
public boolean isMandatory() { public boolean isMandatory() {
return ObjectUtils.isEmpty(this.parameter.getAnnotationsByType(Nullable.class)); if (!ObjectUtils.isEmpty(this.parameter.getAnnotationsByType(Nullable.class))) {
return false;
}
return (jsr305Present) ? new Jsr305().isMandatory(this.parameter) : true;
} }
@Override @Override
@ -63,4 +74,13 @@ class OperationMethodParameter implements OperationParameter {
return this.name + " of type " + this.parameter.getType().getName(); return this.name + " of type " + this.parameter.getType().getName();
} }
private static class Jsr305 {
boolean isMandatory(Parameter parameter) {
MergedAnnotation<Nonnull> annotation = MergedAnnotations.from(parameter).get(Nonnull.class);
return !annotation.isPresent() || annotation.getEnum("when", When.class) == When.ALWAYS;
}
}
} }

@ -1,5 +1,5 @@
/* /*
* Copyright 2012-2019 the original author or authors. * Copyright 2012-2021 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -16,8 +16,14 @@
package org.springframework.boot.actuate.endpoint.invoke.reflect; package org.springframework.boot.actuate.endpoint.invoke.reflect;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import javax.annotation.Nonnull;
import javax.annotation.meta.TypeQualifier;
import javax.annotation.meta.When;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.springframework.lang.Nullable; import org.springframework.lang.Nullable;
@ -32,29 +38,48 @@ import static org.assertj.core.api.Assertions.assertThat;
*/ */
class OperationMethodParameterTests { class OperationMethodParameterTests {
private Method method = ReflectionUtils.findMethod(getClass(), "example", String.class, String.class); private Method example = ReflectionUtils.findMethod(getClass(), "example", String.class, String.class);
private Method exampleJsr305 = ReflectionUtils.findMethod(getClass(), "exampleJsr305", String.class, String.class);
private Method exampleMetaJsr305 = ReflectionUtils.findMethod(getClass(), "exampleMetaJsr305", String.class,
String.class);
@Test @Test
void getNameShouldReturnName() { void getNameShouldReturnName() {
OperationMethodParameter parameter = new OperationMethodParameter("name", this.method.getParameters()[0]); OperationMethodParameter parameter = new OperationMethodParameter("name", this.example.getParameters()[0]);
assertThat(parameter.getName()).isEqualTo("name"); assertThat(parameter.getName()).isEqualTo("name");
} }
@Test @Test
void getTypeShouldReturnType() { void getTypeShouldReturnType() {
OperationMethodParameter parameter = new OperationMethodParameter("name", this.method.getParameters()[0]); OperationMethodParameter parameter = new OperationMethodParameter("name", this.example.getParameters()[0]);
assertThat(parameter.getType()).isEqualTo(String.class); assertThat(parameter.getType()).isEqualTo(String.class);
} }
@Test @Test
void isMandatoryWhenNoAnnotationShouldReturnTrue() { void isMandatoryWhenNoAnnotationShouldReturnTrue() {
OperationMethodParameter parameter = new OperationMethodParameter("name", this.method.getParameters()[0]); OperationMethodParameter parameter = new OperationMethodParameter("name", this.example.getParameters()[0]);
assertThat(parameter.isMandatory()).isTrue(); assertThat(parameter.isMandatory()).isTrue();
} }
@Test @Test
void isMandatoryWhenNullableAnnotationShouldReturnFalse() { void isMandatoryWhenNullableAnnotationShouldReturnFalse() {
OperationMethodParameter parameter = new OperationMethodParameter("name", this.method.getParameters()[1]); OperationMethodParameter parameter = new OperationMethodParameter("name", this.example.getParameters()[1]);
assertThat(parameter.isMandatory()).isFalse();
}
@Test
void isMandatoryWhenJsrNullableAnnotationShouldReturnFalse() {
OperationMethodParameter parameter = new OperationMethodParameter("name",
this.exampleJsr305.getParameters()[1]);
assertThat(parameter.isMandatory()).isFalse();
}
@Test
void isMandatoryWhenJsrMetaNullableAnnotationShouldReturnFalse() {
OperationMethodParameter parameter = new OperationMethodParameter("name",
this.exampleMetaJsr305.getParameters()[1]);
assertThat(parameter.isMandatory()).isFalse(); assertThat(parameter.isMandatory()).isFalse();
} }
@ -62,4 +87,19 @@ class OperationMethodParameterTests {
} }
void exampleJsr305(String one, @javax.annotation.Nullable String two) {
}
void exampleMetaJsr305(String one, @MetaNullable String two) {
}
@TypeQualifier
@Retention(RetentionPolicy.RUNTIME)
@Nonnull(when = When.MAYBE)
@interface MetaNullable {
}
} }

Loading…
Cancel
Save