三分钟掌握 JUnit3.0
曾经公司做过一个.net的项目,在项目开发的过程中。我们採用的是分层的开发方式,大家先在一起讨论接口, 然后讨论完以后,形成文档,然后依照文档进行开发!这样就有一个问题,你必需要保证你的接口是正确的。然后才干提供给其它人使用。
所以一定要对你写的方法进行单元測试。单元測试真的是非常方便!
如今的公司是开发java 项目的,开发过程也和.net的开发模式是一样的,所以说单元測试也成了必需品。
可是我们用的JUnit。
下边就给大家介绍一下JUnit的用法。
我们首先来建立一个项目。项目结构例如以下例如以下图所看到的!
然后倒入我们须要的jar包,我用的Myeclipse 。他集成了JUnit,所以说直接加入他的jar就能够了,在项目上单击右键。选择BuildPath 然后选择Libraries, 然后选择JUnit,他会有两个版本号,Junit3 和Junit 4然后选择一个, 本项目选择的是Junit3 ,加入完毕后, 项目中会多出一个Junit3的 一个库。
然后在项目的根文件夹下建一个Source Folder 例如以下图所看到的, 然后在建立一个和src 下边一样的包。这么做的目的是使下边要生成的測试类。不用引用对被測试类的依赖。他们生成的.class文件在同一个Bin文件夹下。
在我们的要測试的那个类上边单击右键, 然后选择New ,然后选择Others ,然后选择Junit Test Case。 然后Source folder 选择我们后来建立的測试的Source folder。然后将setUp和tearDown勾选上。
将我们我们要測试的那个类的全部的方法都勾选上,或者勾选我们要測试的方法就能够了!
然后选择完毕!
这样就会看到我们的測试类已经自己主动的为我们生成好了。
可是我们能够看到。自己主动为我们生成的測试方法。都是没有实现的,并且这些測试方法符合了一定的规范。
測试方法满足例如以下原则: 1)方法类型必须为public 2)返回值void 3)无參数 4)方法名必须以test开头或者以test结尾。可是建议使用前者!
所以接下来我们要自己写測试方法的实现了!
。例如以下所看到的。
package com.tgb.test; import junit.framework.Assert; import junit.framework.TestCase; public class CountMethodTest extends TestCase { /** * setUp在每一个測试方法运行前都要运行 该方法 */ protected void setUp() throws Exception { super.setUp(); } /** * tearDown 在每一个測试方法运行完毕后都要运行 该方法 */ protected void tearDown() throws Exception { super.tearDown(); } /** * 測试目标类的add 方法 */ public void testAdd() { int par1=3; int par2=0; CountMethod cm = new CountMethod(); //该值为运行完目标类方法后,返回的实际值 int actual= cm.add(par1, par2); // 推断方法的返回结果 Assert.assertEquals(3, actual);// 第一个參数是期望值,第二个參数是要验证的值 } public void testSubtract() { int par1=3; int par2=0; CountMethod cm = new CountMethod(); int actual= cm.subtract(par1, par2); assertEquals(3, actual); } public void testMultiply() { int par1=3; int par2=0; CountMethod cm = new CountMethod(); int actual= cm.multiply(par1, par2); assertEquals(0, actual); } public void testDiv() { int par1=3; int par2=0; CountMethod cm = new CountMethod(); int actual= cm.div(par1, par2); assertEquals(0, actual); } }
然后我们在该測试类的空白处单击右键选择 Run As 然后选择Junit Test 。这样我们就能够运行我们刚才写的单元測试了!
能够看到測试结果例如以下。运行了四个方法,有一个错误的。能够看到打叉的那个失败了! 通过单元測试,我们能够非常快的发现我们的方法写的是否正确!
假设在測试的SourceFolder以下有多个单元測试类,我们想统一进行单元測试。你会怎么处理呢?我们能够一个个的去手动运行,然后在哪等着结果。是不是有点浪费时间呢。Junit 给我提供了一个更好的方法,我们在建立一个測试类。然后 该类的写法例如以下,这样我们就能够一次性的把全部的方法都运行了!
package com.tgb.test; import junit.framework.Assert; import junit.framework.TestCase; public class CountMethodTest extends TestCase { /** * setUp在每一个測试方法运行前都要运行 该方法 */ protected void setUp() throws Exception { super.setUp(); } /** * tearDown 在每一个測试方法运行完毕后都要运行 该方法 */ protected void tearDown() throws Exception { super.tearDown(); } /** * 測试目标类的add 方法 */ public void testAdd() { int par1=3; int par2=0; CountMethod cm = new CountMethod(); //该值为运行完目标类方法后,返回的实际值 int actual= cm.add(par1, par2); // 推断方法的返回结果 Assert.assertEquals(3, actual);// 第一个參数是期望值,第二个參数是要验证的值 } public void testSubtract() { int par1=3; int par2=0; CountMethod cm = new CountMethod(); int actual= cm.subtract(par1, par2); assertEquals(3, actual); } public void testMultiply() { int par1=3; int par2=0; CountMethod cm = new CountMethod(); int actual= cm.multiply(par1, par2); assertEquals(0, actual); } public void testDiv() { int par1=3; int par2=0; CountMethod cm = new CountMethod(); int actual= cm.div(par1, par2); assertEquals(0, actual); } }
Junit 的使用,非常方便的让我们測试类,可是他生成的測试方法体是空的,都须要自己写, 假设能想.Net 中那样,把測试方法体,大部分的内容都给你写好了就更好了!