springboot学习笔记:执行单元测试时,mapper默认扫描路径为启动类的包名

15 篇文章 0 订阅
9 篇文章 0 订阅

环境

springboot:2

前言

情况是这样的:

  1. 对新建的项目,进行模块调整:按照DDD的架构,设计各个module。
  2. 当把启动类Application.java调整包路径后,发现单元测试执行失败;
  3. 调整的具体操作是,将原有的包com.alibaba.模糊.模糊改为com.alibaba.模糊.模糊.start。也就是加了一个start路径。
  4. 然后又将启动类的包路径还原回去后,单元测试执行成功。
  5. 纠结了一下午,加一晚上终于找到原因了。特此记录下。

在这里插入图片描述
当执行单元测试时,会报错,我们看到下图红线处的提示,Mybatis尝试在com.alibaba.模糊.模糊.start这个包下扫描mapper时,在这个包下找不到相关的mapper
在这里插入图片描述
我把红线处的错误,单独贴出来,如下:

o.m.s.mapper.ClassPathMapperScanner : No MyBatis mapper was found in '[com.alibaba.模糊.模糊.start]' package. Please check your configuration.

根据提示,是com.alibaba.模糊.模糊.start这个包路径下,没有找到mapper
但是我的mapper类,本来就不在[com.alibaba.模糊.模糊.start]路径下,该路径是启动类的包路径。
在这里插入图片描述

单元测试mapper扫描的包路径默认是启动类的路径

由上面的情况,我们可以知道:单元测试mapper扫描的包路径默认是启动类的路径
因为我的项目是按照DDD模式,进行模块化的,XxxMapper类,在infrastructure模块中,其包路径是:com.alibaba.模糊.模糊.infrastructure

要解决这个问题,有两种办法:

方法一: 在单元测试里,加@MapperScan指定扫描路径
在这里插入图片描述
即:@MapperScan("com.alibaba.模糊.模糊.infrastructure")

这种改法有个缺点,就是每次单元测试用例都得加,一百个单元测试,得加一百遍。

方法二:在启动类中指定@MapperScan

在这里插入图片描述
即:@MapperScan("com.alibaba.模糊.模糊.infrastructure.模糊.mybatis")

这样就不用每次都在单元测试里面添加了。

加餐

知识背景:

@Mapper及@MapperScan注解是Spring boot Mybatis的注解,并非属于SpringBoot。

所以单独使用@Mapper而不使用@MapperScan是没问题的

这个项目脚手架生成的代码,只使用了@Mapper,并没有在启动类中用@MapperScan
在这里插入图片描述
也就是说,如果你的项目一开始就是在启动类中使用:@MapperScan,那么你都不会遇到这个问题;

总结

单元测试的扫描路径范围默认是和主启动类一致的。即使在application.properties或者test.properties中指定了mybatis.config-location也是没用的:

# mybatis 即使指定了,单元测试也不会用到。
mybatis.config-location=classpath:/mybatis/mybatis-config.xml

需要使用@MapperScan进行指定包路径。

在基于Spring Boot的工程中进行Mapper层的单元测试,可以利用IDEA的goto功能自动生成对应的测试和测试方法,并在生成的测试上加上@SpringBootTest注解,然后执行对应的test方法即可。然而,默认情况下,这样会启动整个Spring Boot应用,包括启动Web容器,导致测试间较长且不够优雅。\[1\] 在执行单元测试,可能会遇到报错,提示找不到相关的Mapper。这是因为MyBatis尝试在启动所在的包路径扫描Mapper,而实际上Mapper可能位于其他模块中的不同包路径下。\[2\] 解决这个问题的方法是,在单元测试上使用@MapperScan注解,指定Mapper所在的包路径。例如,如果Mapper位于infrastructure模块的com.alibaba.模糊.模糊.infrastructure包下,可以在单元测试上加上@MapperScan("com.alibaba.模糊.模糊.infrastructure")注解。这样就能正确扫描Mapper了。\[3\] #### 引用[.reference_title] - *1* [Springboot优雅单元测试mapper的测试(基于mybatis-plus)](https://blog.csdn.net/xiaocy66/article/details/126716098)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [springboot学习笔记执行单元测试mapper默认扫描路径启动包名](https://blog.csdn.net/u013066244/article/details/123099207)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山鬼谣me

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值