Fix NPE with Hikari when DatabaseDriver has null driverClassName
Fixes gh-44994
This commit is contained in:
parent
88e8c17369
commit
cae3a92ead
|
@ -190,7 +190,10 @@ public final class DataSourceBuilder<T extends DataSource> {
|
|||
&& this.values.containsKey(DataSourceProperty.URL)) {
|
||||
String url = this.values.get(DataSourceProperty.URL);
|
||||
DatabaseDriver driver = DatabaseDriver.fromJdbcUrl(url);
|
||||
properties.set(dataSource, DataSourceProperty.DRIVER_CLASS_NAME, driver.getDriverClassName());
|
||||
String driverClassName = driver.getDriverClassName();
|
||||
if (driverClassName != null) {
|
||||
properties.set(dataSource, DataSourceProperty.DRIVER_CLASS_NAME, driver.getDriverClassName());
|
||||
}
|
||||
}
|
||||
return dataSource;
|
||||
}
|
||||
|
|
|
@ -474,6 +474,15 @@ class DataSourceBuilderTests {
|
|||
assertThat(c3p0DataSource.getDriverClass()).isEqualTo("com.example.Driver");
|
||||
}
|
||||
|
||||
@Test
|
||||
void buildWhenJdbcUrlIsFromUnknownDriverLeavesDriverClassNameUnset() {
|
||||
this.dataSource = DataSourceBuilder.create()
|
||||
.url("jdbc:example://localhost:1234/example")
|
||||
.type(HikariDataSource.class)
|
||||
.build();
|
||||
assertThat(((HikariDataSource) this.dataSource).getDriverClassName()).isNull();
|
||||
}
|
||||
|
||||
private DataSource wrap(DataSource target) {
|
||||
return new DataSourceWrapper(target);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue