JUnit4 简单Demo

 我们都知道,在合作开发中,我们写的类是要给别人用的,那么会不会有Bug呢?显然,我们需要测试。在之前的学习中,一般我们都是写个main方法进行测试。

         先分析一下用main方法测试的几个弊端:

1. 不能有组织地运行。(解释一下,就是说不能有效地控制测试哪些方法,有人就要说了,我就在main方法里把要测试的方法都测试一下呗。是可以,但是项目大了呢,创建一堆对象,再调用N个方法,估计自己看了都晕了)

2.需要人为地去判断一个个运行结果是否正确。(估计测试了十几个方法就看晕了)

JUnit就可以弥补这些弊端。JUnit是一个非常常见的单元测试框架,利用它可以很容易地组织几套测试用例。

 

一个简单的例子:

 

T 类是要测试的类:

 

Java代码   收藏代码
  1. package org.htnecro.junit4;  
  2.   
  3. public class T {  
  4.   
  5.     public int plus(int x, int y) {  
  6.         return x + y;  
  7.     }  
  8.     public int minus(int x, int y) {  
  9.         return x - y;  
  10.     }  
  11.       
  12. }  

 

将测试代码写在一个新的Source folder—test里面与源码分离开,新建Junit Test Case—TTest 类:

 

Java代码   收藏代码
  1. package org.htnecro.junit4;  
  2.   
  3. import static org.hamcrest.Matchers.greaterThan;  
  4. import static org.hamcrest.Matchers.*;  
  5. import static org.junit.Assert.assertThat;  
  6.   
  7. import org.junit.Test;  
  8.   
  9. public class TTest {  
  10.   
  11.     @Test  
  12.     public void testPlus() {  
  13.         int z=new T().plus(2, 2);  
  14.         assertThat(z,is(4));  
  15.     }  
  16.   
  17.     @Test  
  18.     public void testMinus() {  
  19.         int z=new T().minus(5, 3);  
  20.         assertThat(z, greaterThan(1));  
  21.     }  
  22.   
  23. }   

 

assertThat(actual, matcher)是JUnit4的一个新方法,之前常用的是assertEquals()方法,actual参数就是实际值,macher的意思是匹配,可以看到引入的包中有个hamcrest,hamcrest是一个书写匹配器对象时允许直接定义匹配规则的框架。

@Test 是JUnit4 Annotation注解,当然还有一些其他的注解。

 

Run as JUnit Test:

 

       Errors:0             Failures:0          测试正确。

 

Junit可以分开组织需要测试方法。可以测试单个的方法,也可以测试一个类的,一个包下的,甚至一个项目下的所有方法。而且很易于重用和修改。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值