mock数据,不使用springboot的单元测试

业务代码

java 复制代码
package com.haier.configure.service.impl;

import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.haier.common.util.RequestUtil;
import com.haier.configure.entity.LanguageTableDO;
import com.haier.configure.mapper.LanguageTableMapper;
import com.haier.configure.service.LanguageTableService;
import com.haier.configure.util.CheckDataUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;

import java.util.List;

/**
 * @author A2001111
 * @date 2024/4/3010:24
 */
@Slf4j
@Service
public class LanguageTableServiceImpl extends ServiceImpl<LanguageTableMapper, LanguageTableDO> implements LanguageTableService {

    @Override
    public void test1() {
        System.out.println("业务1...");
        String appId = RequestUtil.getAppId();
        System.out.println("appid:"+appId);
        System.out.println("第一次调用-----");
        List<LanguageTableDO> list = this.list(Wrappers.lambdaQuery(LanguageTableDO.class).eq(LanguageTableDO::getId, 1));
        for (LanguageTableDO languageTableDO : list) {
            System.out.println("循环结果1:"+languageTableDO.getChineseName());
        }

        System.out.println("第二次调用-----");
        List<LanguageTableDO> list2 = this.list(Wrappers.lambdaQuery(LanguageTableDO.class).eq(LanguageTableDO::getId, 1));
        for (LanguageTableDO languageTableDO : list2) {
            System.out.println("循环结果2:"+languageTableDO.getChineseName());
        }

        System.out.println("第3次调用-----");
        List<LanguageTableDO> list3 = this.list(Wrappers.lambdaQuery(LanguageTableDO.class).eq(LanguageTableDO::getId, 1));
        for (LanguageTableDO languageTableDO : list3) {
            System.out.println("循环结果3:"+languageTableDO.getChineseName());
        }

        System.out.println("业务2...");
    }


}

需要mock静态方法RequestUtil.getAppId(),需要mock成员方法this.list(lambdaQuery);

java 复制代码
/**
 * @author A2001111
 * @date 2024/9/30 9:07
 */
package com.haier.configure.service.impl;

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.haier.common.util.RequestUtil;
import com.haier.configure.entity.LanguageTableDO;
import com.haier.configure.mapper.LanguageTableMapper;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.mockito.*;
import org.mockito.junit.jupiter.MockitoSettings;
import org.mockito.quality.Strictness;

import java.util.ArrayList;
import java.util.List;

import static org.mockito.Mockito.any;
import static org.mockito.Mockito.when;

@MockitoSettings(strictness = Strictness.LENIENT)
class LanguageTableServiceImplTest<M extends LanguageTableMapper> {
    @InjectMocks
    @Spy
    private LanguageTableServiceImpl languageTableServiceImpl;
    @Mock
    private M mapper;

    private AutoCloseable mockitoCloseable;

    @BeforeEach
    void setUp() throws Exception {
        mockitoCloseable = MockitoAnnotations.openMocks(this);
    }

    @AfterEach
    void tearDown() throws Exception {
        mockitoCloseable.close();
    }

    @Test
    void test_getAllList_should_return_not_null_when_condition() throws Exception {
        // mock静态
        MockedStatic<RequestUtil> requestUtilMockedStatic = Mockito.mockStatic(RequestUtil.class);
        requestUtilMockedStatic.when(RequestUtil::getAppId).thenReturn("假数据哦");
        // setup
        LanguageTableDO languageTableDO = new LanguageTableDO();
        languageTableDO.setId(111L);
        languageTableDO.setCode("code");
        languageTableDO.setEnglishName("englishName111");
        languageTableDO.setChineseName("chineseName111");
        List<LanguageTableDO> list = new ArrayList<>();
        list.add(languageTableDO);

        LanguageTableDO languageTableDO2 = new LanguageTableDO();
        languageTableDO2.setId(222L);
        languageTableDO2.setCode("code");
        languageTableDO2.setEnglishName("englishName222");
        languageTableDO2.setChineseName("chineseName222");
        List<LanguageTableDO> list2 = new ArrayList<>();
        list2.add(languageTableDO2);

        // when(mapper.selectList(any(LambdaQueryWrapper.class))).thenReturn(list);
        // 也可以设置多次调用返回不同的结果,比如:第一次返回list,第二次返回list2,后续多次调用,都返回list2
        when(mapper.selectList(any(LambdaQueryWrapper.class)))
                .thenReturn(list)
                .thenReturn(list2);
        // run the test
        languageTableServiceImpl.test1();
        System.out.println("完毕");
    }


}
相关推荐
爱码少年1 小时前
springboot中责任链模式之简单应用
spring boot·责任链模式
苹果酱05671 小时前
「Mysql优化大师一」mysql服务性能剖析工具
java·vue.js·spring boot·mysql·课程设计
武昌库里写JAVA1 小时前
【MySQL】7.0 入门学习(七)——MySQL基本指令:帮助、清除输入、查询等
spring boot·spring·毕业设计·layui·课程设计
刘大辉在路上4 小时前
突发!!!GitLab停止为中国大陆、港澳地区提供服务,60天内需迁移账号否则将被删除
git·后端·gitlab·版本管理·源代码管理
星蓝_starblue5 小时前
单元测试(UT,C++版)经验总结(gtest+gmock)
单元测试
栗子~~5 小时前
集成 jacoco 插件,查看单元测试覆盖率
缓存·单元测试·log4j
追逐时光者6 小时前
免费、简单、直观的数据库设计工具和 SQL 生成器
后端·mysql
初晴~6 小时前
【Redis分布式锁】高并发场景下秒杀业务的实现思路(集群模式)
java·数据库·redis·分布式·后端·spring·
盖世英雄酱581366 小时前
InnoDB 的页分裂和页合并
数据库·后端