前面的博客我们也已经整理到了,我们使用junit38,在写测试类的时候我们的测试类必须继承TestCase。这个所有测试类的父类在junit.framework包下面。

前面我们的整理都是说直接在IDE中直接运行测试类,右击然后run as junit。当然我们还可以自己写main方法来运行测试,其实都一样。

OK,现在我们来写一个例子,直接运行测试类的main方法来跑测试。代码如下:

package org.linkinpark.commons.textui;

import org.linkinpark.commons.framework.TestCase;
import org.linkinpark.junit.Assert; /**
* @创建作者: LinkinPark
* @创建时间: 2016年2月4日
* @功能描述: 写一个测试类,用main方法来驱动测试。
*/
public class LinkinTest2 extends TestCase
{ public void test1()
{
Assert.assertEquals("1", "1");
} /**
* @创建时间: 2016年2月4日
* @相关参数: @param args
* @功能描述: 调用TestRunner来run测试。
*/
public static void main(String[] args)
{
TestRunner.run(LinkinTest2.class);
} }

前面的3篇博客,我已经认真的整理过了junit测试的3个步骤,这里做一个总结。

我们来自己写的测试类上的一个测试方法打一个断点,然后看下eclipse中junit方法调用的情况。

      



OK,上面的2张图很直接了说明了测试开始到测试方法真正被执行的所有的过程,我在这里也不做赘述了。之后的结果收集,无疑就是在每个测试类中传递一个TestResult类,通过printerWriter来打印日志而已,这里也不在赘述了。



在前面的演示junit源码过程中,我自己也修改了好多的控制台输出。最后这里写2个测试例子,来一起看下控制台的输出,整体回顾下junit的整个测试过程好了。

2个测试类代码如下:

package org.linkinpark.commons.textui;

import org.linkinpark.commons.framework.TestCase;
import org.linkinpark.junit.Assert; public class LinkinTest1 extends TestCase
{ public LinkinTest1(String methodName)
{
super(methodName);
} public void setUp()
{
System.out.println("这里是自己定义的setUp()");
} public void tearDown()
{
System.out.println("这里是自己定义的tearDown()");
} public void testLinkin4Normal()
{
System.out.println("======>开始执行被测试代码====");
final String str = "林肯:这里是自己的被测试的正确代码";
System.out.println(str);
System.out.println("======>结束执行被测试代码====");
Assert.assertEquals(str, str);
} public void testLinkin8Error()
{
System.out.println("======>开始执行被测试代码====");
final String str = "林肯:这里是自己的被测试的错误代码";
System.out.println(str);
System.out.println("======>结束执行被测试代码====");
Assert.assertEquals("这里是我期望的错误逻辑输出", str);
} }
package org.linkinpark.commons.textui;

import org.linkinpark.commons.framework.TestCase;
import org.linkinpark.junit.Assert; public class LinkinTest1 extends TestCase
{ public LinkinTest1(String methodName)
{
super(methodName);
} public void testLinkin()
{
Assert.assertTrue(true);
} }
package org.linkinpark.commons.textui;

import org.linkinpark.commons.framework.Test;
import org.linkinpark.commons.framework.TestCase;
import org.linkinpark.commons.framework.TestSuite; public class LinkinTestAll extends TestCase
{ public static Test suite()
{
TestSuite suite = new TestSuite().addTestSuite(LinkinTest.class);
return suite.addTest(new LinkinTest1("testLinkin"));
} public static void main(String args[])
{
TestRunner.run(suite());
} }

以下是控制台输出:

###########开始迭代运行整套测试,互相独立###########
第一步:框架开始打印日志====
~~~~~~~~~~~~~~~~~~~~~~~
第二步:框架开始运行测试====
这里是自己定义的setUp()
框架开始执行测试,执行的方法是-->public void org.linkinpark.commons.textui.LinkinTest.testLinkin4Normal()
======>开始执行被测试代码====
林肯:这里是自己的被测试的正确代码
======>结束执行被测试代码====
框架结束执行测试,执行的方法是-->public void org.linkinpark.commons.textui.LinkinTest.testLinkin4Normal()
这里是自己定义的tearDown()
第三步:框架结束运行测试====
~~~~~~~~~~~~~~~~~~~~~~~
###########开始迭代运行整套测试,互相独立###########
第一步:框架开始打印日志====
~~~~~~~~~~~~~~~~~~~~~~~
第二步:框架开始运行测试====
这里是自己定义的setUp()
框架开始执行测试,执行的方法是-->public void org.linkinpark.commons.textui.LinkinTest.testLinkin8Error()
======>开始执行被测试代码====
林肯:这里是自己的被测试的错误代码
======>结束执行被测试代码====
这里是自己定义的tearDown()
第三步:框架结束运行测试====
~~~~~~~~~~~~~~~~~~~~~~~
KAO,有报错啦!!!
###########开始迭代运行整套测试,互相独立###########
第一步:框架开始打印日志====
~~~~~~~~~~~~~~~~~~~~~~~
第二步:框架开始运行测试====
====框架执行默认的setUp====
框架开始执行测试,执行的方法是-->public void org.linkinpark.commons.textui.LinkinTest1.testLinkin()
框架结束执行测试,执行的方法是-->public void org.linkinpark.commons.textui.LinkinTest1.testLinkin()
====框架执行默认的tearDown====
第三步:框架结束运行测试====
~~~~~~~~~~~~~~~~~~~~~~~
第四步:框架开始统计时间====
耗时:0.024秒
遗憾:!一共有1个错误:
1) testLinkin8Error(org.linkinpark.commons.textui.LinkinTest)org.linkinpark.junit.ComparisonFailure: 期望是:<[这里是我期望的错误逻辑输出]> 结果却是:<[林肯:这里是自己的被测试的错误代码]>
at org.linkinpark.junit.Assert.assertEquals(Assert.java:104)
at org.linkinpark.junit.Assert.assertEquals(Assert.java:135)
at org.linkinpark.commons.textui.LinkinTest.testLinkin8Error(LinkinTest.java:42)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at org.linkinpark.commons.framework.TestCase.runTest(TestCase.java:117)
at org.linkinpark.commons.framework.TestCase.runBare(TestCase.java:53)
at org.linkinpark.commons.framework.TestResult$1.protect(TestResult.java:251)
at org.linkinpark.commons.framework.TestResult.runProtected(TestResult.java:154)
at org.linkinpark.commons.framework.TestResult.run(TestResult.java:254)
at org.linkinpark.commons.framework.TestCase.run(TestCase.java:42)
at org.linkinpark.commons.framework.TestSuite.runTest(TestSuite.java:322)
at org.linkinpark.commons.framework.TestSuite.run(TestSuite.java:316)
at org.linkinpark.commons.framework.TestSuite.runTest(TestSuite.java:322)
at org.linkinpark.commons.framework.TestSuite.run(TestSuite.java:316)
at org.linkinpark.commons.textui.TestRunner.doRun(TestRunner.java:113)
at org.linkinpark.commons.textui.TestRunner.doRun(TestRunner.java:98)
at org.linkinpark.commons.textui.TestRunner.run(TestRunner.java:58)
at org.linkinpark.commons.textui.LinkinTestAll.main(LinkinTestAll.java:18)
第五步:框架开始统计结果====
结果:AU,出错啦!
Tests run: 3, Failures: 0, Errors: 1
第六步:框架结束整个测试====



OK,junit源码解析就先整理到这里吧。接下来,我会整理junit4中的一些高级特性,之后再整理下junit中用的一些设计模式。



junit源码解析总结的更多相关文章

  1. junit源码解析--核心类

    JUnit 的概念及用途 JUnit 是由 Erich Gamma 和 Kent Beck 编写的一个开源的单元测试框架.它属于白盒测试,只要将待测类继承 TestCase 类,就可以利用 JUnit ...

  2. junit源码解析--初始化阶段

    OK,我们接着上篇整理.上篇博客中已经列出的junit的几个核心的类,这里我们开始整理junit完整的生命周期. JUnit 的完整生命周期分为 3 个阶段:初始化阶段.运行阶段和结果捕捉阶段. 这篇 ...

  3. junit源码解析--捕获测试结果

    OK,前面的博客我们整理了junit运行完了所有的测试用例,那么OK了,现在开始该收集测试结果了. 在这最后一步中,junit主要是玩一个类,TestResult.这里类中封装了几个参数,在初始化这个 ...

  4. junit源码解析--测试驱动运行阶段

    前面的博客里面我们已经整理了junit的初始化阶段,接下来就是junit的测试驱动运行阶段,也就是运行所有的testXXX方法.OK,现在我们开始吧. 前面初始化junit之后,开始执行doRun方法 ...

  5. JUnit源码分析 - 扩展 - 自定义RunListener

    RunListener简述 JUnit4中的RunListener类用来监听测试执行的各个阶段,由RunNotifier通知测试去运行.RunListener与RunNotifier之间的协作应用的是 ...

  6. Mybatis 系列8-结合源码解析select、resultMap的用法

    [Mybatis 系列10-结合源码解析mybatis 执行流程] [Mybatis 系列9-强大的动态sql 语句] [Mybatis 系列8-结合源码解析select.resultMap的用法] ...

  7. Mybatis源码解析,一步一步从浅入深(一):创建准备工程

    Spring SpringMVC Mybatis(简称ssm)是一个很流行的java web框架,而Mybatis作为ORM 持久层框架,因其灵活简单,深受青睐.而且现在的招聘职位中都要求应试者熟悉M ...

  8. Mybatis源码解析,一步一步从浅入深(二):按步骤解析源码

    在文章:Mybatis源码解析,一步一步从浅入深(一):创建准备工程,中我们为了解析mybatis源码创建了一个mybatis的简单工程(源码已上传github,链接在文章末尾),并实现了一个查询功能 ...

  9. Collections.unmodifiableMap,Collections.unmodifiableList,Collections.unmodifiableSet作用及源码解析

    在文章:Mybatis源码解析,一步一步从浅入深(五):mapper节点的解析中mybatis的源码中用到了Collections.unmodifiableList方法,其实还有unmodifiabl ...

随机推荐

  1. dataZoom 详细参数

    dataZoom:[ //区域缩放 { id: 'dataZoomX', show:true, //是否显示 组件.如果设置为 false,不会显示,但是数据过滤的功能还存在. backgroundC ...

  2. js中var,let,const理解

    var变量提升: 解释:在声明a之前输出a,因为a是使用var声明变量得到提升,解释为下句 var a: console.log(a) a = 1; var声明会提到最上面的位置,但是赋值的位置还是当 ...

  3. 基于input子系统的sensor驱动调试(一)

    要想弄明白世界的本质,就要追根溯源:代码也是一样的道理: 最近调试几个sensor驱动,alps sensor驱动.compass sensor驱动.G-sensor驱动都是一样的架构: 一.基于in ...

  4. 使用三种方法求解前N个正整数的排列

    本篇博文给大家介绍前N个正整数的排列求解的三种方式.第一种是暴力求解法:第二种则另外声明了一个长度为N的数组,并且将已经排列过的数字保存其中:第三种方式则采用了另外一种思路,即首先获取N个整数的升序排 ...

  5. LevelDB的源码阅读(四) Compaction操作

    leveldb的数据存储采用LSM的思想,将随机写入变为顺序写入,记录写入操作日志,一旦日志被以追加写的形式写入硬盘,就返回写入成功,由后台线程将写入日志作用于原有的磁盘文件生成新的磁盘数据.Leve ...

  6. JS 引擎的执行机制

    关于JS引擎的执行机制,首先牢记2点: .JS是单线程语言 JS的Event Loop是JS的执行机制.深入了解JS的执行,就等于深入了解JS里的event loop 关于单线程相对还比较好理解,就是 ...

  7. 运用C语言将图片转换成16进制的字符串(base64)

    最近在写手机端的性能测试脚本的时候,发现手机在上传图片数据时,先将图片转换成一堆16进制的字符,将字符传输过去,服务器再将字符解码成图片 我们在loadrunner中测试时,就需要用C语言将图片编码. ...

  8. XML(一)XML大揭秘

    前言 每天都要学习很多新的知识,比你厉害的程序员比你还努力,那你混的下这口饭吗?所以不抱怨,坚持!接下来给大家分享的是xml.可能很多做开发的都遇到过xml, 比如maven,各种框架的配置文件都有, ...

  9. bzoj 3874: [Ahoi2014]宅男计划

    Description  [故事背景] 自从迷上了拼图,JYY就变成了个彻底的宅男.为了解决温饱问题,JYY 不得不依靠叫外卖来维持生计. [问题描述] 外卖店一共有N种食物,分别有1到N编号.第i种 ...

  10. zoj 3228:Searching the String

    Description Little jay really hates to deal with string. But moondy likes it very much, and she's so ...