Skip to content

Commit

Permalink
Polish contribution
Browse files Browse the repository at this point in the history
  • Loading branch information
sbrannen committed Jul 29, 2020
1 parent 83a9583 commit 7dbf42e
Show file tree
Hide file tree
Showing 2 changed files with 51 additions and 19 deletions.
Expand Up @@ -37,7 +37,6 @@
import org.springframework.core.annotation.AnnotationTypeMapping.MirrorSets;
import org.springframework.core.annotation.AnnotationTypeMapping.MirrorSets.MirrorSet;
import org.springframework.lang.UsesSunMisc;
import org.springframework.util.ObjectUtils;
import org.springframework.util.ReflectionUtils;

import static java.util.stream.Collectors.toList;
Expand Down Expand Up @@ -86,6 +85,14 @@ void forAnnotationTypeWhenHasRepeatingMetaAnnotationReturnsMapping() {
WithRepeatedMetaAnnotations.class, Repeating.class, Repeating.class);
}

@Test
void forAnnotationTypeWhenRepeatableMetaAnnotationIsFiltered() {
AnnotationTypeMappings mappings = AnnotationTypeMappings.forAnnotationType(WithRepeatedMetaAnnotations.class,
Repeating.class.getName()::equals);
assertThat(getAll(mappings)).flatExtracting(AnnotationTypeMapping::getAnnotationType)
.containsExactly(WithRepeatedMetaAnnotations.class);
}

@Test
void forAnnotationTypeWhenSelfAnnotatedReturnsMapping() {
AnnotationTypeMappings mappings = AnnotationTypeMappings.forAnnotationType(SelfAnnotated.class);
Expand Down Expand Up @@ -477,16 +484,6 @@ private Method[] resolveMirrorSets(AnnotationTypeMapping mapping, Class<?> eleme
return result;
}

@Test
void forAnnotationTypeWhenRepeatableMetaAnnotationFilterd() {
AnnotationTypeMappings mappings = AnnotationTypeMappings.forAnnotationType(WithRepeatedMetaAnnotations.class,
annotationType ->
ObjectUtils.nullSafeEquals(annotationType, Repeating.class.getName()));
assertThat(getAll(mappings)).flatExtracting(
AnnotationTypeMapping::getAnnotationType).containsExactly(
WithRepeatedMetaAnnotations.class);
}

@Nullable
private Method getAliasMapping(AnnotationTypeMapping mapping, int attributeIndex) {
int mapped = mapping.getAliasMapping(attributeIndex);
Expand Down
@@ -1,5 +1,5 @@
/*
* Copyright 2002-2019 the original author or authors.
* Copyright 2002-2020 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.
Expand All @@ -25,6 +25,7 @@
import java.lang.annotation.Target;
import java.lang.reflect.AnnotatedElement;
import java.util.Set;
import java.util.stream.Stream;

import org.assertj.core.api.ThrowableTypeAssert;
import org.junit.jupiter.api.Test;
Expand Down Expand Up @@ -222,14 +223,35 @@ void typeHierarchyAnnotationsWhenNoninheritedComposedRepeatableOnSuperclassRetur
"B", "C");
}

private <A extends Annotation> Set<A> getAnnotations(
Class<? extends Annotation> container, Class<A> repeatable,
SearchStrategy searchStrategy, AnnotatedElement element) {
@Test
void typeHierarchyAnnotationsWithLocalComposedAnnotationWhoseRepeatableMetaAnnotationsAreFiltered() {
Class<WithRepeatedMetaAnnotationsClass> element = WithRepeatedMetaAnnotationsClass.class;
SearchStrategy searchStrategy = SearchStrategy.TYPE_HIERARCHY;
AnnotationFilter annotationFilter = PeteRepeat.class.getName()::equals;

Set<PeteRepeat> annotations = getAnnotations(null, PeteRepeat.class, searchStrategy, element, annotationFilter);
assertThat(annotations).isEmpty();

MergedAnnotations mergedAnnotations = MergedAnnotations.from(element, searchStrategy,
RepeatableContainers.standardRepeatables(), annotationFilter);
Stream<Class<? extends Annotation>> annotationTypes = mergedAnnotations.stream()
.map(MergedAnnotation::synthesize)
.map(Annotation::annotationType);
assertThat(annotationTypes).containsExactly(WithRepeatedMetaAnnotations.class, Noninherited.class, Noninherited.class);
}

private <A extends Annotation> Set<A> getAnnotations(Class<? extends Annotation> container,
Class<A> repeatable, SearchStrategy searchStrategy, AnnotatedElement element) {

return getAnnotations(container, repeatable, searchStrategy, element, AnnotationFilter.PLAIN);
}

private <A extends Annotation> Set<A> getAnnotations(Class<? extends Annotation> container,
Class<A> repeatable, SearchStrategy searchStrategy, AnnotatedElement element, AnnotationFilter annotationFilter) {

RepeatableContainers containers = RepeatableContainers.of(repeatable, container);
MergedAnnotations annotations = MergedAnnotations.from(element,
searchStrategy, containers, AnnotationFilter.PLAIN);
return annotations.stream(repeatable).collect(
MergedAnnotationCollectors.toAnnotationSet());
MergedAnnotations annotations = MergedAnnotations.from(element, searchStrategy, containers, annotationFilter);
return annotations.stream(repeatable).collect(MergedAnnotationCollectors.toAnnotationSet());
}

private void nonRepeatableRequirements(Exception ex) {
Expand Down Expand Up @@ -414,4 +436,17 @@ static class SubNoninheritedRepeatableClass extends NoninheritedRepeatableClass

}

@Retention(RetentionPolicy.RUNTIME)
@PeteRepeat("A")
@PeteRepeat("B")
@interface WithRepeatedMetaAnnotations {
}

@WithRepeatedMetaAnnotations
@PeteRepeat("C")
@Noninherited("X")
@Noninherited("Y")
static class WithRepeatedMetaAnnotationsClass {
}

}

0 comments on commit 7dbf42e

Please sign in to comment.