繁体   English   中英

在Spring Boot中的同一个pom.xml中管理H2和Postgres

[英]Manage H2 and Postgres in same pom.xml in Spring Boot

我正在使用Spring Boot开发一个微服务应用程序。 我的应用程序将用于生产配置Postgres DB和Spring Boot自动测试H2 DB。 因此,我的pom.xml包含两个依赖项(H2 + Postgres)。 我尝试将H2依赖关系与tes范围相关联,Postgres与运行时关联如下:

        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <scope>test</scope>
        </dependency>

我可以看到运行mvn测试时 ,Spring Boot默认选择postgres数据库,这在我的单元测试环境中不存在。 这就是为什么我更喜欢使用H2来运行单元测试的原因。

有没有一种正确的方法来告诉spring boot使用H2进行测试而Postgres使用其他方法?

我不知道是否使用不同的application.properties文件(一个在src / main / resources中,另一个在src / test / resources中)可以解决问题。

您应该知道有多个类路径,例如:

  1. 编译时类路径,
  2. 运行时类路径,
  3. 测试类路径。

当您使用<scope>runtime</scope> ,依赖项将在运行时类路径中作为测试类路径使用 ,如文档所述

此范围表示编译不需要依赖项,但是用于执行。 它位于运行时和测试类路径中,但不是编译类路径。

这意味着即使在执行测试时,如果使用<scope>runtime</scope> ,Postgres仍会在您的类路径上。


通过提供两个单独的application.properties ,您提到的解决方案是正确的选择。

src/main/resources/application.properties ,您可以像这样配置数据源:

spring.datasource.url=jdbc:postgresql://localhost:5432/mydatabase

src/test/resources/application.properties ,您可以像这样配置数据源:

spring.datasource.url=jdbc:h2:mydatabase

如果需要更细粒度的控件,可以使用Spring配置文件。 例如,您可以使用名为“testdb”的配置文件,然后使用@ActiveProfiles("testdb")注释您的测试。

现在,您可以创建一个名为application-testdb.properties的文件,并添加设置测试数据库所需的属性。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM