JUnit——Java单元测试

本文详细介绍JUnit测试框架的基本概念、常用注解及其应用场景。包括如何创建测试类、运行测试方法、测试套件、参数化测试等内容。

JUnit是一个简单的框架,用于编写可重复的测试。 它是单元测试框架的xUnit架构的一个实例。JUnit官网

@Test:将一个普通的方法修饰成为一个测试方法
    >@Test(expected=XX.class):抛出此异常时表示测试成功
    >@Test(timeout=x毫秒 ):如果在时间x内没有执行完,则停止
@BeforeClass:它会在所有的方法运行前被执行,static修饰
@AfterClass:它会在所有的方法运行结束后被执行,static修饰
@Before:会在每一个测试方法被运行前执行一次
@After:会在每一个测试方法运行后被执行一次
@Ignore:所修饰的测试方法会被测试运行器忽略
@RunWith:可以更改测试运行器 org.junit.runner.Runner

Eclipse软件自带JUnit,所以不用再去下载JUnit的jar包等。

因为测试类只是在我们写代码的时候使用,为了项目发布时便于删除,为了测试方便,我们一般在src同级建个test,test文件夹下的包名与类名与src下的相同。

1.导入JUnit包。鼠标右击项目,Build Path>Configure Build Path...>Add Library..>JUnit

2.新建测试类。New>JUnit Case

如果是建立某个类对应的测试类,那么可以鼠标右键要测试的类,New>JUnit Test Case

3.点击Next,勾选要测试的方法

Calculate.java

package com.f145a.util;

public class Calculate {
	public int add(int a, int b) {
		return a + b;
	}

	public int subtract(int a, int b) {
		return a - b;
	}

	public int multiply(int a, int b) {
		return a * b;
	}

	public int divide(int a, int b) {
		return a / b;
	}
}

CalculateTest.java(测试类)

package com.f145a.util;

import static org.junit.Assert.*;
import org.junit.Test;
import com.f145a.util.Calculate;

public class CalculateTest {

	/*
	 * 1.测试方法上必须使用@Test进行修饰
	 * 2.测试方法必须使用public void 进行修饰,不能带任何的参数
	 * 3.新建一个源代码目录来存放我们的测试代码
	 * 4.测试类的包应该和被测试类保持一致
	 * 5.测试单元中的每个方法必须可以独立测试,测试方法间不能有任何的依赖
	 * 6.测试类使用Test作为类名的后缀(不是必须)
	 * 7.测试方法使用test作为方法名的前缀(不是必须)
	 */
	@Test
	public void testAdd() {
		assertEquals(6, new Calculate().add(3,3));
	}
	
	@Test
	public void testSubtract() {
		assertEquals(3, new Calculate().subtract(5,2));
	}
	
	@Test
	public void testMultiply() {
		assertEquals(4, new Calculate().multiply(2, 2));
	}
	
	@Test
	public void testDivide() {
		assertEquals(3, new Calculate().divide(6, 2));
	}
}

4.运行测试类或其中的测试方法

可以右键点击测试类,Run as>JUnit Test,运行整个测试类;或右键点击某个方法(如:testAdd)运行测试

运行测试类后可以看到这样一个窗口,可以看到运行的@Test方法个数,出现的异常及错误,如图绿色显示条说明测试成功,如果是红色显示条,则说明出现了错误。

测试类的运行流程

JUnitFlowTest.java

package com.f145a.util;

import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;

public class JUnitFlowTest {

	/*
	 * 1.@BeforeClass修饰的方法会在所有方法被调用前被执行, 而且该方法是静态的,所以当测试类被加载后接着就会运行它,
	 * 而且在内存中它只会存在一份实例,它比较适合加载配置文件。
	 * 2.@AfterClass所修饰的方法通常用来对资源的清理,如关闭数据库的连接
	 * 3.@Before和@After会在每个测试方法的前后各执行一次。
	 */
	@BeforeClass
	public static void setUpBeforeClass() throws Exception {
		System.out.println("this is beforeClass...");
	}

