commit
ab8080353e
|
@ -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…
Reference in New Issue