文章列表
 
2009-06-20 7:09
博客搬新家了,网址是http://www.daniel-journey.com/ RSS的地址是http://feed.feedsky.com/imlearningimthinking
欢迎大家在新空间中跟我交流
 
2009-06-18 5:23
    最近一直都在思考应该说是迷茫自己的接下来3-4年要走的路,是留在目前的公司发展,保存一份稳定的收入呢,还是多冒一点的风险去一家小公司发展,代价就是这两年的工资都会被降很多。想离开现有公司的主要原因是自己搞了很长时间的企业软件开发做的都是一些类似CRM的东西,在目前的公司也是继续这样的工作,从自己心底愿望上讲看好中国互联网的发展,想有机会自己也建立和运营这样的一个网站。但目前无论技术上和管理上都没有相应的知识和经验的积累。去小公司就可以有这样的机会,而在现在的公司只能做一些技术方面的研究了,苦恼ing......。另外,下定决心购买自己的域名和blog空间,会在新空间上继续自己的blog。
 
2009-06-10 13:13
由于博客搬家到了http://www.daniel-journey.com/ 该文章页被搬到新的地址http://www.daniel-journey.com/archives/73   
为什么要编写单元测试?原因是单元测试有不少的优点,能够给我们的工作带来很大的帮助。
单元测试的优点

    1.帮助开发人员编写代码,提升质量、减少bug。如果大家分析一下我们bug原因的构成,我想有会有一部分bug的原因是开发人员在编写工作代码的时候没有考虑到某些case或者边际条件。造成这种问题的原因很多,其中很重要的一个原因是我们对工作代码所要完成的功能思考不足,而编写单元测试,特别是先写单元测试再写工作代码就可以帮助开发人员思考编写的代码到底要实现哪些功能。例如实现一个简单的用户注册功能的业务类方法,用单元测试再写工作代码的方式来工作的话
      开发人员就会先考虑各种场景相关,例如正常注册、用户名重复、没有满足必要的填写内容......等等,之后就会编写相关的测试用例

      public Class UserSerivceTest(){
          public userRegister_Ok(){
              ......
          }

          public userRegister_nameDuplicated(){
              ......
          }

          public userRegister_emailEmpty(){
              ......
          }
      }

      编写单元测试代码的过程就是促使开发人员思考工作代码实现内容和逻辑的过程,之后实现工作代码的时候,开发人员思路会更清晰,实现代码的质量也会有相应的提升。

    2. 提升反馈速度,减少重复工作,提高开发效率。开发人员实现某个功能或者修补了某个bug,如果有相应的单元测试支持的话,开发人员可以马上通过运行单元测试来验证之前完成的代码是否正确,而不需要反复通过发布war包、启动jboss、通过浏览器输入数据等繁琐的步骤来验证所完成的功能。用单元测试代码来验证代码和通过发布应用以人工的方式来验证代码这两者的效率差很多,看到很多开发人员每天要反复执行N次发布脚本(antx之类的工具)真是痛苦。
    3.保证你最后的代码修改不会破坏之前代码的功能。项目越做越大,代码越来越多,特别涉及到一些公用接口之类的代码或是底层的基础库,谁也不敢保证这次修改的代码不会破坏之前的功能,所以与此相关的需求会被搁置或推迟,由于不敢改进代码,代码也变得越来越难以维护,质量也越来越差。而单元测试就是解决这种问题的很好方法(不敢说最好的)。由于代码的历史功能都有相应的单元测试保证,修改了某些代码以后,通过运行相关的单元测试就可以验证出新调整的功能是否有影响到之前的功能。当然要实现到这种程度需要很大的付出,不但要能够达到比较高的测试覆盖率,而且单元测试代码的编写质量也要有保证。

    4. 让代码维护更容易。由于给代码写很多单元测试,相当于给代码加上了规格说明书,开发人员通过读单元测试代码也能够帮助开发人员理解现有代码。很有opensource的项目都有相当量的单元测试代码,通过读这些测试代码会有助于理解生产源代码。

    5. 有助于改进代码质量和设计。除了那些大拿们编写的代码,我相信很多易于维护、设计良好的代码都是通过不断的重构才得到的。虽然说单元测试本身不能直接改进生产代码的质量,但它为生产代码提供了"安全网",让开发人员可以勇敢地改进代码,从而让代码的clean和beautiful不再是梦想。

单元测试的缺点

    1.单元测试的学习成本比较高。编写单元测试涉及的技术很多,如果只是单纯的使用Junit或是TestNG这样的基础单元测试框架往往很难应对各种复杂的单元测试情况,所以势必要借助很多第三方的框架和技术(easymock,jmock,dbunit等等),这些框架和技术的学习还是会增加学习的成本和难度。
    2.编写单元测试会增加程序员工作量。单元测试跟生产代码是一样的,并不会应为是用来测试的就有所不同,开发人员同样要面对测试代码的编写、维护等工作,也同样要面对避免重复代码等一系列问题,能否写出好的测试代码还是取决于开发人员的设计和编码能力。
    3. 推广和运用单元测试需要比较大的投入。只有在每个开发人员都编写了足够的、质量好的单元测试代码,大家才能真正享受到单元测试带给我们的好处。在达到这种层度以前,还需要不少实现和资源的投入。

总结

   虽然单元测试也有一些缺点和负面的效应,但跟单元测试的优点比较起来,为了克服和解决这些缺点所在的付出是值得的。

相关文章
单元测试的基本概念
推荐一个优秀的Java单元测试框架——JTester
关于《单元测试的七种境界》的自我总结
 
2009-06-10 9:42
   这几天在准备一个给部门内部的单元测试的介绍,所以想说明一些单元测试的基本概念。google了一下,发现一篇整理了不错的文章《单元测试的基本概念》,所以直接转载了,原文内容如下。
  
    要减少软件中的错误数目,方法之一就是拥有一个专业的测试组,其工作就是尽一切可能使软件崩溃。不幸的是,如果拥有测试组,那么即使是经验丰富的开发人员,也会倾向于花费较少的时间来保证代码的可靠性。

    软件界有一句俗语:“开发人员不应该测试他们自己的代码”。这是因为开发人员对自己的代码了如指掌,他们很清楚如何采用适当的方法对代码进行测试。尽管这 句俗语很有道理,但却忽略了非常重要的一点 - 如果开发人员不对自己的代码进行测试,又如何知道代码能否按照预期的方式运行?

    简单说来,他们根本无从得知。开发人员编写那种运行不正常或只在某些情况下运行正常的代码是一个严重的问题。他们通常只测试代码能否在很少的情况下正常运行,而不是验证代码能够在所有情况下均正常运行。

    发现软件错误的情况有很多:

    1.由首次编写代码的开发人员发现。
    2.由尝试运行代码的开发人员发现。
    3.由组中的其他开发人员或测试人员发现。
    4.作为产品大规模测试的一部分。
    5.由最终用户发现。

    如果在第一种情况下发现软件错误,则修复错误比较容易,成本也很低。情况越靠后,修复软件错误的成本就越高;修复一个由最终用户发现的软件错误可能要耗费 100 或 1000 倍的成本。更不用说用户通常因为软件错误导致工作无法继续,而一直等到下一个版本才能解决问题。
    如果开发人员能够在编写代码期间发现所有的软件错误,那就再好不过了。为此,您必须编写能在编写代码时运行的测试。

    测试是软件开发的重要环节之一。按照软件开发的过程测试可分为:单元测试、功能测试、性能测试、性能测试、集成测试、系统测试、域测试(Field test)等。我们这里将主要研究的是面向程序员的单元测试。

    什么是单元测试

    单元测试是开发者编写的一小段代码,用于检验被测代码中的一个很明确的功能是否正确。通常而言,一个单元测试是用于判断某个特定条件(或者场景)下某个特 定函数的行为。例如,你可能把一个很大的值放入一个有序list 中去,然后确认该值出现在list 的尾部。或者,你可能会从字符串中删除匹配某种模式的字符,然后确认字符串确实不再包含这些字符了。

    单元测试是由程序员自己来完成,最终受益的也是程序员自己。可以这么说,程序员有责任编写功能代码,同时也就有责任为自己的代码编写单元测试。执行单元测试,就是为了证明这段代码的行为和我们期望的一致。

    为什么要使用单元测试

    我们编写代码时,一定会反复调试保证它能够编译通过。如果是编译没有通过的代码,没有任何人会愿意交付给自己的客户。但代码通过编译,只是说明了它的语法正确;我们却无法保证它的语义也一定正确,没有任何人可以轻易承诺这段代码的行为一定是正确的。

    幸运,单元测试会为我们的承诺做保证。编写单元测试就是用来验证这段代码的行为是否与我们期望的一致。有了单元测试,我们可以自信的交付自己的代码,而没有任何的后顾之忧。

    单元测试有下面的这些优点:

    1、它是一种验证行为。

    程序中的每一项功能都是测试来验证它的正确性。它为以后的开发提供支缓。就算是开发后期,我们也可以轻松的增加功能或更改程序结构,而不用担心这个过程中会破坏重要的东西。而且它为代码的重构提供了保障。这样,我们就可以更自由的对程序进行改进。

    2、它是一种设计行为。

    编写单元测试将使我们从调用者观察、思考。特别是先写测试(test-first),迫使我们把程序设计成易于调用和可测试的,即迫使我们解除软件中的耦合。

    3、它是一种编写文档的行为。

    单元测试是一种无价的文档,它是展示函数或类如何使用的最佳文档。这份文档是可编译、可运行的,并且它保持最新,永远与代码同步。

    4、它具有回归性。

    自动化的单元测试避免了代码出现回归,编写完成之后,可以随时随地的快速运行测试。

    单元测试的范畴

    如果要给单元测试定义一个明确的范畴,指出哪些功能是属于单元测试,这似乎很难。但下面讨论的四个问题,基本上可以说明单元测试的范畴,单元测试所要做的工作。

    1、 它的行为和我期望的一致吗?

    这是单元测试最根本的目的,我们就是用单元测试的代码来证明它所做的就是我们所期望的。

    2、 它的行为一直和我期望的一致吗?

    编写单元测试,如果只测试代码的一条正确路径,让它正确走一遍,并不算是真正的完成。软件开发是一个项复杂的工程,在测试某段代码的行为是否和你的期望一 致时,你需要确认:在任何情况下,这段代码是否都和你的期望一致;譬如参数很可疑、硬盘没有剩余空间、缓冲区溢出、网络掉线的时候。

    3、 我可以依赖单元测试吗?

    不能依赖的代码是没有多大用处的。既然单元测试是用来保证代码的正确性,那么单元测试也一定要值得依赖。

    4、 单元测试说明我的意图了吗?

    单元测试能够帮我们充分了解代码的用法,从效果上而言,单元测试就像是能执行的文档,说明了在你用各种条件调用代码时,你所能期望这段代码完成的功能。

    不写测试的借口

    到这里,我们已经知道了使用单元测试的种种理由。但目前的实际情况是大多数程序员不进行单元测试,或只进行简单的单元测试。下面是一些他们常用的接口:

    1、 编写单元测试太花时间了。

    我们知道,在开发时越早发现BUG,就能节省更多的时间,降低更多的风险。如果你仍然认为在编写产品代码的时候,还是没有时间编写测试代码,那么请先考虑下面这些问题:

    1)、对于所编写的代码,你在调试上面花了多少时间。
    2)、对于以前你自认为正确的代码,而实际上这些代码却存在重大的bug,你花了多少时间在重新确认这些代码上面。
    3)、对于一个别人报告的bug,你花了多少时间才找出导致这个bug 的源码位置。
    回答完这些问题,你一定不再以“太花时间”作为拒绝单元测试的借口。

    2、 运行测试的时间太长了。

    合适的测试是不会让这种情况发生的。实际上,大多数测试的执行都是非常快的,因此你在几秒之内就可以运行成千上万个测试。但是有时某些测试会花费很长的时间。这时,需要把这些耗时的测试和其他测试分开。通常可以每天运行这种测试一次,或者几天一次。

    3、 测试代码并不是我的工作。

    你的工作就是保证代码能够正确的完成你的行为,恰恰相反,测试代码正是你不可缺少的工作。

    4、 我并不清楚代码的行为,所以也就无从测试。

    如果你实在不清楚代码的行为,那么估计现在并不是编码的时候。如果你并不知道代码的行为,那么你又如何知道你编写的代码是正确的呢?

    5、 但是这些代码都能够编译通过。

    我们前面已经说过,代码通过编译只是验证它的语法通过。但并不能保证它的行为就一定正确。

    6、 公司请我来是为了写代码,而不是写测试。

    公司付给你薪水是为了让你编写产品代码,而单元测试大体上是一个工具,是一个和编辑器、开发环境、编译器等处于同一位置的工具。

    7、 如果我让测试员或者QA(Quality Assurance)人员没有工作,那么我会觉得很内疚。

    你并不需要担心这些。请记住,我们在此只是谈论单元测试,而它只是一种针对源码的、低层次的,为程序员而设计的测试。在整个项目中,还有其他的很多测试需要这些人来完成,如:功能测试、验收测试、性能测试、环境测试、有效性测试、正确性测试、正规分析等等。

    8、 我的公司并不会让我在真实系统中运行单元测试。

    我们所讨论的只是针对开发者的单元测试。也就是说,如果你可以在其他的环境下(例如在正式的产品系统中)运行这些测试的话,那么它们就不再是单元测试,而是其他类型的测试了。实际上,你可以在你的本机运行单元测试,使用你自己的数据库。

    总而言之,单元测试会让我们的开发工作变得更加轻松,让我们对自己的代码更加自信。无论是大型项目还是小型项目,无论是时间紧迫的项目还是时间宽裕的项目,只要代码不是一次写完永不改动,编写单元测试就一定超值,它已成为我们编码不可缺少的一部分。

