首页 > 其他分享 >@DataJpaTest 进行测试的坑

@DataJpaTest 进行测试的坑

时间:2022-08-26 02:04:43浏览次数:74  
标签:数据库 默认 DataJpaTest 测试 使用 注解 主键 进行

@DataJpaTest 这个注解主要用来在 Spring 项目中测试 JPA 数据源。

默认情况下,带有 @DataJpaTest 注解的测试使用嵌入式内存数据库。

因此 @DataJpaTest 这个注解还是有点坑的。

默认数据库

默认采用的是嵌入的 H2 数据库。

就算你配置了数据库链接,如果你不使用下面的注解的话,@DataJpaTest 还是会使用配置的默认数据库。

使用注解:

@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)

来让你的程序只使用你提供的数据库连接来进行连接。

事务

@DataJpaTest 具有事务性,会自动回滚插入数据。

如果你的不进行配置的话,你会发现你插入的数据没有办法在数据库中出现。

解决办法就是在方法中,提供 @Commit 注解。

2022-08-25_08-21-32

然后再对数据库中的数据进行校验,这个时候数据是不会回滚的。

从日志中,我们也可以看到,插入的数据被回滚了。

 

2022-08-25_08-22-17

 

当我们提供 Commit 这个注释后,在日志中明确的提示已经提交了。

 

2022-08-25_08-23-40

 

表 hibernate_sequence

这是因为我们在数据库实体类配置的时候,没有指定主键策略。

在默认情况使用的是 Auto。

如果使用 Auto,Hibernate 将会使用 Oracle 的方式来自增的。

如果需要使用 Mysql 的话,你的实体类需要将主键策略修改为:

@GeneratedValue(strategy = GenerationType.IDENTITY)

因为我们实体类使用了继承 AbstractPersistable。

 

2022-08-25_08-27-28

 

因此我们可以通过修改 application.properties 来实现。

将参数设置为 false

spring.jpa.hibernate.use-new-id-generator-mappings=false

 

2022-08-25_08-28-14

 

这样就会对主键的策略进行修改了,我们就可以避免上面的这个问题了。

 

https://www.ossez.com/t/datajpatest/14070

标签:数据库,默认,DataJpaTest,测试,使用,注解,主键,进行
From: https://www.cnblogs.com/huyuchengus/p/16626318.html

相关文章

  • Spring Data 测试时的 Repository 提示为空对象
    错误信息如下:java.lang.NullPointerException atcom.usvisatrack.common.data.tests.jpa.UserRepositoryTest.testInsert(UserRepositoryTest.java:57) atjava.base/j......
  • 性能测试学习笔记——工具的使用,性能测试流程
    性能测试学习笔记一、为什么要做性能测试:因为功能和接口测试只能验证软件的功能是否正常运行,功能和接口测试不能验证软件的性能在多用户,多并发,长时间的操作下,能否正常运......
  • 四、Spring Cloud Alibaba项目,测试模块之生产者与消费者
    1、模块说明生产者:service-order消费者:service-user说明:消费者user调用生产者order,调用订单服务 2、生产者pom文件<?xmlversion="1.0"encoding="UTF-8"?><proj......
  • tidb oom测试
    #准备测试数据:sysbench--config-file=config_newoltp_common.lua--tables=3--table-size=500000prepare#执行语句explainanalyzeselecta.c,b.c,c.pad fromsb......
  • 3 敏捷测试思维方式
     敏捷测试与传统测试之间的区别,不仅在于测试的独立性、阶段性、计划性、自动化测试等多个方面有很大的不同,而且更大的区别是在测试原则和测试思维模式(TestMindset,也可翻......
  • 将 SAP Spartacus 作为 feature module 进行 Lazy Load 延迟加载时遇到的注入错误分析
    将SAPSpartacus作为featuremodule进行LazyLoad延迟加载时,遇到如下错误:ERRORError:Uncaught(inpromise):NullInjectorError:R3InjectorError(CatalogModu......
  • 系统测试问题汇总
    我们这个系统测试要学习哪些内容?软件工程的基本概念什么是软件?什么是测试?如何理解软件测试?软件测试岗位有哪里?软件的发展历史是什么?什么是......
  • 测试 SAP 电商云 Spartacus UI 3.4.x 和 4.3.x 的 guest checkout 功能
    按照这个链接的步骤安装。新建一个Angular应用,取名mystore,待所有package安装完毕后:ngnewmystore--style=scss进入mystore文件夹,使用命令行:ngadd@spartacus......
  • 传统测试与敏捷测试对比
     本文的内容是通过一个例子来全面比较一下传统测试与敏捷测试的区别,这个例子来自一本书——《凤凰项目:一个IT运维的传奇故事》。这是由美国的三位DevOps专家撰写的一......
  • NIG-AP:自动化渗透测试的新方法
    目录NIG-AP:自动化渗透测试的新方法一、摘要二、背景知识介绍三、算法实现四、实验评估五、总结文章信息NIG-AP:自动化渗透测试的新方法一、摘要本文提出了一种NIG-AP信......