Mockito Mybatis-plus 单元测试

1. mock Mybatis-plus 自带 ServiceImpl方法问题

  • 分析

    mybatis-plus 自带的ServiceImpl,其实其最后执行使用的是我们所创建的Mapper,他最终会注入到 ServiceImpl的baseMapper中
    - 示例

    1. 业务代码

      java 复制代码
      // 实体
      public class UtilSaleData {
      }
      
      // mapper
      public interface UtilSaleDataMapper extends BaseMapper<UtilSaleData> {
      }
      // service
      public class UtilSaleDataServiceImpl extends ServiceImpl<UtilSaleDataMapper, UtilSaleData> implements UtilSaleDataService {
          @Override
          public List<UtilSaleData> selectSaleDataList(String id) {
              LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<UtilSaleData>()
                      .eq(StringUtils.isNotBlank(id), UtilSaleData::getId, id);
              return list(queryWrapper);
          }
    2. 测试代码

      java 复制代码
      	@RunWith(MockitoJUnitRunner.class) // 使用Mockito运行器
      	public class MockTest {
      	    @InjectMocks // 被测对象
      	    private UtilSaleDataServiceImpl productService;
      	    
      	    @Mock // mock模拟对象依赖注入
      	    private UtilSaleDataMapper mapper;
      	    
      	    @Test 
      	    public void findProductByIdTest2() {
      	        List<UtilSaleData> list = new ArrayList<>();
      	        UtilSaleData utilSaleData = new UtilSaleData();
      	        utilSaleData.setId("22222");
      	        list.add(utilSaleData);
      	        // 模拟结果 selectList 结果
      	        Mockito.when(mapper.selectList(any())).thenReturn(list);
      	        List<UtilSaleData> list1 = productService.selectSaleDataList("1");
      	        System.out.println(list1);
      	    }
      	
      	}
      	```
    3. 依赖

      xml 复制代码
              <dependency>
                  <groupId>org.mockito</groupId>
                  <artifactId>mockito-core</artifactId>
                  <version>3.7.7</version>
                  <scope>test</scope>
              </dependency>
  • 解释

    我想要mock的方法是selectSaleDataList方法里面的 list(queryWrapper)方法结果,使其不调用数据库,但是list实际调用的是mapper的selectList方式,所以上面mock时用的是Mockito.when(mapper.selectList(any())).thenReturn(list)

相关推荐
设计师小聂!14 小时前
尚庭公寓----------分页查询
java·开发语言·spring·maven·mybatis
秋秋棠20 小时前
MyBatis延迟加载(Lazy Loading)之“关联查询”深度解析与实践
java·mybatis
一个快乐的小测试1 天前
JUnit-自动化测试框架
java·junit·单元测试·自动化
秋秋棠1 天前
MyBatis级联查询深度解析:一对多关联实战指南
jvm·tomcat·mybatis
hello 早上好2 天前
MyBatis 动态 SQL、#{}与 ${}区别、与 Hibernate区别、延迟加载、优势、XML映射关系
sql·mybatis·hibernate
长路 ㅤ   2 天前
Java单元测试JUnit
junit·单元测试·springboot·注解·断言
我命由我123452 天前
Spring Boot - Spring Boot 集成 MyBatis 分页实现 手写 SQL 分页
java·spring boot·后端·sql·spring·java-ee·mybatis
艺杯羹2 天前
MyBatis 之分页四式传参与聚合、主键操作全解
java·开发语言·maven·mybatis
设计师小聂!2 天前
尚庭公寓-----day1 业务功能实现
java·ide·spring·maven·mybatis
郑州吴彦祖7722 天前
Mybatis的SQL编写—XML方式
java·sql·spring·mybatis