如何在使用了 Spring Boot 和 MyBatis 的应用中使用 Mockito 测试 DAO 层

发布于 2022-09-03 23:59:53 字数 2075 浏览 21 评论 0

在一个web项目的开发中,对于controllerservice的测试,可以利用mockito框架来进行快速的单元测试。每个测试用例都只测试被测方法的功能,而不关系其调用的其他方法的功能是否正确。

@RunWith(MockitoJUnitRunner.class)
public class ActivityControllerTest {

    @Mock
    private ActivityService activitySearcher;

    private ActivityController controller;

    @Before
    public void setUp() throws Exception {
        controller = new ActivityController(activitySearcher);
    }

    @Test
    public void should_return_activity_list() throws Exception {
        List<Activity> activities = new ArrayList<Activity>(3);
        for (int i = 1; i < 4; i++) {
            Activity activity = new Activity();
            activity.setId(i);
            activity.setTitle("activity" + i);
            activity.setCreateTime(1L);
            activity.setEndTime(2L);
            activity.setImg("/img/" + i + ".jpg");
            activities.add(activity);
        }

        int page = 1;
        when(activitySearcher.getList(page)).thenReturn(activities);

        List<Activity> result = controller.getList(page);

        assertThat(result, is(activities));
    }

}

但是对于dao层,因为使用springmybatis整合,所以我只需要写接口就可以完成工作:

@Repository
@Mapper
public interface ActivityDao {

    @Select("select id, title, content, create_time, end_time, img " +
                    "from activity limit #{start}, #{offset}")
    List<Activity> list(@Param("start") int start,
                        @Param("offset") int offset);

    @Insert("insert into activity(title, content, create_time, end_time, img)" +
                    "value (#{title}, #{content}, #{createTime}, #{endTime}, #{img})")
    int addActivity(Activity activity);

}

但是这样,具体的实现就交给了框架完成了。
这时,我仍旧希望能够通过mockito框架来进行测试,模拟出数据库连接和sql执行的结果,我应该用mock创建什么对象呢?
是不是需要找到创建数据库连接和执行sql的类,然后mock出来?
但是我应该怎么去找到这些需要mock的类呢?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

灼痛 2022-09-10 23:59:53

数据库测试没必要使用mock使用spring-test直接连接数据库测试,在单元测试环境中事务会自动回滚,清理测试数据。这样准确性高也简单容易。

肩上的翅膀 2022-09-10 23:59:53

其实连接真实的数据库我一直都认为不是单元测试的行为,而是集成测试,建议可以使用内存数据库H2或是SQLite代替MySQL来完成,内存数据库无需要真实数据库的环境,特别是在持续集成环境,我想在构建前运行单元测试,这种环境如果也需要连接真实的数据库,想想持续集成工程师得有多无助

逐鹿 2022-09-10 23:59:53

题主知道怎么用junit测这个dao层吗?

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文