- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试使用注释 @DataJpaTest 编写集成测试。
我有两个数据源:主要和次要(类配置)
结果我有一个错误:
expected single matching bean but found 2: primaryDataSource,secondary
@AutoConfigureTestDatabase(replace= AutoConfigureTestDatabase.Replace.AUTO_CONFIGURED)
Dialect : HHH000400: Using dialect: org.hibernate.dialect.Oracle10gDialect
@DataJpaTest
有多个数据源?
public class DataSourcesConfig {
@Bean
@Primary
@ConfigurationProperties(prefix="spring.datasource")
public DataSource primaryDataSource() {
return DataSourceBuilder.create().build();
}
@Bean(name = "secondary")
@ConfigurationProperties(prefix="datasource.secondary")
public DataSource secondaryDataSource() {
return DataSourceBuilder.create().build();
}
}
最佳答案
找到可能的解决方案 here .
基本上,您可以适本地手动配置 H2 数据库,而不是让 Spring 自动进行配置。
在“src/test/resources”中创建一个application.properties文件,内容如下
# Let Spring autodetect the different SQL Dialects of each datasource
spring.jpa.database=default
# Generate the DB schema in the In-Memory H2 databases based on the JPA Entities
spring.jpa.generate-ddl=true
# H2 In-Memory Database "foo" (used in tests instead of a real PostgreSQL DB)
spring.datasource.url=jdbc:h2:mem:foo;DB_CLOSE_ON_EXIT=FALSE
spring.datasource.username=sa
spring.datasource.password=
spring.datasource.driver-class-name=org.h2.Driver
# H2 In-Memory Database "bar" (used in tests instead of a real PostgreSQL DB)
bar.datasource.url=jdbc:h2:mem:bar;DB_CLOSE_ON_EXIT=FALSE
bar.datasource.username=sa
bar.datasource.password=
bar.datasource.driver-class-name=org.h2.Driver
关于spring-boot - 如何将@DataJpaTest 与多个数据源一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47471969/
我试图找出为什么我的单元测试不起作用。我看到 Hibernate 在更新之前做了一个插入。 为什么这样做? 是测试失败的原因吗? 我已经为测试环境设置了 hsqldb,该服务在 mysql 中似乎运行
我有一个使用 Spring Boot 的中等大小的项目,我正在尝试创建我的第一个带有嵌入式 H2 的 DataJpaTest,但我收到以下异常: org.hibernate.tool.schema.s
我有一个名为 TagRepository 的 spring-data-jpa 存储库。我的 spring-boot 版本是 2.1.2。我在运行时范围内使用 H2 依赖项,我打算将它用于应用程序和集成
在一个SpringBoot应用中,我想对repository层做一些测试。 @RunWith(SpringRunner.class) @DataJpaTest public class VisitRe
我有一个 Employee具有以下列的实体: @Entity class Employee { @Column(name = "first_name", length = 14) privat
默认 @DataJpaTest扫描所有 jpa 存储库和 @Entity .就我而言,我有 5 个存储库包和 5 个实体包。例如 com.acme.product.entity与....关联com.a
让我们假设一个自定义基础 JpaRepository实现如下。 public class SimpleCustomJpaRepository extends SimpleJpaRepository i
在 Windows (+ Maven) 上,我对 Métro 词的 é 有疑问。我的 sql 文件是用 UTF-8 编码的。我在 Unix 服务器上确实遇到了这个问题。 我的 Maven 错误: ex
我正在尝试使用 Spring @DataJpaTest 注释创建存储库测试。即使是简单的演示项目,我也会收到 IllegalArgumentException: Unknown entity。我错过了
我想用 Spring Boot 测试一个存储库,并想包含 TestEntityManager 来检查存储库是否真的做了它应该做的事情。 那是 JUnit 测试: @RunWith(SpringRunn
我正在尝试使用 @DataJpaTest 设置我的数据库单元测试注释以避免加载完整的 Spring 应用程序上下文。但它的执行方式与我使用 @SpringBootTest 时的方式不同。 + 配置的
我尝试使用注释 @DataJpaTest 编写集成测试。 我有两个数据源:主要和次要(类配置) 结果我有一个错误: expected single matching bean but found 2:
我正在使用 SpringBoot/Kotlin/JPA/Hibernate/Junit 并拥有 JpaServiceTest 类来执行与单个实体相关的存储库方法。 JpaService 类的方法名称遵
我使用@DataJpaTest 注释创建了一个测试。 hsqldb 已配置,但出现错误: No qualifying bean of type [org.springframework.jdbc.co
我编写了这个包含自定义查询的存储库: @Repository interface PersonRepository : JpaRepository { @Query("UPDATE Perso
我想将测试容器与 @DataJpaTest 一起使用(和 @SpringBootTest )使用 JUnit 5。我使用 @Testcontainers 进行基本设置工作和 @Container像这样
我在数据层中有几个实体以特定的架构存储。例如: @Entity @Table(name = "FOO", schema = "DUMMY") public class Foo {} 我正在尝试设置H2
我想使用 Controller 和存储库通过 Spring Boot 上下文配置创建完整的 JUnit 测试。我的测试类如下所示: @RunWith(SpringRunner.class) @Spri
Spring boot @DataJpaTest exclude filter donsn't work 我见过这个问题,但就我而言,他的方法不起作用。 我必须使用存储过程从 SQL 服务器检索数据,
我正在从 spring-boot 1.5.x 迁移到 2.0.4,并注意到 @DataJpaTest 的一个有趣的案例/行为 我有一个测试 @ExtendWith(SpringExtension.cl
我是一名优秀的程序员,十分优秀!