@DataJpaTest 进行测试的坑
@DataJpaTest 这个注解主要用来在 Spring 项目中测试 JPA 数据源。
默认情况下,带有 @DataJpaTest 注解的测试使用嵌入式内存数据库。
因此 @DataJpaTest 这个注解还是有点坑的。
默认数据库
默认采用的是嵌入的 H2 数据库。
就算你配置了数据库链接,如果你不使用下面的注解的话,@DataJpaTest 还是会使用配置的默认数据库。
使用注解:
@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)
来让你的程序只使用你提供的数据库连接来进行连接。
事务
@DataJpaTest 具有事务性,会自动回滚插入数据。
如果你的不进行配置的话,你会发现你插入的数据没有办法在数据库中出现。
解决办法就是在方法中,提供 @Commit 注解。
然后再对数据库中的数据进行校验,这个时候数据是不会回滚的。
从日志中,我们也可以看到,插入的数据被回滚了。
当我们提供 Commit 这个注释后,在日志中明确的提示已经提交了。
表 hibernate_sequence
这是因为我们在数据库实体类配置的时候,没有指定主键策略。
在默认情况使用的是 Auto。
如果使用 Auto,Hibernate 将会使用 Oracle 的方式来自增的。
如果需要使用 Mysql 的话,你的实体类需要将主键策略修改为:
@GeneratedValue(strategy = GenerationType.IDENTITY)
因为我们实体类使用了继承 AbstractPersistable。
因此我们可以通过修改 application.properties 来实现。
将参数设置为 false
spring.jpa.hibernate.use-new-id-generator-mappings=false
这样就会对主键的策略进行修改了,我们就可以避免上面的这个问题了。
相关文章
- 测试需要做单元测试吗?
- 同步测试
- unixbench分析_燕青: Unixbench 测试套件缺陷深度分析
- jmeter5.x与beanShell[测试专题]
- 使用THPC进行NAS Parallel BenchMark高性能基准测试
- 使用 ab 进行压力测试遇到 "Connection reset by peer"
- 测试用 - 4.使用eBPF逃逸容器技术分析与实践
- 实战|一次对企业内部系统的渗透测试
- 使用JMeter进行MySQL的压力测试
- 不懂运维的程序员不是好测试
- 【rainbowzhou 面试8/101】技术提问--如何进行大数据基准测试?
- linux安装和测试php的方法
- 测试节点对客户站点缓存状态的脚本详解程序员
- 掌握linux:从基础命令测试开始(测试常用linux命令)
- 利用Redis进行可靠性测试的工具(redis测试工具)
- 无人驾驶将在高速道路进行场景测试?百度Apollo获首批资质
- 治疗COVID-19的几种新型抗病毒药物目前正在进行人体测试
- 如何进行Linux内存压力测试?(linux内存压力测试)
- 如何进行 Linux 下的磁盘 IO 测试(linux磁盘io测试)
- 测试连接MSSQL数据库:全面指南(测试连接mssql数据库)
- 使用SoapUI轻松进行Linux应用程序测试(soapuilinux)
- 用PHP进行MySQL功能测试(php 测试mysql)
- 利用redis进行性能测试一次有效的实验经验(性能测试数据库redis)
- 深入测试Redis的连接性能(测试redis连接)
- 压力测试下的Redis表现优异(压力测试redis)
- 快速简单以Redis配置测试工具来进行测试(redis配置测试工具)