JUnit 3.8.1 源码学习


  环境搭建(源码加载配置)

  由于IDE自身含有JUint插件,因此通过正常途径是没有源码加载入口的,因此需通过手动加载扩展JAR,然后再添加对应源码JAR,如图:项目右键—>Propreties

完成之后,项目结构如图:

  启动类创建

  为了能够对JUint的整个流程有个完整的认识,通过一个简单的调用作为入口,走进JUint的大门。在这里通过一段非常简单的代码,如下

public class Caculator {

    int a,b;
public Caculator(int a, int b) {
super();
this.a = a;
this.b = b;
}
public static int add(int a, int b) {
return a+b;
}
public static void main(String[] args) throws NoSuchMethodException, SecurityException {
junit.textui.TestRunner.run(TestCaculator.class);
}
} public class TestCaculator extends TestCase{ public void testadd() {
int result = Caculator.add(1,2);
Assert.assertEquals(4, result);
}
}

  这里通过代码启动,junit.textui.TestRunner.run(TestCaculator.class);

  正式开始

  首先看到的是TestSuite(Test子类),通过调用TestSuite的有参构造器

  


  有参构造中,最主要的就是addTestMethod方法,该方法执行条件是:测试类中有多少个方法就执行多少次,并支持测试类继承


  在方法内部,再对方法进行规则校验


  包括对方法的参数个数、方法名称、方法返回值以及方法修饰符


  同时也注意到,不管校验是否通过,都会调用addTest方法(这里用到了组合模式),添加的Test对象在执行测试类时进行遍历获取

  该方法接收一个Test接口类型的参数

  先说校验不通过的处理逻辑,在warning方法体内,通过匿名内部类的方式生成TestCase类,并重写runTest方法,其中的fail方法,则是throw一个自定义error异常信息

  


   再说校验通过所调用的createTest方法,该方法主体是通过反射生成TestCase对象实例,同时将字段名称赋值给TestCase对象的fName字段(该用于日志输出)


到此,测试类已经加载完毕,接下来就是启动测试类

  对于测试结果,通过TestResult类进行接收,通过createTestResult方法new出一个TestResult实例对象,再调用其addListener方法添加监听(这里使用到了观察者模式)

  通过调用Test.run方法进行测试类的启动,这里的suite的实际类型为TestSuite类型


  调用tests方法获取加载测试类时所添加的测试类对象,遍历执行每个测试类的run方法

  


  执行到TestCase的run方法,方法接收一个TestResult类型的参数,方法体内,再执行该TestResult对象的run方法


  在TestResult类中的run方法体内,调用了三个方法,其中最重要的就是Protectable这个接口的内部类实现,它的protect方法体中的TestCase.runBare()方法中的runTest方法是最终的测试方法的执行


  startTest方法,用来执行Listener(观察者)实际类型为ResultPrinter的startTest方法,控制台则输出对应的"."信息


  通过反射执行测试类中指定的测试方法,方法体重的fName字段的参数,在通过反射生成对象实例时,调用set方法进行赋值了,如在测试方法执行过程中,产生的异常,则会向上抛出

  p.protect是执行测试方法的最后一步,如执行测试方法有异常,在runProtected方法体中,进行catch捕获,并调用对应的addFailure或addError方法


  记录失败信息,fFailures用来存储产生的错误信息日志数据,用来执行Listener(观察者)实际类型为ResultPrinter的addFailure方法输出对应的错误信息


至此,启动测试类已经运行完毕,接下来就是输出运行结果

  调用fPrinter.print方法实现日志的输出

  


  在方法体中的四个方法,就是最终日志的输出方法


  printFailures实现代码如下,获取在执行测试类记录的错误日志,并输出

JUnit 3.8.1 源码学习的更多相关文章

  1. JUnit 3.8.1 源码学习简记

    先记录一个整理的流程 1.首先使用TestSuite获取一个TestCase中的所有测试方法(方法名以test开头的方法),为每个方法生成一个TestCase实例并保存,实例中有个字段保存对应的方法名 ...

  2. Junit 3.8.1 源码分析(一)

    写在前面:本文基于Junit3.8.1版本,因为这是我第一次进行源码学习,先从简单的源码开始学起 1. 示例代码 1.1 准备工作 下载Junit3.8.1的JAR包 需要下载junit-3.8.1- ...

  3. Tomcat源码学习

    Tomcat源码学习(一) 转自:http://carllgc.blog.ccidnet.com/blog-htm-do-showone-uid-4092-type-blog-itemid-26309 ...

  4. spring源码学习——spring整体架构和设计理念

    Spring是在Rod Johnson的<Expert One-On-One J2EE Development and Design >的基础上衍生而来的.主要目的是通过使用基本的java ...

  5. Java集合专题总结(1):HashMap 和 HashTable 源码学习和面试总结

    2017年的秋招彻底结束了,感觉Java上面的最常见的集合相关的问题就是hash--系列和一些常用并发集合和队列,堆等结合算法一起考察,不完全统计,本人经历:先后百度.唯品会.58同城.新浪微博.趣分 ...

  6. jQuery源码学习感想

    还记得去年(2015)九月份的时候,作为一个大四的学生去参加美团霸面,结果被美团技术总监教育了一番,那次问了我很多jQuery源码的知识点,以前虽然喜欢研究框架,但水平还不足够来研究jQuery源码, ...

  7. MVC系列——MVC源码学习:打造自己的MVC框架(四:了解神奇的视图引擎)

    前言:通过之前的三篇介绍,我们基本上完成了从请求发出到路由匹配.再到控制器的激活,再到Action的执行这些个过程.今天还是趁热打铁,将我们的View也来完善下,也让整个系列相对完整,博主不希望烂尾. ...

  8. MVC系列——MVC源码学习:打造自己的MVC框架(三:自定义路由规则)

    前言:上篇介绍了下自己的MVC框架前两个版本,经过两天的整理,版本三基本已经完成,今天还是发出来供大家参考和学习.虽然微软的Routing功能已经非常强大,完全没有必要再“重复造轮子”了,但博主还是觉 ...

  9. MVC系列——MVC源码学习:打造自己的MVC框架(二:附源码)

    前言:上篇介绍了下 MVC5 的核心原理,整篇文章比较偏理论,所以相对比较枯燥.今天就来根据上篇的理论一步一步进行实践,通过自己写的一个简易MVC框架逐步理解,相信通过这一篇的实践,你会对MVC有一个 ...

随机推荐

  1. [Git] 1、常用Git命令行总结(一)

    一.GIT CLONE最常用的有如下几个 1.最简单直接的命令:git clone xxx.git 2.如果想clone到指定目录:git clone xxx.git “指定目录” 3.clone时创 ...

  2. swift UILabel多行显示时 计算UILable的高度(可用于UILable高度自适应)

    代码如下 func heightForView(text:String, font:UIFont, width:CGFloat) -> CGFloat{ let label:UILabel = ...

  3. NYOJ--1236--挑战密室(第八届河南省程序设计大赛)

    挑战密室 时间限制:1000 ms  |  内存限制:65535 KB 难度:4   描述 R组织的特工Dr. Kong 为了寻找丢失的超体元素,不幸陷入WTO密室.Dr. Kong必须尽快找到解锁密 ...

  4. C++STL(vector,map,set,list)成员函数整理

    / *最近ACM比赛,用到的时候忘记成员函数了,贼尴尬,给以后比赛做下准备 */ LIST: 构造函数 list<int> c0; //空链表 list<int> c1(3); ...

  5. 微信小程序(有始有终,全部代码)开发--- 新增模块: 图片选取以及拍照功能

    开篇语 前几天发了一篇: <简年15: 微信小程序(有始有终,全部代码)开发---跑步App+音乐播放器 > 后来又发了BUG修复的版本: 简年18: 微信小程序(有始有终,全部代码)开发 ...

  6. ps 命令的详细功能解析

    转自:http://www.cnblogs.com/wangkangluo1/archive/2011/09/23/2185938.html 要对进程进行监测和控制,首先必须要了解当前进程的情况,也就 ...

  7. RabbitMQ安装以及java使用(二)

    上一篇记录了rabbitmq的安装,这一篇记录一下rabbitmq的java客户端的简单使用,当然在项目中我们有更为复杂的应用场景,这里只有最简单的点对点生产者与消费者模式. 1.建立工程 首先建立一 ...

  8. Python查询SQLserver数据库备份(抛砖引玉)

    通过python pymssql直接访问SQLserver数据库,查找其数据库mode,这个脚本具有很强的抛砖引玉特性: 1.可以巡检多台多数据库服务器 2.query内容可以多样化,譬如查询死锁.连 ...

  9. NYOJ 23.取石子(一)

    取石子(一) 时间限制:3000 ms  |  内存限制:65535 KB 难度:2   描述 一天,TT在寝室闲着无聊,和同寝的人玩起了取石子游戏,而由于条件有限,他/她们是用旺仔小馒头当作石子.游 ...

  10. 【python密码学编程】5.反转加密法

    #Reverse Cipher message = 'there can keep a secret,if two of them are dead.' translated = '' i = len ...