【发布时间】:2017-01-25 05:59:12
【问题描述】:
这是我的 spring-boot 应用程序的 DbConfig。
@Configuration
@EnableTransactionManagement
public class DBConfig
{
@Bean
public LocalSessionFactoryBean sessionFactory()
{
....
}
@Bean
public DataSource aaDataSource()
{
.....
}
public PlatformTransactionManager transactionManager()
{
....
}
private Properties hibernateProperties()
{
....
}
}
这是我的测试课
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = Application.class)
@WebAppConfiguration
public class ApplicationTests {
@Test
public void contextLoads() {
}
}
这是一个 gradle 项目。
当我在本地运行 gradlew clean build 时,我会成功构建,因为我在 application.properties 中的连接设置与我的 sql 连接匹配。
但是当我在我们的 qa 环境(数据库是 qa one)中从 jenkins box 运行时,构建失败并出现以下异常。
java.lang.IllegalStateException: Failed to load ApplicationContext
....
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaAutoConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean]: Factory method 'entityManagerFactory' threw exception; nested exception is com.zaxxer.hikari.pool.PoolInitializationException: Exception during pool initialization
at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:599)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1123)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1018)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(Abstract
.....
Caused by: com.zaxxer.hikari.pool.PoolInitializationException: Exception during pool initialization
at com.zaxxer.hikari.pool.BaseHikariPool.initializeConnections(BaseHikariPool.java:544)
at com.zaxxer.hikari.pool.BaseHikariPool.<init>(BaseHikariPool.java:171)
at com.zaxxer.hikari.pool.HikariPool.<init>(HikariPool.java:60)
at com.zaxxer.hikari.pool.HikariPool.<init>(HikariPool.java:48)
.....
Caused by: java.sql.SQLException: Access denied for user 'admin1'@'localhost' (using password: YES)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:998)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3835)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3771)
我尝试在具有 qa db 设置的 src/main/resources/ 中使用 application-qa.properties 运行 gradlew clean build -Dspring.profiles.active=qa。构建仍然失败,出现同样的异常。
我有两个选择。
运行构建跳过数据源 bean 创建。我仍然需要运行我的单元测试,因为它们不依赖数据源
或将正确的设置传递给 gradle build 以便创建应用程序上下文。
我更喜欢第二个选项来让它工作
【问题讨论】:
-
请检查您的 MySql 连接。在 pom.xml 中的 spring boot maven 插件中添加配置文件。在
application.properties文件spring.profile.active 中设置您的活动配置文件。为什么不运行测试目标,只运行测试类呢?
标签: spring-mvc gradle spring-boot spring-test