	@AfterClass
	public static void tearDownAfterClass() throws Exception {
		System.out.println("this is afterClass...");
	}

	@Before
	public void setUp() throws Exception {
		System.out.println("this is before...");
	}

	@After
	public void tearDown() throws Exception {
		System.out.println("this is after");
	}

	@Test
	public void test1() {
		System.out.println("this is test1...");
	}

	@Test
	public void test2() {
		System.out.println("this is test2...");
	}

}

运行此测试类可以在控制台看到这样的输出循序

测试失败的情况

ErrorAndFailureTest.java

package com.f145a.util;

import static org.junit.Assert.*;
import org.junit.Test;

public class ErrorAndFailureTest {
	/*
	 * 1.Failure一般由单元测试使用的断言方法判断失败所引起的,这经表示 测试点发现了问题 ,就是说程序输出的结果和我们预期的不一样。
	 * 2.error是由代码异常引起的,它可以产生于测试代码本身的错误,也可以是被测试代码中的 一个隐藏的bug
	 * 3.测试用例不是用来证明你是对的,而是用来证明你没有错。
	 */
	@Test
	public void testAdd() {
		assertEquals(5, new Calculate().add(3, 3));
	}

	@Test
	public void testDivide() {
		assertEquals(3, new Calculate().divide(6, 0));
	}
}

分别运行两个测试方法,可以在Failure Trace模块看到抛出的异常,

测试套件

在项目测试中我们要测试的类可能会很多,那么一个个测试就显得有点麻烦,这是我们可以定义个测试套件

SuiteTest.java

package com.f145a.util;

import org.junit.runner.RunWith;
import org.junit.runners.Suite;

@RunWith(Suite.class) // 设置为测试套件入口类
@Suite.SuiteClasses({ TaskTest1.class, TaskTest2.class, TaskTest3.class })
public class SuiteTest {
	/*
	 * 1.测试套件就是组织测试类一起运行的
	 * 
	 * 写一个作为测试套件的入口类,这个类里不包含其他的方法 更改测试运行器Suite.class
	 * 将要测试的类作为数组传入到Suite.SuiteClasses({})
	 */

}

TaskTest1.java

package com.f145a.util;

import org.junit.Test;

public class TaskTest1 {

	@Test
	public void test() {
		System.out.println("this is TaskTest1...");
	}

}

TaskTest2.java

package com.f145a.util;

import org.junit.Test;

public class TaskTest2 {

	@Test
	public void test() {
		System.out.println("this is TaskTest2...");
	}

}

TaskTest3.java

package com.f145a.util;

import org.junit.Test;

public class TaskTest3 {

	@Test
	public void test() {
		System.out.println("this is TaskTest3...");
	}

}

运行SuiteTest即可

参数化设置

有些测试方法代码可能大同小异,不同的只是测试数据和预期值,为了提高代码的可重用度,我们可以采用参数化设置

ParameterTest.java

package com.f145a.util;

import static org.junit.Assert.*;
import java.util.Arrays;
import java.util.Collection;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;

@RunWith(Parameterized.class)
public class ParameterTest {
	/*
	 * 1.更改默认的测试运行器为RunWith(Parameterized.class)
	 * 2.声明变量来存放预期值 和结果值
	 * 3.声明一个返回值 为Collection的公共静态方法,并使用@Parameters进行修饰
	 * 4.为测试类声明一个带有参数的公共构造函数,并在其中为之声明变量赋值
	 */
	int expected =0;
	int input1 = 0;
	int input2 = 0;
	
	@Parameters
	public static Collection<Object[]> t() {
		return Arrays.asList(new Object[][]{
				{3,1,2},
				{4,2,2}
		}) ;
	}
	
	public ParameterTest(int expected,int input1,int input2) {
		this.expected = expected;
		this.input1 = input1;
		this.input2 = input2;
	}
	
	@Test
	public void testAdd() {
		assertEquals(expected, new Calculate().add(input1, input2));
	}

}

欢迎访问我的个人博客http://www.chengzequn.top

转载于:https://my.oschina.net/chengzequn/blog/790571

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值