白盒测试—把测试对象看作一个打开的盒子,程序内部的逻辑结构和其他信息对测试人员是公开的。
回归测试—软件或环境的修复或更正后的“再测试”,自动测试工具对这类测试尤其有用。
单元测试—是最小粒度的测试,以测试某个功能或代码块。一般由程序员来做,因为它需要知道内部程序设计和编码的细节。
JUnit—是一个开发源代码的Java测试框架,用于编写和运行可重复的测试。他是用于单元测试框架体系xUnit的一个实例(用于java语言)。主要用于白盒测试,回归测试。
用法
1. 基本使用步骤,Junit的使用非常简单,它的基本使用步骤:
- 创建,从junit.framework.TestCase派生unit test需要的test case - 书写测试方法,提供类似于如下函数签名的测试方法:
public void testXXXXX();
- 编译,书写完test case后,编译所写的test case类
- 运行,启动junit test runner,来运行这个test case。
实验步骤:
大概总结一下如何在eclipse环境下使用Junit进行单元测试。
一、 新建一个测试用例或选择已有的所想测试的JAVA文件,点击“File->New->…”菜单项或右击文件,在弹出的“New”对话框中选择“JUnit Test Case”,就进入“New JUnit Test Case”对话框。 在“New JUnit TestCase”对话框填写相应的栏目,主要有Name(测试用例名),SuperClass(若JUnit的版本是3.8.1,则测试的超类一般默认为junit.framework.TestCase; 若JUnit版本是JUnit 4.4,则默认超类为java.lang.Object。),Class Under Test(被测试的类),Source Folder(测试用例保存的目录),Package(测试用例包名),及是否自动生成main,setUp,tearDown方法。在此一般填写NAME及选上复选上setUpt和teardown即可。
二、 点击“Next>”按钮,则进入Test Methods,在此你可以直接勾选你想测试的被测试类的方法,Eclipse将自动生成与被选方法相应的测试方法,点击“Fishish”按钮后一个测试用例就创建好了。
三、编写完测试用例后,直接运行Run->Run As->JUnit Test,就可以看到JUnit测试结果: 绿色表示测试通过,只要有1个测试未通过,就会显示红色并列出未通过测试的方法。 下面看一个例子:
源代码:
package hello;
public class Calculator {
public int add(int a, int b) {
return a + b;
}
public int minus(int a, int b) {
return a - b;
}
public int multiply(int a, int b) {
return a * b;
}
public int divide(int a, int b) throws Exception { if (0 == b) {
throw new Exception("除数不能为零");
}
return a / b;
}
}
测试用例:
package hello;
import junit.framework.Assert;
import junit.framework.TestCase;
public class CalculatorTest extends TestCase { private Calculator cal;
protected void setUp() throws Exception { cal = new Calculator();
}
protected void tearDown() throws Exception { super.tearDown();
}
public void testAdd() {
int result = cal.add(1, 2);
Assert.assertEquals(3, result);
}
public void testMinus() {
int result = cal.minus(5, 2);
Assert.assertEquals(3, result);
}
public void testMultiply() {
int result = cal.multiply(4, 2);
Assert.assertEquals(8,result);
}
public void testDivide() {
int result = 0;
try {
result = cal.divide(10, 5);
} catch (Exception e) {
e.printStackTrace();
// 我们期望result = cal.divide(10,5);正常执行;如果进入到catch中说明失败; // 所以我们加上fail。
Assert.fail();// 如果这行没有执行。说明这部分正确。
}
Assert.assertEquals(2, result);
}
}
第二篇:myEclipse中如何使用Junit
myEclipse下使用Junit
一、准备工作:
1. 导入Junit jar包;
2. 在项目目录下新建一个Source Fold(一般命名为 test);
3. 新建一个测试类(一般命名规则为:被测试类名+Test,例如: HelloWordTest) 继承junit.framework.TestCase类;
4. 编写测试方法(方法名必须以test+用例方法名称);
如下
:
二、使用Junit进行测试 Junit被用来测试代码,并且它是由能够测试不同条件的断言方法(assertion method)组成,常用断言方法如下:
? assertEquals(a, b)
测试a是否等于b(a和b是原始类型数值(primitive value)或者必须为实现比较而具有equal方法) ? assertFalse(a)
测试a是否为false(假),a是一个Boolean数值。
? assertNotNull(a)
测试a是否非空,a是一个对象或者null。
? assertNotSame(a, b)
测试a和b是否没有都引用同一个对象。
~ 1 ~
? assertNull(a)
测试a是否为null,a是一个对象或者null。
? assertSame(a, b)
测试a和b是否都引用同一个对象。
? assertTrue(a)
测试a是否为true(真),a是一个Boolean数值。
? 我们使用这些方法来构建JUnit测试。当运行一个JUnit应用程序时,它打开自己的视图(view)
来立即指示哪个测试通过了,哪个测试失败了。
被测试类:
测试类:
~ 2 ~
? 注:执行TestRunner.run(HelloWordTest.class)后会出现:
或
? Time上的小点表示测试个数,如果测试通过则显示OK。否则在小点的后边标上F,表示该测
试失败。
? 综上所叙:编写测试类的基本步骤:
1>;扩展TestCase类;
2>;覆盖runTest()方法(可选);
3>;写一些testXXXXX()方法;
三、Junit4的新特性
1、Hamcrest的断言语法——assertThat
1.导入junit 4和hamcrest-all jar包;
2.assertThat:
基本语法: assertThat( [value], [matcher statement] );
value 是接下来想要测试的变量值;
matcher statement 是使用 Hamcrest 匹配符来表达的对前面变量所期望的值的声明,如果 value 值与 matcher statement 所表达的期望值相符,则测试成功,否则测试失败。
~ 3 ~
2、使用hamcrest的匹配方法
2.1、一般匹配符
? allOf
匹配符表明如果接下来的所有条件必须都成立测试才通过,相当于“与”(&&)
assertThat( testedNumber, allOf( greaterThan(8), lessThan(16) ) );
? anyOf
匹配符表明如果接下来的所有条件只要有一个成立则测试通过,相当于“或”(||)
assertThat( testedNumber, anyOf( greaterThan(16), lessThan(8) ) );
? anything
匹配符表明无论什么条件,永远为true
assertThat( testedNumber, anything() );
? is
匹配符表明如果前面待测的object等于后面给出的object,则测试通过
assertThat( testedString, is( "developerWorks" ) );
? not
匹配符和is匹配符正好相反,表明如果前面待测的object不等于后面给出的object,则测试通过
assertThat( testedString, not( "developerWorks" ) );
2.2、字符串相关匹配符
? containsString
匹配符表明如果测试的字符串testedString包含子字符串"developerWorks"则测试通过
assertThat( testedString, containsString( "developerWorks" ) );
? endsWith
匹配符表明如果测试的字符串testedString以子字符串"developerWorks"结尾则测试通过
assertThat( testedString, endsWith( "developerWorks" ) );
? startsWith
匹配符表明如果测试的字符串testedString以子字符串"developerWorks"开始则测试通过
assertThat( testedString, startsWith( "developerWorks" ) );
? equalTo
匹配符表明如果测试的testedValue等于expectedValue则测试通过,equalTo可以测试数值之间,字符串之间和对象之间是否相等,相当于Object的equals方法
~ 4 ~
assertThat( testedValue, equalTo( expectedValue ) );
? equalToIgnoringCase
匹配符表明如果测试的字符串testedString在忽略大小写的情况下等于 "developerWorks"则测试通过
assertThat( testedString, equalToIgnoringCase( "developerWorks" ) );
? equalToIgnoringWhiteSpace
匹配符表明如果测试的字符串testedString在忽略头尾的任意个空格的情况下等于"developerWorks"则测试通过,注意:字符串中的空格不能被忽略
assertThat( testedString, equalToIgnoringWhiteSpace( "developerWorks" ) );
2.3、数值相关匹配符
? closeTo
匹配符表明如果所测试的浮点型数testedDouble在20.0±0.5范围之内则测试通过
assertThat( testedDouble, closeTo( 20.0, 0.5 ) );
? greaterThan
匹配符表明如果所测试的数值testedNumber大于16.0则测试通过
assertThat( testedNumber, greaterThan(16.0) );
? lessThan
匹配符表明如果所测试的数值testedNumber小于16.0则测试通过
assertThat( testedNumber, lessThan (16.0) );
? greaterThanOrEqualTo
匹配符表明如果所测试的数值testedNumber大于等于16.0则测试通过
assertThat( testedNumber, greaterThanOrEqualTo (16.0) );
? lessThanOrEqualTo
匹配符表明如果所测试的数值testedNumber小于等于16.0则测试通过
assertThat( testedNumber, lessThanOrEqualTo (16.0) );
2.4、collection相关匹配符
? hasEntry
匹配符表明如果测试的Map对象mapObject含有一个键值为"key"对应元素值为"value"的Entry项则测试通过
assertThat( mapObject, hasEntry( "key", "value" ) );
? hasItem
匹配符表明如果测试的迭代对象iterableObject含有元素“element”项则测试通过
assertThat( iterableObject, hasItem ( "element" ) );
~ 5 ~
? hasKey
匹配符表明如果测试的Map对象mapObject含有键值“key”则测试通过
assertThat( mapObject, hasKey ( "key" ) );
? hasValue
匹配符表明如果测试的Map对象mapObject含有元素值“value”则测试通过
assertThat( mapObject, hasValue ( "key" ) );
2.5、Matcher 匹配符联合使用
? not和equalTo
表示“不等于”
assertThat( something, not( equalTo( "developer" ) ) );
? not和containsString
表示“不包含子字符串”
assertThat( something, not( containsString( "Works" ) ) );
? anyOf和containsString
表示“包含任何一个子字符串”
assertThat(something, anyOf(containsString("developer"), containsString("Works")));
3、JUnit4 注解
? @Test: 测试方法
? @Ignore: 被忽略的测试方法
? @Before: 每一个测试方法之前运行
? @After: 每一个测试方法之后运行
? @BeforeClass: 所有测试开始之前运行
? @AfterClass: 所有测试结束之后运行
~ 6 ~
四、附录
Junit4注解式测试方法示例(测试类不用继承TestCase) 被测试类:
测试类:
~ 7 ~
免费共享资源,从我做起!
~ 8 ~