其他相关资料

Unit testing

 
2009-06-03 12:49
   依照wiki.ubuntu.org.cn上的申请Ubuntu免费光盘的全程指导 申请了Ubuntu9.04的光盘。接下来就是等待光盘了,说是要4-6周才能送到。另外Ubuntu9.04硬盘安装的方法网上也有,地址如下 http://tech.ccidnet.com/art/302/20090424/1750209_1.html 这个安装方法我试过OK的!
  
 
2009-06-02 9:03
   google真是个有钱的主,通过google可以免费订阅短信天气预报。订阅网址为http://www.google.com/sms/alerts。不爽的地方这个短信天气预报服务需要每个月底去激活下个月的订阅,比较麻烦。
  
 
2009-06-01 18:29
JTester简介
1、在unitils的基础,集成了jmock功能。
2、在hamcrest断言的基础上,实现了fluent interface断言。
3、改造了jmock expectation参数断言为fluent interface形式
4、提供了将普通的pojo对象序列化到文件,然后再从文件中反序列化回来的功能,用于在对象复杂的情况下,直接录制接口(远程接口)调用返回的对象,以供下次测试或调试使用。
5、使用wiki代替xml来准备测试数据。
6、实现了更加丰富的断言。
7、提供了hibernate annotation环境下,直接使用内存数据库进行db测试。
8、提供了hibernate annotation环境下,Open Test in Session的实现。

   熟悉Java单元测试的同学应该能体会到对Java程序如果只是单纯的使用Junit或是TestNG这样的基础单元测试框架往往很难应对各种复杂的单元测试情况,所以势必要借助很多第三方的框架和技术(easymock,jmock,dbunit等等)。而这些框架和技术的学习又会增加学习的成本和难度,所以有人在这些java基础单元测试的工具基础上开发一些测试框架(如unitils)将多种Java单元测试技术整合在一起,提高开发效率。JTester的目的也是一样,在作者精心的开发和维护的基础上,已经拥有了强大的功能和稳定的质量。希望对Java的单元测试技术感兴趣的同学能加以使用,对JTester有功能需求的同学可以跟作者 Darui.wu 或者我联系

