一、测试环境
- eclipse
- JUnit4
- EasyMock-4.0
一般eclipse自带有JUnit4版本的测试包
EasyMock的jar包也可以自己去官网下载
链接: easymock-4.0.2.jar
提取码: s2bp
二、导入包
1. 创建工程JUnit_test,导入JUnit测试包
导入成功
二、简单的JUnit测试
1. 创建包名com.test,创建类demo.java
demo.java
package com.test;
import java.util.Arrays;
public class demo {
/*
* 判断三角形类型的方法
* 返回值0,输入错误;
* 返回值1,普通三角形;
* 返回值2,等腰三角形;
* 返回值3,等边三角新。
*/
public int CheckType(int a, int b, int c){
int [] ary = {a, b, c};
Arrays.sort(ary);
if(ary[0]<=0 || ary[0]+ary[1]<=ary[2]){
return 0;
}
else if(ary[0] == ary[1] || ary[1] == ary[2]){
if(ary[0] == ary[2]){
return 2; //这里故意写一个bug,应该返回3,后面会在测试中找出来
}
else{
return 2;
}
}
else{
return 1;
}
}
}
2. 生成JUnit测试类
生成成功
3. 编写测试类
JUnit注解
参考:junit常用注解详细说明
博主:Tobey唐
这里只简单摘了一部分,原博客更加详细
每个注解都要导入相应的包
注解 | 描述 |
---|---|
@Test | 声明测试方法,继承JUnit测试基类,方法必须是public void,方法名随意 |
@BeforeClass | 在运行测试之前,运行一次这个方法,必须是public static void |
@AfterClass | 与@BefreClass相对应,在完成所有测试之后,运行一次方法,同样必须是public static void |
@Before | 在每个测试用例之前都运行一次,必须是public void |
@After | 与@Before对类似 |
@Ignore | 忽略测试用例,可以对尚未完成的测试用例进行忽略 |
@Runwith | 放在测试类名之前,用来确定这个类怎么运行,也可以不标注,将使用默认运行器 |
@Parameters | 用于使用参数化功能 |
demoTest.java
package com.test;
import static org.junit.Assert.*;
import org.junit.Before;
import org.junit.Test;
import org.junit.After;
import org.junit.Ignore;
public class demoTest {
static int Testnum = 1;
demo dm = new demo();
@Before
public void printBefore(){
System.out.println("第"+Testnum+"次测试");
}
@Test
public void test1() {
assertEquals(0, dm.CheckType(0, 0, 0));
System.out.println("测试"+Testnum+"通过");
}
@Test
public void test2() {
assertEquals(0, dm.CheckType(0, 0, 1));
System.out.println("测试"+Testnum+"通过");
}
@Test
public void test3() {
assertEquals(0, dm.CheckType(0, 1, 1));
System.out.println("测试"+Testnum+"通过");
}
@Test
public void test4() {
assertEquals(3, dm.CheckType(1, 1, 1));
System.out.println("测试"+Testnum+"通过");
}
@Test
public void test5() {
assertEquals(0, dm.CheckType(1, 1, 2));
System.out.println("测试"+Testnum+"通过");
}
@Test
public void test6() {
assertEquals(2, dm.CheckType(2, 2, 3));
System.out.println("测试"+Testnum+"通过");
}
@Test
public void test7() {
assertEquals(1, dm.CheckType(3, 4, 5));
System.out.println("测试"+Testnum+"通过");
}
@Ignore("测试还没有写")
@Test
public void test8() {
}
@After
public void printAfter(){
System.out.println("测试"+Testnum+"结束");
Testnum++;
}
}
4. 测试结果
运行测试类
结果,棕色的表示有bug,可以依此找到bug的位置
三、使用EasyMock进行测试
EasyMock使用场景:
你和另一个小伙伴A合作完成一个项目,你比较勤快,完成了自己代码的编写工作,你想要调用A的接口来测试你的代码是不是有逻辑上的bug,A比较懒,接口还没有写好,这时候你不需要干等着,可以使用EasyMock来模拟接口,独立完成自己的测试。
1. 导入文章前面下载好的EasyMock的jar包
先把jar包拖到工程文件的src目录里面
再添加到Build Path
2. 创建包名com.easymock,创建Interface类mock.java
mock.java
package com.easymock;
public interface mock {
//可以看到,这个接口是没有实体的,我们需要用EasyMock来模拟实体
public int pay(int money);
}
3. mock测试类
同样按照【步骤二-2】new一个JUnit Test Case
mockTest.java
package com.easymock;
import static org.junit.Assert.assertEquals;
import org.easymock.EasyMock;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
public class mockTest {
@Before
public void printBefore(){
System.out.println("my easymock test");
}
@Test
public void test1() {
System.out.println("Start test");
//使用EasyMock生成Mock对象
mock my = EasyMock.createMock(mock.class);
//设定Mock对象的预期行为和输出
EasyMock.expect(my.pay(30)).andReturn(300);
//将Mock对象切换到replay状态
EasyMock.replay(my);
//进行单元测试
assertEquals(300, my.pay(30));
//对Mock进行行为验证
EasyMock.verify(my);
}
@After
public void printAfter(){
System.out.println("test end");
}
}
4. 测试结果