Skip to content

Commit dd9efef

Browse files
committed
GH-455 - Guard against AutoConfiguration- and EntityScanPackages bean definitions not having any constructor argument defined.
1 parent 35f7ee6 commit dd9efef

File tree

2 files changed

+54
-6
lines changed

2 files changed

+54
-6
lines changed

spring-modulith-test/src/main/java/org/springframework/modulith/test/ModuleTestAutoConfiguration.java

Lines changed: 8 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -43,8 +43,8 @@
4343
@AutoConfigureOrder(Ordered.HIGHEST_PRECEDENCE)
4444
class ModuleTestAutoConfiguration {
4545

46-
private static final String AUTOCONFIG_PACKAGES = "org.springframework.boot.autoconfigure.AutoConfigurationPackages";
47-
private static final String ENTITY_SCAN_PACKAGE = "org.springframework.boot.autoconfigure.domain.EntityScanPackages";
46+
static final String AUTOCONFIG_PACKAGES = "org.springframework.boot.autoconfigure.AutoConfigurationPackages";
47+
static final String ENTITY_SCAN_PACKAGE = "org.springframework.boot.autoconfigure.domain.EntityScanPackages";
4848

4949
static class AutoConfigurationAndEntityScanPackageCustomizer implements ImportBeanDefinitionRegistrar {
5050

@@ -67,7 +67,7 @@ public void registerBeanDefinitions(AnnotationMetadata importingClassMetadata, B
6767
setBasePackagesOn(registry, ENTITY_SCAN_PACKAGE, basePackages);
6868
}
6969

70-
private void setBasePackagesOn(BeanDefinitionRegistry registry, String beanName, List<String> packages) {
70+
void setBasePackagesOn(BeanDefinitionRegistry registry, String beanName, List<String> packages) {
7171

7272
if (!registry.containsBeanDefinition(beanName)) {
7373
return;
@@ -77,9 +77,11 @@ private void setBasePackagesOn(BeanDefinitionRegistry registry, String beanName,
7777
var definition = registry.getBeanDefinition(beanName);
7878
var holder = definition.getConstructorArgumentValues().getArgumentValue(0, String[].class);
7979

80-
Arrays.stream((String[]) holder.getValue())
81-
.filter(it -> it.startsWith("org.springframework.modulith"))
82-
.forEach(packagesToSet::add);
80+
if (holder != null) {
81+
Arrays.stream((String[]) holder.getValue())
82+
.filter(it -> it.startsWith("org.springframework.modulith"))
83+
.forEach(packagesToSet::add);
84+
}
8385

8486
definition.getConstructorArgumentValues().addIndexedArgumentValue(0, packagesToSet.toArray(String[]::new));
8587
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,46 @@
1+
/*
2+
* Copyright 2024 the original author or authors.
3+
*
4+
* Licensed under the Apache License, Version 2.0 (the "License");
5+
* you may not use this file except in compliance with the License.
6+
* You may obtain a copy of the License at
7+
*
8+
* https://www.apache.org/licenses/LICENSE-2.0
9+
*
10+
* Unless required by applicable law or agreed to in writing, software
11+
* distributed under the License is distributed on an "AS IS" BASIS,
12+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
* See the License for the specific language governing permissions and
14+
* limitations under the License.
15+
*/
16+
package org.springframework.modulith.test;
17+
18+
import static org.assertj.core.api.Assertions.*;
19+
20+
import java.util.Collections;
21+
22+
import org.junit.jupiter.api.Test;
23+
import org.springframework.beans.factory.support.DefaultListableBeanFactory;
24+
import org.springframework.beans.factory.support.RootBeanDefinition;
25+
import org.springframework.boot.autoconfigure.AutoConfigurationPackages;
26+
27+
/**
28+
* Unit tests for {@link ModuleTestAutoConfiguration}.
29+
*
30+
* @author Oliver Drotbohm
31+
*/
32+
class ModuleTestAutoConfigurationUnitTests {
33+
34+
@Test // GH-453
35+
void handlesNoConstructorArgumentOnPackagesBeanDefinition() {
36+
37+
var definition = new RootBeanDefinition(AutoConfigurationPackages.class);
38+
var factory = new DefaultListableBeanFactory();
39+
factory.registerBeanDefinition(ModuleTestAutoConfiguration.AUTOCONFIG_PACKAGES, definition);
40+
41+
assertThatNoException().isThrownBy(() -> {
42+
new ModuleTestAutoConfiguration.AutoConfigurationAndEntityScanPackageCustomizer()
43+
.setBasePackagesOn(factory, ModuleTestAutoConfiguration.AUTOCONFIG_PACKAGES, Collections.emptyList());
44+
});
45+
}
46+
}

0 commit comments

Comments
 (0)