相关资料
项目主页http://code.google.com/p/java-tester/
 
2009-05-29 8:07
    平时习惯用mht保存在网上找到的一些网页资料(都是借助IE),最近把操作系统更换成了Ubuntu, 需要用Firefox来保存和打开mht,原生的firefox不支持mht,可已经有热心的同学开发了相应的插件使firefox也可以支持mht.
什么是mht
   mht又叫“web单一文件”也就是将网页中包含的图片,CSS文件以及HTML文件全部放到一个MHT文件里面。mht就是mono html,就是独立的HTML文件,在浏览器特别是IE在save as时将页面中所有可以收集的元素全部存放在一个页面里。

Firefox支持mht吗
   微软的IE6+原生就可以很好的支持mht,而firefox必须要借助 UnMHT 扩展才能处理mht,   UnMHT 项目主页。
安装完毕以后,firefox就会出现以下的内容,OK搞定

 
2009-05-28 21:03
文章内容迁移到了 http://www.daniel-journey.com/archives/182
moreUnit是一个Eclipse的插件,为编写Java的单元测试提供了很多辅助的功能,提高了编写和管理Java单元测试(Junit或者TestNG)的效率。主要的功能有以下几点
1.标志出哪些类是有单元测试支持的。
2.标志出那些方法是有单元测试支持的。
3.对类或者方法的名称进行重命名的时候会相应的重命名单元测试中的名称。
4.移动类的时候moreUnit会相应的移动单元测试类。
5.在工作类和测试类之间通过快捷方式实现(Ctrl+J)快速跳转,这个功能真是很方便

