`
wuhua
  • 浏览: 2110519 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

用easymock测试jdbc

阅读更多
     虽然以前用easymock测试过Dao,但那些Dao的实现,要么就hibernate,要么就用spring,而这两个框架的执行正确与否我们是不用关心的。JDBC是不是也这样测试了。答案是肯定的。
      这几天要用存储过程跟jdbc来做个项目,想想也有好长一段时间没用过JDBC来做项目了。该复习复习了。
      前阵子学了easymock,真好现在可以派上用场了。不过在测试的过程中还是遇到了不小问题,想来是自己基础不好的缘故。

       这次不TDD了,太麻烦了。
       先看看我们要测试的代码
     
java 代码
 
  1. CallableStatementcstmt = null;  
  2.         try {  
  3.             cstmt = _conn.prepareCall("{call LUCK_LOAD_COMMON(?,?)}");  
  4.             cstmt.setString(1"1");  
  5.             cstmt.registerOutParameter(2, java.sql.Types.VARCHAR);  
  6.   
  7.             cstmt.executeUpdate();  
  8.             return cstmt.getString(2);  
  9.   
  10.         } catch (Exception e) {  
  11.             GxDebug.logException(e);  
  12.             e.printStackTrace();  
  13.             return null;  
  14.         } finally {  
  15.             if (cstmt != null)  
  16.                 try {  
  17.                     cstmt.close();  
  18.                 } catch (Exception e) {  
  19.             }  
  20.         }  
  代码还挺长的。从上面的代码我们知道我们必须mock两个对象进去。一个是Connection, 一个是CallableStatementcstmt 。
好再看看我们的测试代码
java 代码
  1. conn.prepareCall("{call LUCK_LOAD_COMMON(?,?)}");  
  2.     conControl.setReturnValue(cstmt);  
  3.     conControl.replay();  
  4.       
  5.     cstmt.setString(1"1");  
  6.     cstmt.registerOutParameter(2, java.sql.Types.VARCHAR);  
  7.     cstmt.executeUpdate();  
  8.     cstmtControl.setReturnValue(1);  
  9.     cstmt.getString(2);  
  10.     cstmtControl.setReturnValue("5,4,3");  
  11.     cstmt.close();  
  12.     cstmtControl.replay();  
  13.       
  14.       
  15.     String rusult = dao.getNumber();  
  16.     Assert.assertEquals("5,4,3", rusult);  
  17.       
  18.     conControl.verify();  
  19.     cstmtControl.verify();  

oh,my got!测试代码比实现代码还要多。这段代码能执行吗?
我想可以的。easymock的原理是记录-回放的模式。
我想要做的工作是:
1,记录你mock对象的工作记录,比如上面的代码我们mock对象的工作记录是:
java 代码
  1. conn.prepareCall("{call LUCK_LOAD_COMMON(?,?)}");  
  2.         conControl.setReturnValue(cstmt);  
  3.         cstmt.setString(1"1");  
  4.         cstmt.registerOutParameter(2, java.sql.Types.VARCHAR);  
  5.         cstmt.executeUpdate();  
  6.         cstmtControl.setReturnValue(1);  
  7.         cstmt.getString(2);  
  8.         cstmtControl.setReturnValue("5,4,3");  
  9.         cstmt.close();  
  10.   

 如果你工作记录的代码要求有返回值的话,那么你必须提供一个自定义的值给它,否则会报错。比如上面的
  •  cstmt.getString(2);  
  •         cstmtControl.setReturnValue("5,4,3");   //自己定义的返回值,用作以后的比较。

  • 上面的是记录操作,回放的时候,easymock会把记录的操作跟你实际的代码进行比较,如果里面出了什么差错,那么不好意思你的代码有问题,请修正后再测试。

    如果有兴趣可以自己试下。
    分享到:
    评论
    6 楼 123456 2007-07-11  
         
    5 楼 123456 2007-07-11  
    4 楼 sun113 2007-06-02  
    写这个东西确实费时间,不过想想以后能自动测试找到错误,还不错咯,想在这个项目的过程中试一下,我是刚学的!
    3 楼 klyuan 2006-12-30  
    dao层应该进行集成式的测试,就是有一个真实的环境!否则就跟不测一样的
    2 楼 wuhua 2006-12-20  
    现在我总算是对ribbon说对于数据库的测试还是真实环境的好。
    因为你测试的时候你不知道存储过程是否正确。
    而且如果用真实的数据库测试,相对与mock测试,则简洁很多。而且清晰很多。
    上面只是在比较少逻辑的时候测试,如果代码逻辑复杂,我觉得写出来的测试代码会更复杂,这有引出,可能维护测试代码的工作比维护代码的工作更累
    1 楼 wuhua 2006-12-20  
    比如如果您
    conn.prepareCall("{call LUCK_LOAD_COMMON(?,?)}");
    修改为
    conn.prepareCall("{call LUCK_LOAD_COMMON(?,?,?)}");
    则出现的异常是:
    junit.framework.AssertionFailedError:
      Unexpected method call prepareCall("{call LUCK_LOAD_COMMON(?,?)}"):
        prepareCall("{call LUCK_LOAD_COMMON(?,?)}"): expected: 0, actual: 1
        prepareCall("{call LUCK_LOAD_COMMON(?,?,?)}"): expected: 1, actual: 0

    相关推荐

      基于JavaScript的线上车位销售系统源码+sql数据库+项目说明.zip

      基于JavaScript的线上车位销售系统源码+sql数据库+项目说明.zip 【资源介绍】 IDEA开发,JAVA编写,SSM框架 ...测试工具使用了Junit、Easymock 对每个service层和controller层的函数各进行了一次黑盒测试和白盒测试

      spring依赖包讲解.doc

      测试方面,EasyMock(easymock.jar和easymockclassextension.jar)是Spring测试套件的一部分,但只在构建和运行测试时需要,不随应用发布。FreeMarker(freemarker.jar)是Spring支持的模板引擎之一,如果你的应用...

      ConnectionMother Unit test for JDBC-开源

      Connection Mother 是 JAVA 的一个简单框架,它促进了 JDBC 的单元测试。 它依赖于 EasyMock 框架来模拟连接。 它基于 ObjectMother 的模式,该模式隐藏了构建假数据库连接的复杂性。

      java常用Jar包

      EasyMock是一个模拟测试框架,它允许开发者创建和控制对象的行为,以便进行单元测试。通过EasyMock,可以轻松地模拟依赖对象,从而专注于测试目标代码的行为,而不是整个系统。 5. **Ehcache** Ehcache是一个广泛...

      即时到账 Java Demo.zip

      JUnit是Java中常用的单元测试框架,可以用于测试单个方法的功能。Mockito或EasyMock等库则可以帮助模拟依赖,以便进行隔离测试。对于整个支付流程的测试,可能需要用到像Selenium这样的工具来进行端到端的集成测试。...

      spring框架各jar包详解

      Spring 的测试套件用到了 EasyMock,因此只有构建和运行测试套件时才用到这个 JAR,无需随你的应用一起发布。 freemarkerfreemaker.jar Spring 提供了 FreeMarker 模板引擎的包装类,还为把 FreeMarker 模板用作 ...

      Spring包的依赖关系

      若使用JDBC或其他ORM工具如Hibernate或JDO,则无需包含它们。 ### 13. iText - **JAR文件**: itext-1.02b.jar - **说明**: Spring通过iText提供web层的PDF支持。仅当web应用需要生成PDF输出时,才需包含此JAR文件...

      spring3.0包文件

      10. **测试框架**:Spring 3.0改进了测试支持,提供Mockito和EasyMock集成,使得单元测试和集成测试更加便捷。 这些只是Spring 3.0框架中的一部分关键特性。通过下载的`spring-framework-3.0.0.RELEASE`压缩包,...

      spring 3.2 帮助文档

      Spring TestContext框架可以帮助开发者配置和管理测试环境,而Mockito和EasyMock等库的集成则简化了模拟对象的创建。 7. **模块化**:Spring 3.2进一步加强了模块化,使得开发者可以根据项目需求选择引入必要的模块...

      spring-framework-4.0.3.RELEASE

      它提供了Mockito和EasyMock的集成,使得创建测试桩变得简单。此外,Spring TestContext Framework可以自动配置Spring容器,使得集成测试变得更加便捷。 六、与其他技术的兼容性 Spring 4.0.3.RELEASE对Java EE 7有...

      Spring3.0xMVC jar包关系

      如果你使用JDBC或其他ORM工具,例如Hibernate或JDO,则无需包含这些文件。 13. **iText** - **JAR文件**:itext-1.02b.jar - **说明**:Spring使用iText提供Web层的PDF支持。只有当你的Web应用需要生成PDF输出时...

      spring3.0轻量级框架

      Spring Test模块提供了全面的单元测试和集成测试支持,包括Mockito和EasyMock的集成,以及对Web应用的模拟测试。 十、其他改进 Spring 3.0还增强了对Groovy的支持,允许使用Groovy脚本作为配置。此外,对Java EE 6...

      spring-framework-3.2.17.RELEASE-dist.zip

      3.2.17版加强了Mockito和EasyMock的集成,使得测试更便捷。 9. **国际化支持** Spring 3.2.17包含对i18n(国际化)的支持,通过MessageSource接口,开发者可以轻松地实现多语言环境的应用。 10. **安全性集成** ...

      jTester使用指南(带书签).pdf

      通常这样的例子会包括创建一个测试类,并使用 TestNG 的注解来定义测试方法。 - **示例代码**: ```java import org.testng.annotations.Test; import com.jtester.junit.Assert; public class SimpleTest { @...

      J2EE 学习计划J2EE 学习计划J2EE 学习计划J2EE 学习计划

      熟练掌握JDBC API(如`DriverManager`、`Connection`、`PreparedStatement`、`ResultSet`等)的使用方法,对于实现数据的增删改查等基本操作至关重要。这将帮助开发者更加灵活地与各种关系型数据库进行交互。 ### ...

      Webgisedo

      使用JUnit或TestNG进行单元测试,Mockito或EasyMock进行模拟测试,以及Spring Boot的@SpringBootTest注解进行集成测试,这些都是保证代码质量的重要手段。 综上所述,Webgisedo是一个围绕Java Web开发的项目,可能...

      个人英文简历模板resume

      - **测试工具**:JUnit、JUnit Perf、EasyMock、JMock、FIT、Fitnesse、DBFit、Selenium、JMeter、JAMon。 - **持续集成工具**:CruiseControl、Hudson。 - **项目管理工具**:VersionOne、JIRA、Bugzilla、...

    Global site tag (gtag.js) - Google Analytics