gpt4 book ai didi

postgresql - 检查 TestContainers 的内容

转载 作者:行者123 更新时间:2023-12-02 20:41:29 25 4
gpt4 key购买 nike

我正在使用 PostgreSQL TestContainer 来测试 Spring Boot 中的 Liquibase 架构迁移。我没有任何存储库。我想知道我是否可以查看/访问 TestContainer 的内容,并测试架构迁移。

最佳答案

是的,您可以像访问任何其他 Docker 容器一样访问由 Testcontainers 生成的 Docker 容器。但是,对 Testcontainers 使用 JUnit 5 扩展或 JUnit 4 规则将在测试后关闭容器。

您可以使用 coontainer re-usability feature用于测试容器(自 1.12.3 以来处于 alpha 状态),用于确保您的容器在测试完成后启动并运行。

由于 Testcontainers 将在临时端口上启动容器,只需执行 docker ps 并检查容器端口映射到哪个本地端口。例如:

b0df4733babb        postgres:9.6.12      "docker-entrypoint.s…"   19 seconds ago      Up 18 seconds       0.0.0.0:32778->5432/tcp   inspiring_dewdney

您现在可以连接到 localhost:32778 上的数据库,例如PgAdmin 或 IntelliJ IDEA 的数据库 View 并检查您的数据库表。

访问凭据是您在测试中指定的凭据:

static PostgreSQLContainer postgreSQLContainer = (PostgreSQLContainer) new PostgreSQLContainer()
.withDatabaseName("differentDatabaseName")
.withUsername("duke")
.withPassword("s3cret")
.withReuse(true);

作为一种解决方法,您还可以在测试结束时设置断点、调试测试并快速检查您的数据库。

更新:如果您想验证架构的有效性,您可以为此使用 Hibernate 功能:

spring.jpa.hibernate.ddl-auto=validate

这将验证您的 Java 实体设置是否与应用程序启动时的底层数据库架构匹配。您还可以将此添加到您的生产 application.properties 文件中,因为如果存在不匹配(例如缺少表、列),您的应用程序将无法启动。

为了在测试中工作,您需要使用 @DataJpaTest 或使用 @SpringBootTest 将整个应用程序上下文连接到本地容器。

查找更多信息here .

关于postgresql - 检查 TestContainers 的内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63182498/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com