Skip to content

Commit

Permalink
Test that ImportsContextCustomizer can support @AliasFor
Browse files Browse the repository at this point in the history
Add test to ensure that `ImportsContextCustomizer` can support
`@AliasFor` annotations.

See gh-34917
  • Loading branch information
Laurent Martelli authored and philwebb committed Jul 4, 2023
1 parent 1850d19 commit 9baf23c
Showing 1 changed file with 96 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import org.springframework.context.annotation.ImportSelector;
import org.springframework.core.annotation.AliasFor;
import org.springframework.core.type.AnnotationMetadata;

import static org.assertj.core.api.Assertions.assertThat;
Expand All @@ -41,6 +42,7 @@
* Tests for {@link ImportsContextCustomizer}.
*
* @author Andy Wilkinson
* @author Laurent Martelli
*/
class ImportsContextCustomizerTests {

Expand Down Expand Up @@ -80,6 +82,30 @@ void customizersForTestClassesWithDifferentJUnitAnnotationsAreEqual() {
.isEqualTo(new ImportsContextCustomizer(SecondJUnitAnnotatedTestClass.class));
}

@Test
void customizersForClassesWithDifferentImportsAreNotEqual() {
assertThat(new ImportsContextCustomizer(FirstAnnotatedTestClass.class))
.isNotEqualTo(new ImportsContextCustomizer(SecondAnnotatedTestClass.class));
}

@Test
void customizersForClassesWithDifferentMetaImportsAreNotEqual() {
assertThat(new ImportsContextCustomizer(FirstMetaAnnotatedTestClass.class))
.isNotEqualTo(new ImportsContextCustomizer(SecondMetaAnnotatedTestClass.class));
}

@Test
void customizersForClassesWithDifferentAliasedImportsAreNotEqual() {
assertThat(new ImportsContextCustomizer(FirstAliasAnnotatedTestClass.class))
.isNotEqualTo(new ImportsContextCustomizer(SecondAliasAnnotatedTestClass.class));
}

@Test
void importsCanBeScatteredOnMultipleAnnotations() {
assertThat(new ImportsContextCustomizer(SingleImportAnnotationTestClass.class))
.isEqualTo(new ImportsContextCustomizer(MultipleImportAnnotationTestClass.class));
}

@Import(TestImportSelector.class)
@Indicator1
static class FirstImportSelectorAnnotatedClass {
Expand Down Expand Up @@ -152,6 +178,17 @@ static class SecondJUnitAnnotatedTestClass {

}

@Import({ FirstImportedClass.class, SecondImportedClass.class })
static class SingleImportAnnotationTestClass {

}

@FirstMetaImport
@Import(SecondImportedClass.class)
static class MultipleImportAnnotationTestClass {

}

@Retention(RetentionPolicy.RUNTIME)
@interface Indicator1 {

Expand All @@ -162,6 +199,65 @@ static class SecondJUnitAnnotatedTestClass {

}

@Retention(RetentionPolicy.RUNTIME)
@Import(AliasFor.class)
public @interface AliasedImport {

@AliasFor(annotation = Import.class)
Class<?>[] value();

}

@Retention(RetentionPolicy.RUNTIME)
@Import(FirstImportedClass.class)
public @interface FirstMetaImport {

}

@Retention(RetentionPolicy.RUNTIME)
@Import(SecondImportedClass.class)
public @interface SecondMetaImport {

}

static class FirstImportedClass {

}

static class SecondImportedClass {

}

@AliasedImport(FirstImportedClass.class)
static class FirstAliasAnnotatedTestClass {

}

@AliasedImport(SecondImportedClass.class)
static class SecondAliasAnnotatedTestClass {

}

@FirstMetaImport
static class FirstMetaAnnotatedTestClass {

}

@SecondMetaImport
static class SecondMetaAnnotatedTestClass {

}

@Import(FirstImportedClass.class)
static class FirstAnnotatedTestClass {

}

@Import(SecondImportedClass.class)
static class SecondAnnotatedTestClass {

}

static class TestImportSelector implements ImportSelector {

@Override
Expand Down

0 comments on commit 9baf23c

Please sign in to comment.