Browse Source

DATACMNS-1141 - Add missing NonNullApi and Nullable annotations.

Add Nullable annotation to ParsingUtils, Sort.Order and PropertyValueProvider.

Add getRequiredAnnotation(…) to PersistentEntity and PersistentProperty to provide methods returning required, non-null annotations.
pull/236/merge
Mark Paluch 9 years ago
parent
commit
3a2b6b601b
  1. 5
      src/main/java/org/springframework/data/config/ParsingUtils.java
  2. 6
      src/main/java/org/springframework/data/domain/Sort.java
  3. 20
      src/main/java/org/springframework/data/mapping/PersistentEntity.java
  4. 21
      src/main/java/org/springframework/data/mapping/PersistentProperty.java
  5. 3
      src/main/java/org/springframework/data/mapping/model/PropertyValueProvider.java
  6. 27
      src/test/java/org/springframework/data/mapping/model/AnnotationBasedPersistentPropertyUnitTests.java
  7. 18
      src/test/java/org/springframework/data/mapping/model/BasicPersistentEntityUnitTests.java

5
src/main/java/org/springframework/data/config/ParsingUtils.java

@ -1,5 +1,5 @@ @@ -1,5 +1,5 @@
/*
* Copyright 2011-2012 the original author or authors.
* Copyright 2011-2017 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@ -30,6 +30,7 @@ import org.w3c.dom.Element; @@ -30,6 +30,7 @@ import org.w3c.dom.Element;
* Utility methods for {@link BeanDefinitionParser} implementations.
*
* @author Oliver Gierke
* @author Mark Paluch
*/
public abstract class ParsingUtils {
@ -138,7 +139,7 @@ public abstract class ParsingUtils { @@ -138,7 +139,7 @@ public abstract class ParsingUtils {
* @param source
* @return
*/
public static AbstractBeanDefinition getObjectFactoryBeanDefinition(String targetBeanName, Object source) {
public static AbstractBeanDefinition getObjectFactoryBeanDefinition(String targetBeanName, @Nullable Object source) {
Assert.hasText(targetBeanName, "Target bean name must not be null or empty!");

6
src/main/java/org/springframework/data/domain/Sort.java

@ -414,7 +414,7 @@ public class Sort implements Streamable<org.springframework.data.domain.Sort.Ord @@ -414,7 +414,7 @@ public class Sort implements Streamable<org.springframework.data.domain.Sort.Ord
* @param direction can be {@literal null}, will default to {@link Sort#DEFAULT_DIRECTION}
* @param property must not be {@literal null} or empty.
*/
public Order(Direction direction, String property) {
public Order(@Nullable Direction direction, String property) {
this(direction, property, DEFAULT_IGNORE_CASE, DEFAULT_NULL_HANDLING);
}
@ -426,7 +426,7 @@ public class Sort implements Streamable<org.springframework.data.domain.Sort.Ord @@ -426,7 +426,7 @@ public class Sort implements Streamable<org.springframework.data.domain.Sort.Ord
* @param property must not be {@literal null} or empty.
* @param nullHandling must not be {@literal null}.
*/
public Order(Direction direction, String property, NullHandling nullHandlingHint) {
public Order(@Nullable Direction direction, String property, NullHandling nullHandlingHint) {
this(direction, property, DEFAULT_IGNORE_CASE, nullHandlingHint);
}
@ -485,7 +485,7 @@ public class Sort implements Streamable<org.springframework.data.domain.Sort.Ord @@ -485,7 +485,7 @@ public class Sort implements Streamable<org.springframework.data.domain.Sort.Ord
* @param nullHandling must not be {@literal null}.
* @since 1.7
*/
private Order(Direction direction, String property, boolean ignoreCase, NullHandling nullHandling) {
private Order(@Nullable Direction direction, String property, boolean ignoreCase, NullHandling nullHandling) {
if (!StringUtils.hasText(property)) {
throw new IllegalArgumentException("Property must not null or empty!");

20
src/main/java/org/springframework/data/mapping/PersistentEntity.java

@ -249,6 +249,26 @@ public interface PersistentEntity<T, P extends PersistentProperty<P>> extends It @@ -249,6 +249,26 @@ public interface PersistentEntity<T, P extends PersistentProperty<P>> extends It
@Nullable
<A extends Annotation> A findAnnotation(Class<A> annotationType);
/**
* Returns the required annotation of the given type on the {@link PersistentEntity}.
*
* @param annotationType must not be {@literal null}.
* @return the annotation.
* @throws IllegalStateException if the required {@code annotationType} is not found.
* @since 2.0
*/
default <A extends Annotation> A getRequiredAnnotation(Class<A> annotationType) throws IllegalStateException {
A annotation = findAnnotation(annotationType);
if (annotation != null) {
return annotation;
}
throw new IllegalStateException(
String.format("Required annotation %s not found for %s!", annotationType, getType()));
}
/**
* Checks whether the annotation of the given type is present on the {@link PersistentEntity}.
*

21
src/main/java/org/springframework/data/mapping/PersistentProperty.java

@ -269,6 +269,27 @@ public interface PersistentProperty<P extends PersistentProperty<P>> { @@ -269,6 +269,27 @@ public interface PersistentProperty<P extends PersistentProperty<P>> {
@Nullable
<A extends Annotation> A findAnnotation(Class<A> annotationType);
/**
* Looks up the annotation of the given type on the {@link PersistentProperty}. Will inspect accessors and the
* potentially backing field and traverse accessor methods to potentially available super types.
*
* @param annotationType the annotation to look up, must not be {@literal null}.
* @return the annotation of the given type.
* @throws IllegalStateException if the required {@code annotationType} is not found.
* @since 2.0
*/
default <A extends Annotation> A getRequiredAnnotation(Class<A> annotationType) throws IllegalStateException {
A annotation = findAnnotation(annotationType);
if (annotation != null) {
return annotation;
}
throw new IllegalStateException(
String.format("Required annotation %s not found for %s!", annotationType, getName()));
}
/**
* Looks up the annotation of the given type on the property and the owning type if no annotation can be found on it.
* Useful to lookup annotations that can be configured on the type but overridden on an individual property.

3
src/main/java/org/springframework/data/mapping/model/PropertyValueProvider.java

@ -16,11 +16,13 @@ @@ -16,11 +16,13 @@
package org.springframework.data.mapping.model;
import org.springframework.data.mapping.PersistentProperty;
import org.springframework.lang.Nullable;
/**
* SPI for components to provide values for as {@link PersistentProperty}.
*
* @author Oliver Gierke
* @author Mark Paluch
*/
public interface PropertyValueProvider<P extends PersistentProperty<P>> {
@ -30,5 +32,6 @@ public interface PropertyValueProvider<P extends PersistentProperty<P>> { @@ -30,5 +32,6 @@ public interface PropertyValueProvider<P extends PersistentProperty<P>> {
* @param property will never be {@literal null}.
* @return
*/
@Nullable
<T> T getPropertyValue(P property);
}

27
src/test/java/org/springframework/data/mapping/model/AnnotationBasedPersistentPropertyUnitTests.java

@ -25,8 +25,6 @@ import java.lang.annotation.Target; @@ -25,8 +25,6 @@ import java.lang.annotation.Target;
import java.util.Map;
import java.util.Optional;
import org.springframework.lang.Nullable;
import org.junit.Before;
import org.junit.Test;
import org.springframework.core.annotation.AliasFor;
@ -37,8 +35,10 @@ import org.springframework.data.annotation.Id; @@ -37,8 +35,10 @@ import org.springframework.data.annotation.Id;
import org.springframework.data.annotation.ReadOnlyProperty;
import org.springframework.data.annotation.Transient;
import org.springframework.data.mapping.MappingException;
import org.springframework.data.mapping.PersistentProperty;
import org.springframework.data.mapping.context.SampleMappingContext;
import org.springframework.data.mapping.context.SamplePersistentProperty;
import org.springframework.lang.Nullable;
import org.springframework.test.util.ReflectionTestUtils;
/**
@ -46,6 +46,7 @@ import org.springframework.test.util.ReflectionTestUtils; @@ -46,6 +46,7 @@ import org.springframework.test.util.ReflectionTestUtils;
*
* @author Oliver Gierke
* @author Christoph Strobl
* @author Mark Paluch
*/
public class AnnotationBasedPersistentPropertyUnitTests<P extends AnnotationBasedPersistentProperty<P>> {
@ -217,9 +218,25 @@ public class AnnotationBasedPersistentPropertyUnitTests<P extends AnnotationBase @@ -217,9 +218,25 @@ public class AnnotationBasedPersistentPropertyUnitTests<P extends AnnotationBase
assertThat(entity.getPersistentProperty("setter")).satisfies(
property -> assertThat(property.findAnnotation(RevisedAnnnotationWithAliasFor.class)).satisfies(annotation -> {
assertThat(annotation.name()).isEqualTo("my-value");
assertThat(annotation.value()).isEqualTo("my-value");
}));
assertThat(annotation.name()).isEqualTo("my-value");
assertThat(annotation.value()).isEqualTo("my-value");
}));
}
@Test // DATACMNS-1141
public void getRequiredAnnotationReturnsAnnotation() {
PersistentProperty property = getProperty(Sample.class, "id");
assertThat(property.getRequiredAnnotation(Id.class)).isNotNull();
}
@Test // DATACMNS-1141
public void getRequiredAnnotationThrowsException() {
PersistentProperty property = getProperty(Sample.class, "id");
assertThatThrownBy(() -> property.getRequiredAnnotation(Transient.class)).isInstanceOf(IllegalStateException.class);
}
@SuppressWarnings("unchecked")

18
src/test/java/org/springframework/data/mapping/model/BasicPersistentEntityUnitTests.java

@ -39,6 +39,7 @@ import org.springframework.data.annotation.CreatedDate; @@ -39,6 +39,7 @@ import org.springframework.data.annotation.CreatedDate;
import org.springframework.data.annotation.LastModifiedBy;
import org.springframework.data.annotation.TypeAlias;
import org.springframework.data.mapping.Alias;
import org.springframework.data.mapping.Document;
import org.springframework.data.mapping.MappingException;
import org.springframework.data.mapping.PersistentEntity;
import org.springframework.data.mapping.PersistentEntitySpec;
@ -258,6 +259,23 @@ public class BasicPersistentEntityUnitTests<T extends PersistentProperty<T>> { @@ -258,6 +259,23 @@ public class BasicPersistentEntityUnitTests<T extends PersistentProperty<T>> {
assertThatExceptionOfType(IllegalArgumentException.class).isThrownBy(() -> entity.addAssociation(null));
}
@Test // DATACMNS-1141
public void getRequiredAnnotationReturnsAnnotation() {
PersistentEntity<AliasEntityUsingComposedAnnotation, T> entity = createEntity(
AliasEntityUsingComposedAnnotation.class);
assertThat(entity.getRequiredAnnotation(TypeAlias.class).value()).isEqualTo("bar");
}
@Test // DATACMNS-1141
public void getRequiredAnnotationThrowsException() {
PersistentEntity<AliasEntityUsingComposedAnnotation, T> entity = createEntity(
AliasEntityUsingComposedAnnotation.class);
assertThatThrownBy(() -> entity.getRequiredAnnotation(Document.class)).isInstanceOf(IllegalStateException.class);
}
private <S> BasicPersistentEntity<S, T> createEntity(Class<S> type) {
return createEntity(type, null);
}

Loading…
Cancel
Save