mirror of
https://github.com/spring-projects/spring-boot.git
synced 2024-07-05 00:56:58 +08:00
Back off if DataSource is not on the classpath
Closes gh-41082
This commit is contained in:
parent
847ff50676
commit
fed13b0e0c
@ -49,7 +49,7 @@ import org.springframework.transaction.TransactionManager;
|
||||
*/
|
||||
@AutoConfiguration(before = TransactionAutoConfiguration.class,
|
||||
after = TransactionManagerCustomizationAutoConfiguration.class)
|
||||
@ConditionalOnClass({ JdbcTemplate.class, TransactionManager.class })
|
||||
@ConditionalOnClass({ DataSource.class, JdbcTemplate.class, TransactionManager.class })
|
||||
@AutoConfigureOrder(Ordered.LOWEST_PRECEDENCE)
|
||||
@EnableConfigurationProperties(DataSourceProperties.class)
|
||||
public class DataSourceTransactionManagerAutoConfiguration {
|
||||
|
@ -25,6 +25,7 @@ import org.junit.jupiter.api.Test;
|
||||
import org.springframework.boot.autoconfigure.AutoConfigurations;
|
||||
import org.springframework.boot.autoconfigure.transaction.TransactionAutoConfiguration;
|
||||
import org.springframework.boot.autoconfigure.transaction.TransactionManagerCustomizationAutoConfiguration;
|
||||
import org.springframework.boot.test.context.FilteredClassLoader;
|
||||
import org.springframework.boot.test.context.runner.ApplicationContextRunner;
|
||||
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
|
||||
import org.springframework.jdbc.support.JdbcTransactionManager;
|
||||
@ -40,6 +41,7 @@ import static org.mockito.Mockito.mock;
|
||||
* @author Stephane Nicoll
|
||||
* @author Kazuki Shimizu
|
||||
* @author Davin Byeon
|
||||
* @author Moritz Halbritter
|
||||
*/
|
||||
class DataSourceTransactionManagerAutoConfigurationTests {
|
||||
|
||||
@ -124,4 +126,10 @@ class DataSourceTransactionManagerAutoConfigurationTests {
|
||||
});
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldNotUseDataSourcePropertiesIfDataSourceIsNotOnTheClasspath() {
|
||||
this.contextRunner.withClassLoader(new FilteredClassLoader(DataSource.class))
|
||||
.run((context) -> assertThat(context).doesNotHaveBean(DataSourceProperties.class));
|
||||
}
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user