moreUnit的安装、配置和使用都很简单,moreUnit的文档也都配有截图,这里就不在做特别的说明了。提供链接,大家直接到项目网站上去看吧,moreUnit文档链接


相关资源
moreUnit
 
2009-05-28 13:22
   小时候端午的活动比较多,记忆最深的就是要吃粽子、佩香囊和额上点雄黄。随着时代的发展传统的风俗在一点点的消失,而且“端午”这个传统的中国节日居然被某个小国申请成了自己的世界遗产,国人真是要认真思考如何保存、发展我们的优秀历史和文化。
吃粽子

  
   点雄黄
  
配香囊
 
2009-05-27 15:17
   很多开发Oracle数据库应用的同学都喜欢使用PLSQL Developer,今天在开发存储过程的时候试用了一下PLSQL Developer的重构(refactoring)功能,修改的代码没有仔细check就提交QA MM测试了。谁知简单的Extract global constant功能都会失败,不知道这个功能是怎么通过QA的测试从而交付的。
   注:我使用的PLSQL Developer的版本是7.1.0。
 
2009-05-26 11:02
   看了electrictoolbox上对PHP,MYSQL,Javascript几种语言关于取整数的专题,也就依样画葫芦整理了Oracle的取整函数说明,这就是本文的由来。

FLOOR——对给定的数字取整数位
SQL> select floor(2345.67) from dual;

FLOOR(2345.67)
--------------
2345

CEIL-- 返回大于或等于给出数字的最小整数
SQL> select ceil(3.1415927) from dual;

CEIL(3.1415927)
---------------
              4

ROUND——按照指定的精度进行四舍五入
SQL> select round(3.1415926,4) from dual;

ROUND(3.1415926,4)
------------------
            3.1416

TRUNC——按照指定的精度进行截取一个数
SQL> select trunc(3.1415926,4) from dual;

ROUND(3.1415926,4)
------------------
            3.1415
相关资源
Rounding numbers with PHP
Rounding numbers with MySQL
Rounding numbers with Javascript
 
2009-05-25 21:11

该博客以及搬迁至http://www.daniel-journey.com/ 该文的新地址为http://www.daniel-journey.com/archives/72

