使用jMock辅助单元测试

2024-01-18 00:08

本文主要是介绍使用jMock辅助单元测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用jMock辅助单元测试

作者:冰云
时间:
2004-04-16
联系:
icecloud(AT)sina.com
Bloghttp://icecloud.51.net

jMock是Junit的一个增强库。源于http://www.jmock.org。

jMock简单易用,非常适合TDD中的Mock测试模式

首先我们来看一段简单测试代码

package name.nona.test.jmock;

import java.sql.SQLException;

import java.sql.Statement;

import org.jmock.Mock;

import org.jmock.MockObjectTestCase;

public class TestUsageOfJmock extends MockObjectTestCase {

    public void testDatabaseUseage() throws SQLException{

        Mock mockStmt = new Mock(Statement.class);

        String sql = "select * from test";

 

        mockStmt.expect(once()).method("execute")

.with(eq(sql)).will(returnValue(false));

        Statement stmt = (Statement) mockStmt.proxy();

        assertFalse(stmt.execute(sql));

      }

}

可以看到,上面是制作了一个假的(Mock)的Statement对象,

通过对这个对象的execute操作,返回一个false值。

 

其中,关键的语句是

mockStmt.expect(once()).method("execute").with(eq(sql)).will(returnValue(false));

解释如下:

       expect: 期待的执行次数,可以有 onceatLeastOnce()notCalled()三种。

       method 期待调用的方法名,这里是execute

       with 方法需要的参数,如果没有的话就不用写with,直接will

       will 返回值,没有就不写啦

       其中的once, eq, returnValue都是继承自MockObjectTestCase的方法。

 

    执行后,Green,成功。尝试两次调用 assertFalse(stmt.execute(sql));  提示错误。

    

     jMock是通过CGLIB的DynamicProxy来实现的mock功能。

 

   

    注:本文仅是对jMock的一个简单介绍,没有太多内容。更多的东西需要你自己来探索,例如jMock的设计很有意思,使用了ValueObject模式等等。
   
如果对Jmock有兴趣,请访问http://www.jmock.org。 你可以下载最新的jMock包来使用,可能在接口上有些不同,但基本的调用已经定型不变(如上)。

    1.0stable的版本正在开发中,帮助很少,通过看JavaDoc和testCase你可以了解到最新的用法。

 

    


版权声明:
本文由冰云完成,首发于CSDN,作者保留中文版权。
未经许可,不得使用于任何商业用途。
欢迎转载,但请保持文章及版权声明完整。
如需联络请发邮件:icecloud(AT)sina.com
Blog:http://icecloud.51.net
 




这篇关于使用jMock辅助单元测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/617593

相关文章

Java Jackson核心注解使用详解

《JavaJackson核心注解使用详解》:本文主要介绍JavaJackson核心注解的使用,​​Jackson核心注解​​用于控制Java对象与JSON之间的序列化、反序列化行为,简化字段映射... 目录前言一、@jsonProperty-指定JSON字段名二、@JsonIgnore-忽略字段三、@Jso

MySQL中隔离级别的使用详解

《MySQL中隔离级别的使用详解》:本文主要介绍MySQL中隔离级别的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录引言undo log的作用MVCC的实现有以下几个重要因素如何根据这些因素判断数据值?可重复读和已提交读区别?串行化隔离级别的实现幻读和可

使用Python和SQLAlchemy实现高效的邮件发送系统

《使用Python和SQLAlchemy实现高效的邮件发送系统》在现代Web应用中,邮件通知是不可或缺的功能之一,无论是订单确认、文件处理结果通知,还是系统告警,邮件都是最常用的通信方式之一,本文将详... 目录引言1. 需求分析2. 数据库设计2.1 User 表(存储用户信息)2.2 CustomerO

9个SpringBoot中的自带实用过滤器使用详解

《9个SpringBoot中的自带实用过滤器使用详解》在SpringBoot应用中,过滤器(Filter)是处理HTTP请求和响应的重要组件,SpringBoot自带了许多实用的过滤器,如字符编码,跨... 目录1. CharacterEncodingFilter - 字符编码过滤器功能和配置手动配置示例2

Redis持久化机制之RDB与AOF的使用

《Redis持久化机制之RDB与AOF的使用》:本文主要介绍Redis持久化机制之RDB与AOF的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Redis持久化机制-RDB与AOF一、RDB持久化机制1、RDB简介2、RDB的工作原理3、RDB的优缺点4

使用Python实现实时金价监控并自动提醒功能

《使用Python实现实时金价监控并自动提醒功能》在日常投资中,很多朋友喜欢在一些平台买点黄金,低买高卖赚点小差价,但黄金价格实时波动频繁,总是盯着手机太累了,于是我用Python写了一个实时金价监控... 目录工具能干啥?手把手教你用1、先装好这些"食材"2、代码实现讲解1. 用户输入参数2. 设置无头浏

Spring Boot 常用注解详解与使用最佳实践建议

《SpringBoot常用注解详解与使用最佳实践建议》:本文主要介绍SpringBoot常用注解详解与使用最佳实践建议,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、核心启动注解1. @SpringBootApplication2. @EnableAutoConfi

mysql递归查询语法WITH RECURSIVE的使用

《mysql递归查询语法WITHRECURSIVE的使用》本文主要介绍了mysql递归查询语法WITHRECURSIVE的使用,WITHRECURSIVE用于执行递归查询,特别适合处理层级结构或递归... 目录基本语法结构:关键部分解析:递归查询的工作流程:示例:员工与经理的层级关系解释:示例:树形结构的数

Redis中RedisSearch使用及应用场景

《Redis中RedisSearch使用及应用场景》RedisSearch是一个强大的全文搜索和索引模块,可以为Redis添加高效的搜索功能,下面就来介绍一下RedisSearch使用及应用场景,感兴... 目录1. RedisSearch的基本概念2. RedisSearch的核心功能(1) 创建索引(2

Redis中HyperLogLog的使用小结

《Redis中HyperLogLog的使用小结》Redis的HyperLogLog是一种概率性数据结构,用于统计唯一元素的数量(基数),本文主要介绍了Redis中HyperLogLog的使用小结,感兴... 目录 一、HyperlogLog 是什么?️ 二、使用方法1. 添加数据2. 查询基数China编程3.