首先在给出一个类Operator,加入如下代码:

public class Operator {

	// 加法 运算
public int add(int i,int j){
return i+j;
} // 除法 运算
public int divide(int i,int j){
return i/j;
} }

接着建一个类来测试上各类的方法,为了命名规范性,取名为TestOperator。代码如下:

/*
* 注意测试类名的命名方法,一般测试哪个类,就在其前面加上Test。
* 测试类, 去测试 operator这个类 的 方法
*
*
* 关于 junit 测试 框架的使用, 掌握 如下的内容 一般 够你用了 .
*
*/
public class TestOperator {//如果想要测试整个类里面的所有方法,直接点击类名进行测试就会测试这类里面的所有的方法 Operator op;//抽取对象到乘员位置。 // 这里 加了 @BeforeClass 之后, 那么 这个方法 就会 在 类加载的时候 执行
@BeforeClass
public static void beforeClass(){//注意方法命名static System.out.println("before class ..."); } // 这里 加了 @Before 之后, 那么 这个方法 就会 在每个 【测试方法】 执行 之前 执行
@Before
public void before(){//在before里面进行初始化对象
op = new Operator();//如果方法有100多个,每次都new显然很麻烦。因此在这里new出这个对象就可以了,
//在每个 【测试方法】 执行 之前 执行 不必担心对象为空指针。
System.out.println("before...");
    }
    
    //  使用测试框架测试程序的条件 :
    // 第一个:测试 方法 不能 接收 任何的参数, 并且不能有任何的返回值, 必须是void
    // 第二个: 需要在测试方法上加 @Test注解
    
    // 使用 junit 测试框架去 测试运行这个方法
    
    // 测试 的时候, 会看到一个 junit 测试的结果, 如果 测试的结果是绿条, 那么  恭喜你,测试通过 ,
    // 如果是 红条,  则测试不通过
    @Test
    public void testAdd(){
        
        int result = op.add(1, 2);
        
        //System.out.println("结果 :" + result);
        
        // 使用 Assert 断言 类 【来对 结果进行判断】
        
        Assert.assertEquals(3, result);
        
    }
    
    // *android 中 也是  使用 junit 测试 框架 对 代码进行 测试 .  
    // cts(compatibility test suit 兼容性测试单元) 的测试 ---
    @Test(expected=java.lang.ArithmeticException.class)//期望测试的时候是否会抛出一个这样的异常
    public void testDivide(){
        
        int result = op.divide(3, 0);
        Assert.assertEquals(3, result);
    }
    
    // 填入10表示10 毫秒内测试的单元必须运行完毕
    @Test(timeout=1)
    public void testAdd2(){
        
        int result = op.add(1, 2);
    }
    
    // 这里 加了 @After 之后, 那么 这个方法 就会 在每个【 测试方法 执行 之 后】  执行after
    @After
    public void after(){//因此可以在这里面释放对象资源。
        op = null;
        System.out.println("after...");
    }
    
    // 类 资源 释放的时候 调用
    @AfterClass
    public static void afterClass(){
        
        System.out.println("after   class ...");
        
    }
    
}  

掌握以上单元测试的相关概念后,足够应对程序测试了。

单元测试junit框架详解的更多相关文章

  1. Junit使用详解

    http://junit.org/上详细介绍了Junit.JUnit is a simple framework to write repeatable tests. It is an instanc ...

  2. Shiro 安全框架详解二(概念+权限案例实现)

    Shiro 安全框架详解二 总结内容 一.登录认证 二.Shiro 授权 1. 概念 2. 授权流程图 三.基于 ini 的授权认证案例实现 1. 实现原理图 2. 实现代码 2.1 添加 maven ...

  3. Shiro 安全框架详解一(概念+登录案例实现)

    shiro 安全框架详细教程 总结内容 一.RBAC 的概念 二.两种常用的权限管理框架 1. Apache Shiro 2. Spring Security 3. Shiro 和 Spring Se ...

  4. jQuery Validate验证框架详解

    转自:http://www.cnblogs.com/linjiqin/p/3431835.html jQuery校验官网地址:http://bassistance.de/jquery-plugins/ ...

  5. mina框架详解

     转:http://blog.csdn.net/w13770269691/article/details/8614584 mina框架详解 分类: web2013-02-26 17:13 12651人 ...

  6. lombok+slf4j+logback SLF4J和Logback日志框架详解

    maven 包依赖 <dependency> <groupId>org.projectlombok</groupId> <artifactId>lomb ...

  7. [Cocoa]深入浅出 Cocoa 之 Core Data(1)- 框架详解

    Core data 是 Cocoa 中处理数据,绑定数据的关键特性,其重要性不言而喻,但也比较复杂.Core Data 相关的类比较多,初学者往往不太容易弄懂.计划用三个教程来讲解这一部分: 框架详解 ...

  8. iOS 开发之照片框架详解(2)

    一. 概况 本文接着 iOS 开发之照片框架详解,侧重介绍在前文中简单介绍过的 PhotoKit 及其与 ALAssetLibrary 的差异,以及如何基于 PhotoKit 与 AlAssetLib ...

  9. Quartz.NET作业调度框架详解

    Quartz.NET作业调度框架详解 http://www.cnblogs.com/lmule/archive/2010/08/28/1811042.html

随机推荐

  1. c++ 文件操作详解

    C++ 通过以下几个类支持文件的输入输出: ofstream: 写操作(输出)的文件类 (由ostream引申而来) ifstream: 读操作(输入)的文件类(由istream引申而来) fstre ...

  2. Linux下常用的配置

    本文主要给出的都是一些常用的Linux配置,系统版本是基于CentOs6.3,供自己复习和新人学习,不当之处还请指正. vmware tools安装 虚拟机--->安装vmware tools ...

  3. kexec 内核快速启动流程分析

    一.命令行 1. kexec -l $kpwd --append="$arg" 其中$kpwd =目标内核的路径 $arg =传给内核的参数,与/proc/cmdline一致时表示 ...

  4. PHP Misc. 函数

    PHP 杂项函数简介 我们把不属于其他类别的函数归纳到杂项函数类别. 安装 杂项函数是 PHP 核心的组成部分.无需安装即可使用这些函数. Runtime 配置 杂项函数的行为受 php.ini 文件 ...

  5. 在linux系统中I/O 调度的选择

        I/O 调度算法再各个进程竞争磁盘I/O的时候担当了裁判的角色.他要求请求的次序和时机做最优化的处理,以求得尽可能最好的整体I/O性能. 在linux下面列出4种调度算法 CFQ (Compl ...

  6. iOS图形手势识别框架SGGestureRecognizer

    简介 苹果官方为我们提供了简单手势的识别器,但对于图形手势,例如五角星.三角形等的识别,就需要自己实现了.通过识别这些手势,可以去执行特定的操作,或是输入公式.释放魔法等,可以为App增光添彩. 下载 ...

  7. 剑指Offer——顺丰笔试题+知识点总结

    剑指Offer--顺丰笔试题+知识点总结 情景回顾 时间:2016.10.16 19:00-20:40 地点:山东省网络环境智能计算技术重点实验室 事件:顺丰笔试 知识点总结 快排 霍尔排序(快排) ...

  8. 长度为N的数组乱序存放着0带N-1.现在只能进行0与其他数的swap操作,请设计并实现排序,必须通过交换实现排序。

    void sort(int* arr, int len) { if (!arr) { return; } for (int i = 1; i < len; ++i) { while (arr[0 ...

  9. 为什么函数式编程可以没有while?

    以前想不通,今天在写代码时不知怎么的,偶然就发现了答案.. 比如说把某个字符串s中所有"00"及更长的'00'统统换为'0'.最后结果中不能包含'00'. 00001100--&g ...

  10. Android开发基础规范(一)

    转载请把头部出处链接和尾部二维码一起转载,本文出自逆流的鱼yuiop:http://blog.csdn.net/hejjunlin/article/details/52602487 前言:Androi ...