很早以前就知道JUnit也知道它用来做单元测试。今天突然又想到还是要学一下这个JUnit,不然说出去不知道怎么用JUnit做单元测试……作为一个程序员怪丢人的。第一篇JUnit不算是一个总结性的文章,只算是第一次摸索着学习JUint怎么来用。到目前来看,确实可能和网上说的一样,不过是多了几个main方法而已,不过,我相信随着学习的深入,JUnit不仅仅是作为几个main方法来调用这么简单。
使用JUnit官方提供了几种方法,一是手动导入jar包,但在手动导入jar包的时候一定要记得导入两个包:
我们这里使用junit-4.12.jar和hamcrest-core-1.3.jar。JUnit的GitHub地址:https://github.com/junit-team/junit4/wiki/Download-and-Install
我们首先来写一个计算器类(之前在简单工厂里同样实现过计算器,这里为演示JUnit的demo,所以就不要在意是否面向对象等等问题了)。
1 package day_13_junit;
2
3 /**
4 * @author turbo
5 *
6 * 2016年9月18日
7 */
8 public class Calc {
9 public double add(double numberA, double numberB){
10 return numberA + numberB;
11 }
12
13 public double div(double numberA, double numberB){
14 return numberA - numberB;
15 }
16
17 public double mul(double numberA, double numberB){
18 return numberA * numberB;
19 }
20
21 public double sub(double numberA, double numberB){
22 return numberA / numberB;
23 }
24 }
好了,我们现在要来测试这个计算器的一般做法是写一个main方法吧,这确实也没问题,这次我们用JUnit来做测试。
1 package day_13_junit;
2
3 import static org.junit.Assert.assertEquals;
4
5 import org.junit.Before;
6 import org.junit.Test;
7
8 /**
9 * 单元测试
10 * @author turbo
11 *
12 * 2016年9月18日
13 */
14 public class TestCalc {
15 Calc calc;
16
17 @Before
18 public void setUp(){
19 calc = new Calc();
20 }
21
22 @Test
23 public void testAdd(){
24 double result = calc.add(1, 1);
25 System.out.println(result);
26 assertEquals(1.0, result, 1.0);
27
28 }
29
30 @Test
31 public void testDiv(){
32 double result = calc.div(1, 2);
33 System.out.println(result);
34 }
35 }
@Before注解从字面上来很好理解,在执行具体某个测试方法前执行这个方法。
@Test就是具体的测试方法。
我们看到一个assertEqueals静态方法第一个参数表示期望值,第二个参数表示实际值,第三个参数表示误差值。在Assert类中对该方法有大量的重载,由于double类型方法在以前的JUnit的assertEqueals只有两个参数,当我只写两个参数时发现已经被弃用。
我们可以通过源码发现:
1 /**
2 * @deprecated Use
3 * <code>assertEquals(double expected, double actual, double delta)</code>
4 * instead
5 */
6 @Deprecated
7 static public void assertEquals(double expected, double actual) {
8 assertEquals(null, expected, actual);
9 }
原来两个参数的assertEquals方法已经被替换,新增加了一个误差值参数。我们看看替换的方法。
1 /**
2 * Asserts that two doubles are equal to within a positive delta.
3 * If they are not, an {@link AssertionError} is thrown. If the expected
4 * value is infinity then the delta value is ignored.NaNs are considered
5 * equal: <code>assertEquals(Double.NaN, Double.NaN, *)</code> passes
6 *
7 * @param expected expected value
8 * @param actual the value to check against <code>expected</code>
9 * @param delta the maximum delta between <code>expected</code> and
10 * <code>actual</code> for which both numbers are still
11 * considered equal.
12 */
13 static public void assertEquals(double expected, double actual, double delta) {
14 assertEquals(null, expected, actual, delta);
15 }
对该方法的参数解释前两个参数很好懂,为什么会新增一个误差值呢?因为double类型浮点数运算并不一定是“绝对准确”的,所以新增一个误差值,这个误差值的范围在期望值和实际值之间。什么意思呢?比如1.0+1.0应该等于2.0,所以我们期望它等于2.0,但实际情况可能某种原因并非如此,所以我们给它一个误差值1.0,这样在范围1.0~3.0都可以认为是“正确”的。
这两个@Test方法,在空白处选择JUnit Test运行时可以同时运行。当我们只想运行一个@Test方法时,只需选择方法名右键选择JUnit Test运行即可运行单个方法。
第一次的JUnit学习就到这里了,一点点小东西,没什么干货,重在积累,重在坚持。