小编典典

测试时使用数据源进行Spring Boot

spring-boot

我正在使用Spring Boot应用程序,并且启用了自动配置功能。主应用程序文件标记为@EnableAutoConfiguration。使用java
config从JNDI查找数据源,并将创建数据源的类标记为@Configuration

我有一个如下的测试课。

@RunWith( SpringJUnit4ClassRunner.class )
@WebAppConfiguration
@ContextConfiguration( classes = Application.class )
public class TestSomeBusiness {}

问题是,当我运行测试用例时,会发生数据源jndi查找,因为测试用例不在服务器环境中运行,所以失败。据我所知,classpath中标记为的类@Configuration已执行,并且数据源查找被调用的原因。

我现在发现的解决方法是使用而不是JNDI查找来创建数据源DriverManagerDataSource,这样,即使它不是服务器环境,数据源查找也不会失败。

我的问题是:

1)在Spring Boot应用程序中进行测试时,我们通常如何处理数据源(从JNDI查找时)?

2)有没有一种方法可以在执行测试用例时从调用中排除数据源配置类?

3)我是否应该创建一个嵌入式服务器,以便在执行测试用例时可以完成JNDI查找?


阅读 354

收藏
2020-05-30

共1个答案

小编典典

2)有没有一种方法可以在执行测试用例时从调用中排除数据源配置类?

您可以在您的application.properties配置文件中添加一个配置文件src/test/resources,Spring
Boot会在测试环境中选择这些配置。我想,您application.properties的情况src/main/resources如下:

spring.datasource.jndi-name=some_jndi

JNDI资源将在您的生产环境中使用。对于您的测试环境,可以通过将以下配置添加到测试中来使用MySQL数据库application.properties

spring.datasource.url=jdbc:mysql://localhost/test
spring.datasource.username=dbuser
spring.datasource.password=dbpass
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

3)我是否应该创建一个嵌入式服务器,以便在执行测试用例时可以完成JNDI查找?

如我所说,JNDI通过添加测试特定的配置,您可以完全绕开您用于生产的事实。

1)在Spring Boot应用程序中进行测试时,我们通常如何处理数据源(从JNDI查找时)?

您可以JNDI使用org.springframework.mock.jndi软件包中提供的功能来模拟资源。例如,通过使用SimpleNamingContextBuilder您可以:

SimpleNamingContextBuilder builder = new SimpleNamingContextBuilder();
builder.bind("jndi_name", dataSource);
builder.activate();

当然,另一个选择是Non JNDI在测试环境中使用资源。

2020-05-30