BeanUtils的copyProperties方法用来orig中的成员变量的值复制给dest,即将已经存在的dest变为orig的副本
    public void copyProperties(Object dest, Object orig) {
   .......
   }

      BeanUtils的populate方法用来将Map<Key,value>中的以值(String或String[])转换到目标bean对应的属性中,Map中的Key是目标bean的属性名。
   public static void populate(Object bean, Map properties){
        ......
    }

copyProperties同样支持了populate中的功能(apache的javadoc中,明确指明这个方法是为解析http请求参数特别定义和使用的,在正常的使用中不推荐使用.他们推荐使用BeanUtils.copyProperties方法)。

BeanUtils.copyProperties和populate的实现方法是将源bean(也可以是Map)中的每个element在转换器(Converter)的帮助下,将转换的结果设置到目标bean对应的属性中。例如在HTTP应用中需要从http request中抽取数据,http request传递过来的都是String 或是String数组类型的变量而目标类型可能是各种各样的,例如http request会有一个name=visitDate,value='2009-05-13'的参数,而目标bean 的visitDate属性的类型是java.util.Date。
       BeanUtils的copyProperties和populate需要在转换器(converter)的配合下实现源和目标对象之间的数据类型的转换。在BeanUtils.copyProperties的javadoc中说明的(Copy property values from the origin bean to the destination bean for all cases where the property names are the same—— 只要属性名相同就可以从源bean中拷贝值到目标bean中)这句话提供到功能就是要通过转换器才能实现的。在BeanUtils的copyProperties和populate的使用过程中Converter是一个非常重要的概念,它提供了强大的扩展能力。  
    /****************************************************************/
        public interface Converter {
           public Object convert(Class type, Object value);
        }
     /****************************************************************/
    
    convert方法的参数type是目标转换的类型,参数value是被转换的值,返回值就是转换以后的结果。当有需要自定义或扩展的Converter 的时候可以通过注册自定义的转换器来实现,例如Beanutil自带的DateConverter不支持String到java.util.Date的转换,通过扩展DateConverter就可以实现支持。需要特别注意的是Converter 是注册在classloader一级的,也就是说在一个class loader中同一时间只能有一个转换器起作用(BeanUtils的copyProperties和populate会依据目标bean属性的类型来决定启用那个转换器),我之前的项目中就有因为其他模块中在特定的时候会重新注册了某个类型的转换器,而新注册的转换器又没有支持我所需要的转换,从而导致在我的模块中出现NPE。 所以在使用BeanUtils.populate和copyProperties的时候要注意以下几点:

1. 只在系统初始化的时候注册一个转换器,而不要在某个功能的执行过程中注册转换器。
       2. 转换器要能够支持项目各个模块的使用需求
       3. 谨慎使用或者思考一下
BeanUtils.populate和copyProperties是你想要的方法吗?

在我使用BeanUtils.populate的模块中本意是实现bean和Map的属性拷贝并不需要类型和值的转换。至于说为什么会使用BeanUtils.populate完全是被它支持Map所误导,其实PropertyUtilsBean.copyProperties和 BeanUtils.copyProperties同样支持Map。就我想要实现的功能而言通过PropertyUtilsBean.copyProperties方法能更好地满足。PropertyUtilsBean.copyProperties方法不会有类型转换的逻辑,所以需要程序员自己保证目标和源Bean属性间的兼容性,也正因为如此PropertyUtilsBean.copyProperties的执行效率更高。

参考资料

BeanUtils.copyProperties与PropertyUtils.copyProperties用法及区别l

http://commons.apache.org/beanutils/v1.8.0/apidocs/org/apache/commons/beanutils/PropertyUtilsBean.html

http://commons.apache.org/beanutils/v1.8.0/apidocs/org/apache/commons/beanutils/BeanUtils.html

