- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我编写了这个包含自定义查询的存储库:
@Repository
interface PersonRepository : JpaRepository<Person, UUID> {
@Query("UPDATE Person SET firstname = :firstname, lastname = :lastname WHERE id IN :ids")
@Modifying
fun updateNames(firstname: String, lastname: String, ids: List<UUID>) : Int
}
并为其实现了以下测试:
@DataJpaTest
@AutoConfigureTestDatabase(replace = NONE)
internal class PersonRepositoryIntegrationTest {
@Autowired
lateinit var personRepository: PersonRepository
@Test
@Commit
fun updateNames() {
// GIVEN
// insert some records
personRepository.save(Person(UUID.randomUUID(), "Homer", "Simpson"))
personRepository.save(Person(UUID.randomUUID(), "Bart", "Simpson"))
personRepository.save(Person(UUID.randomUUID(), "Marge", "Simpson"))
// read back the ids and assert lastname before updating
val readBeforeUpdate = personRepository.findAll()
assertTrue(readBeforeUpdate.isNotEmpty())
assertTrue(readBeforeUpdate.all { it.lastname == "Simpson" })
val ids = readBeforeUpdate.map { it.id }
// WHEN
val count = personRepository.updateNames("John", "Doe", ids)
personRepository.flush()
// THEN
assertEquals(3, count)
val readAfterUpdate = personRepository.findAll()
println(readAfterUpdate)
assertEquals(3, readAfterUpdate.size)
assertTrue(readAfterUpdate.all { it.firstname == "John" && it.lastname == "Doe" })
}
}
在最后一行失败,验证所做的更改,例如名字和姓氏。我添加了 @Commit
来防止自动回滚 spring 会做,这样我就可以在之后检查数据。我可以在数据库中看到更改后的名称,所以看起来我的查询有效。我怀疑 val readAfterUpdate = personRepository.findAll()
要么是
personRepository.updateNames
不同的事务中执行,还不能“看到”其他事务的更改personRepository.findAll()
从Hibernate的缓存什么的返回我在这里错过了什么?如何使测试工作?或者还有什么方法可以检查数据库中的数据是否确实发生了更改?
展示该行为的示例项目可在 https://github.com/timbuethe/SpringBootDataTest 获得。
最佳答案
我认为使用 @Modifiying
会使持久性上下文过时,所以也许添加 (clearAutomatically = true)
可以解决问题
关于spring - 如何使用@DataJpaTest 测试我的自定义 JPA 查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72128645/
我试图找出为什么我的单元测试不起作用。我看到 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
我是一名优秀的程序员,十分优秀!