如何解决为什么 Testcontainers 不使用 application.properties / application.yaml?
在我的 Spring Boot 2.4.3 应用程序中,我使用了 Testcontainers 并按照互联网上的说明进行操作。我有一个application.yaml
:
spring:
datasource:
url: jdbc:tc:postgresql:13.2:///testdb?TC_INITSCRIPT=tc_initscript_postgresql.sql
username: duke
password: s3crEt
jpa:
database-platform: org.hibernate.dialect.PostgreSQL95Dialect
hibernate:
ddl-auto: create-drop
但是当我调试应用程序时,容器总是将“测试”作为 URL、用户名和密码的值。
这是我的测试课:
@ActiveProfiles("test")
@Testcontainers
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
public abstract class AbstractApplicationIT {
final static DockerImageName POSTGRES_IMAGE = DockerImageName.parse("postgres:13.2-alpine");
@Container
// public static GenericContainer postgreSQLContainer = new GenericContainer(POSTGRES_IMAGE)
public static PostgreSQLContainer<?> postgreSQLContainer = new PostgreSQLContainer<>(POSTGRES_IMAGE)
// .withInitScript("tc_initscript_postgresql.sql")
// .withPassword("password")
// .withUsername("username")
// .withDatabaseName("test")
// .withInitScript("tc_initscript_postgresql.sql")
;
// @DynamicPropertySource
// static void postgresqlProperties(DynamicPropertyRegistry registry) {
// registry.add("spring.datasource.url",postgreSQLContainer::getJdbcUrl);
// registry.add("spring.datasource.password",postgreSQLContainer::getPassword);
// registry.add("spring.datasource.username",postgreSQLContainer::getUsername);
// }
@Test
public void contextLoads() {
System.out.println(postgreSQLContainer.getDatabaseName());
System.out.println(postgreSQLContainer.getUsername());
System.out.println(postgreSQLContainer.getPassword());
}
}
系统输出:
测试
测试
测试
...即使不使用 @DynamicPropertySource
。
解决方法
容器不知道 application.properties。
application.properties 为 Spring Boot 配置,与 Testcontainers 无关。
您可以覆盖这样的值
@Container
private PostgreSQLContainer postgresqlContainer = new PostgreSQLContainer()
.withDatabaseName("foo")
.withUsername("foo")
.withPassword("secret");
您还可以像这样从 application.properties 读取值:
@Value("spring.datasource.username")
private String username;
,
Testconainer 可以使用 JDBC support 从您的 spring.datasource.url
派生容器定义。
一个最小的例子如下所示:
@SpringBootTest(properties = {
"spring.datasource.url=jdbc:tc:postgresql:12:///springboot?TC_INITSCRIPT=somepath/init_mysql.sql"
})
class AbstractApplicationIT {
@Autowired
private YourRepository yourRepository;
@Test
@Sql("/scripts/INIT_THREE_ORDERS.sql")
void shouldReturnOrdersThatContainMacBookPro() {
List<Order> orders = yourRepository.findAllContainingMacBookPro();
assertEquals(2,orders.size());
}
}
为此,请勿在测试中手动指定任何其他容器定义。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。