初用apache.commons.beanutils.BeanUtils

 
2009-05-24 16:48
   一直以为TestNG才有参数化测试解决方案,不想在看了Parameterising JUnit tests 的文章以才知道JUnit4中也提供了参数化测试的功能,于是简单的学习了一下。
   什么是参数化测试?
   很多时候一个方法的实现需要支持多种Case或者说从测试的角度来看需要测试多种边际条件。例如一个字符串大小写转换的函数需要实现把employee_info这样以“_”分隔的字符串转换成相应的大写字母开头的字符串EmployeeInfo。针对这样的实现方法进行单元测试就需要考虑支持测试多种情况:
    1.测试空字符串
    2.测试一般处理情况
    3.测试尾字母大写的情况.......
    4.处理Null
    5......
    在不使用参数化测试方法的情况下,我们需要针对各种情况编写assert:
    1. assertEquals(“”,“”);
    2.assertEquals("EmployeeInfo","employee_info");
3. assertEquals("EmployeeInfoA","employee_info_a");
    4.assertEquals(null,null);
    5......
   这种解决方式是不是感到有很多重复,而参数化测试就是解决这种情况的绝好方法。
   下面来介绍一下参数化测试的开发方式
   参数化测试实例
   1. 为准备使用参数化测试的测试类指定特殊的运行器 org.junit.runners.Parameterized。
   2. 为测试类声明几个变量,分别用于存放期望值和测试所用数据。
   3. 为测试类声明一个使用注解 org.junit.runners.Parameterized.Parameters 修饰的,返回值为 java.util.Collection 的公共静态方法,并在此方法中初始化所有需要测试的参数对。
   4. 为测试类声明一个带有参数的公共构造函数,并在其中为第二个环节中声明的几个变量赋值。
   5. 编写测试方法,使用定义的变量作为参数进行测试。
/*********************************************************************************************/
@RunWith(Parameterized.class)
public class StringTransformerTest {
    private String testData;
    private String expectedData;

    public StringTransformerTest(String testData, String expectedData) {
        this.testData = testData;
        this.expectedData = expectedData;
    }

    @Test
    public void testTransfer() {
        assertEquals(expectedData, StringTransformer.transfer(testData));
    }

    @Parameters
    public static Collection getParameters() throws Exception {
        return Arrays.asList(new Object[][] {
                { "employee_info", "employeeInfo" }, // 测试一般的处理情况
                { null, null }, // 测试 null 时的处理情况
                { "", "" }, // 测试空字符串 时的处理情况
                { "employee_info", "EmployeeInfo" }, // 测试当首字母大写时的情况
                { "employee_info_a", "employeeInfoA" }, // 测试当尾字母为大写时的情况
                { "employee_a_info", "employeeAInfo" } // 测试多个相连字母大写时的情况
                });

    }
}
/*********************************************************************************************/

   运行效果如下图


参考资料
Parameterising JUnit tests
单元测试利器 JUnit 4
 
2009-05-23 6:49
    UltraEdit是一个非常棒的编辑器,对于程序员可以支持很多种语言。除了开发意外,用它来分析日志也是方便的。日志文件往往都很庞大,几百兆也是很平常的,而UltraEdit可以支持4G的文件。UltraEdit有一个很有用的查询功能“列出包含字符串的行”,这个选项是UltraEdit的【查找】功能中的【高级】配置。


由于日志文件包含的东西很多,所以用这个方法可以很快的找出自己感兴趣的内容
再通过【查找结果窗口】剪贴板的剪贴板功能,将查询结果复制到windows剪贴板中,然后用Ultraedit再新建一个文件,粘贴内容到该文件。通过这种方式,就可以不断的缩小日志查找的范围,避免了其他内容的干扰。有时候也会需要分析某条日志的上下文,也可以先利用以上的方法定位到了某条日志,再以该条日志的内容为查询条件到完整的日志文件中查找,马上就可以定位了:-)。
 
   
 
 
文章分类
 
   
 
文章存档
 
     
 
最新文章评论
  

如果我想学习了解单元测试的话,我想知道我学到什么水平、或者说了哪些内容后才可以
 

按照这种操作,创建分支,点击ok后,提示access to 'http://xxxx/svn' forbidden,这
 

今天刚了解了这个设计原则,摊开来讲的话,博大精深
 

能详细阐述一下就好了
 

thx
   
帮助中心 | 空间客服 | 投诉中心 | 空间协议
©2012 Baidu