2016-09-01 59 views
2

我使用@DataJpaTest註釋創建了一個測試。 HSQLDB配置,但我得到的錯誤:使用@DataJpaTest時未配置JdbcTemplate

No qualifying bean of type [org.springframework.jdbc.core.JdbcTemplate] 

在項目中,我使用JPA庫和JdbcTemplates。當我使用真正的Oracle DB配置時,它工作正常。爲什麼JdbcTemplate沒有自動配置?我應該怎麼做才能解決這個問題?

@RunWith(SpringRunner.class) 
@SpringBootTest(classes = {MyApplication.class}) 
@DataJpaTest 
public class IntegrationTest 

依賴關係:

<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-thymeleaf</artifactId> 
</dependency> 
<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-tomcat</artifactId> 
    <scope>provided</scope> 
</dependency> 
<dependency> 
    <groupId>javax.el</groupId> 
    <artifactId>javax.el-api</artifactId> 
    <version>2.2.4</version> 
</dependency> 
<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-devtools</artifactId> 
    <optional>true</optional> 
</dependency> 
<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-actuator</artifactId> 
</dependency> 
<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-data-jpa</artifactId> 
</dependency> 
<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-jdbc</artifactId> 
</dependency> 
<dependency> 
    <groupId>args4j</groupId> 
    <artifactId>args4j</artifactId> 
    <version>2.33</version> 
</dependency> 
<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-remote-shell</artifactId> 
</dependency> 

<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-test</artifactId> 
    <scope>test</scope> 
</dependency> 

<dependency> 
    <groupId>commons-lang</groupId> 
    <artifactId>commons-lang</artifactId> 
    <version>2.6</version> 
</dependency> 

<dependency> 
    <groupId>oracle</groupId> 
    <artifactId>ojdbc6</artifactId> 
    <version>11.2.0.3.0</version> 
</dependency> 

<dependency> 
    <groupId>com.netflix.hystrix</groupId> 
    <artifactId>hystrix-core</artifactId> 
    <version>1.4.18</version> 
</dependency> 
<dependency> 
    <groupId>org.perf4j</groupId> 
    <artifactId>perf4j</artifactId> 
    <version>0.9.16</version> 
</dependency> 
<dependency> 
    <groupId>io.reactivex</groupId> 
    <artifactId>rxjava</artifactId> 
    <version>1.0.13</version> 
</dependency> 
<dependency> 
    <groupId>org.springframework</groupId> 
    <artifactId>spring-jdbc</artifactId> 
    <version>4.2.3.RELEASE</version> 
</dependency> 

屬性:

spring.jpa.database=ORACLE 
spring.jpa.show-sql=false 
spring.jpa.hibernate.ddl-auto=validate 

spring.datasource.driverClassName=oracle.jdbc.OracleDriver 
spring.datasource.url=.. 
spring.datasource.username=.. 
spring.datasource.password=.. 

spring.datasource.max-active=20 
spring.datasource.max-idle=5 
spring.datasource.min-idle=1 
spring.datasource.initial-size=5 


spring.datasource.testWhileIdle = true 
spring.datasource.timeBetweenEvictionRunsMillis = 20000 
#spring.datasource.test-on-borrow=true 
spring.datasource.validation-query=select 1 from dual; 

spring.jpa.properties.hibernate.order_inserts=true 
spring.jpa.properties.hibernate.order_updates=true 
spring.jpa.properties.hibernate.jdbc.batch_size=100 
spring.jpa.properties.hibernate.cache.use_second_level_cache=false 
+0

屬性文件包含Oracle。你可以粘貼配置嗎? – abaghel

+0

我包含的屬性在標準模式下使用。我沒有其他屬性。我假設註解@DataJpaTest正在處理內存數據庫中的配置。現在我只覆蓋一個屬性進行測試:spring.jpa.hibernate.ddl-auto = none – mrh

+0

嗯。你能否顯示完整的錯誤日誌? – abaghel

回答

3

這不是目前配置。我有already answered how to create your own slice,我最近寫了a blog post about it

爲什麼JdbcTemplate沒有配置DataJpaTest沒有什麼特別的理由。該註釋的主要用例是測試您的JPA數據層。當你這樣做時,你可能不應該使用JdbcTemplate,但我知道你可能喜歡在你的測試中改變數據庫或其他東西?

我創建了#6802來跟蹤您的請求,請按照更新。

+0

還有另一種用例:測試使用JdbcTemplate的DAO類。這不是JPA測試,但內存數據庫自動配置對於JdbcTemplate DAO測試也非常有用。 –

0

我能夠通過簡單地添加這個文件到測試解決我的問題範圍的包

@Configuration 
public class TestConfig { 
    @Bean 
    public JdbcTemplate getJdbcTemplate(DataSource dataSource) { 
     return new JdbcTemplate(dataSource); 
    } 
}