Junit4 简单使用

一、环境搭建

对于习惯使用Eclipse开发平台来说,Junit早已是非常通常的插件,在Eclipse开发平台中,可以非常方便地搭建Junit测试环境。

1、在Eclipse上创建工程,任何Java工程都行。

2、引入Junit的libraries库,选用Junit4。如下图所示:

3、新建一个Java类,用于演示Junit4类的自动生成,java代码如下:

[java] view plaincopy

  1. package com.hy;
  2. public class Demo {
  3. public void method1() {
  4. System.out.println("method1");
  5. }
  6. public void method2() {
  7. System.out.println("method2");
  8. }
  9. public void method3() {
  10. System.out.println("method3");
  11. }
  12. }

4、在该类上右键单击新建,选JUnit Test Case,自动生成一个对应的测试类,如下图所示:

4、这样就能自动地生成对应的测试类了,测试类代码发下:

[java] view plaincopy

  1. package com.hy;
  2. import static org.junit.Assert.*;
  3. import org.junit.After;
  4. import org.junit.AfterClass;
  5. import org.junit.Before;
  6. import org.junit.BeforeClass;
  7. import org.junit.Test;
  8. public class DemoTest {
  9. @BeforeClass
  10. public static void setUpBeforeClass() throws Exception {
  11. }
  12. @AfterClass
  13. public static void tearDownAfterClass() throws Exception {
  14. }
  15. @Before
  16. public void setUp() throws Exception {
  17. }
  18. @After
  19. public void tearDown() throws Exception {
  20. }
  21. @Test
  22. public void testMethod1() {
  23. fail("Not yet implemented");
  24. }
  25. @Test
  26. public void testMethod2() {
  27. fail("Not yet implemented");
  28. }
  29. @Test
  30. public void testMethod3() {
  31. fail("Not yet implemented");
  32. }
  33. }

5、如此一来,测试类环境的搭建过程就完成了,最后要做的就是,根据实际的业务需求,对测试类中的测试方法编写单元测试代码,直到运行调通。

二、基本规则

从上面的演示可知,测试类名一般都以Test结尾,测试方法名以test开头。这个也是Junit的基本命名规则。

三、Junit注解

我们此次针对的是Junit4版本,注解也是在Junit4版本才有的,之前的版本并无注解功能。而注解开发基本上被认为是一种优秀的设计,所以我们写单元测试用例时,尽可能地去了解并使用注解。

@Test:使用该注解的方法为测试方法,自动运行时能够识别并被执行

包含两个参数:expected=XXXException.class 期望出现的异常

timeout=xxx 设定程序运行的超时时间

@Ignore:被忽略的测试方法

@Before:在每个测试方法之前运行

@After: 在每个测试方法之后运行

@BeforeClass:在所有测试开始之前运行

@AfterClass:在所有测试开始之后运行

以上几个就是Junit 4的关键注解,熟练使用这几个注解,将来的测试用例编写肯定能事半功倍。

注意:@Before与@BeforeClass的区别

@Before会加在每个方法前执行,即有几个@Test就会执行几遍。

@BeforeClass 只在所有测试之前执行,只会执行一次。并且@BeforeClass修饰的方法必须是公有的静态方法(public static )。

@After和@AfterClass也类似

每个测试类中这四个注解不能重复使用,一个方法只能从这四个注解中挑选其中一个。

四、基本写法

1、setUp(),tearDown(),setUpBeforeClass(),tearDownAfterClass()这四个方法其实就是对应的 @Before、@BeforeClass、@After、@AfterClass这四个注解,在Junit4开始使用注解时,其实可以替代这四个方法的功能,只是这四个方法是历史遗留方法,可以考虑使用,也可以直接使用注解替代。

2、Assert是单元测试用例的核心,建议使用静态导入。

3、待测试对象,一般建议设计成静态的。

4、测试方法的要求:带@Test注解,方法名随意,返回值必须为void,不能带有参数,可以声明异常(可以参考演示代码)。

5、Fixture方法的作用

前面介绍的@Before、@BeforeClass、@After、@AfterClass注解修饰的方法,即为Fixture方法,它是在某些阶段必然被调用的方法,如注解功能所示。

@Before、@After修饰方法的一个用处是对待测试对象的“复原”操作,如成员变量回归,数据库回滚等,目的是消除@Test方法之间的耦合。也可以用来打印日志。

@BeforeClass修饰方法可以设计成用来加载一些耗时耗力的操作,如文件流的读取,数据库连接等,然后在@AfterClass中释放对应的资源即可。

6、限时测试

@Test(timeout=1000)超时时间单位为毫秒

用于测试是否有死循环工是实时性要求比较高的用例,这个非常方便而且非常有用。

7、测试异常

@Test(expected=XXXException.class) XXXException为声明式异常

用来验证声明式异常,注意此测试的含义:出现了期望的异常,叫做正常,若没出现异常,Junit会报错,认为不正常。这段描述有些拗口,请各位多琢磨琢磨。

8、运行器Runner

类注解@RunWith,指定不同的类可以改变测试类的行为

9、参数化测试

主要是针对一些相同功能却要进行多组参数测试的情况,开发步骤如下:

1)参数化测试的类和普通测试类不同,要用特殊的Runner,类注解需要改为@RunWith(Parameterized.class)

2)定义该测试类的成员变量,一个放测试参数,另一个放该参数产生的预期结果

3)定义测试数据集合方法 public static Collection data() {...},注意该方法要用@Parameters修饰(数据格式为二维数组)

4)定义带参数的构造函数,注意定义数据集合时,要和构造函数参数次序一致

其他的与普通测试类似

注意:若测试数据有两条,则该类下的所有@Test的方法都会执行两次,所以参数化测试的类不要和别的@Test放在一起。参数化测试方法一般建议单独建立类。

演示代码如下:

[java] view plaincopy

  1. //指定@RunWith
  2. @RunWith(Parameterized.class)
  3. public class ParamTest {
  4. //定义成员变量,i为测试参数,j为测试结果
  5. private int i;
  6. private int j;
  7. //构造函数
  8. public ParamTest(int i, int j) {
  9. super();
  10. this.i = i;
  11. this.j = j;
  12. }
  13. //测试数据集合,注意使用的注解,数据结构及次序
  14. @Parameters
  15. public static Collection data() {
  16. return Arrays.asList(new Object[][]{{1,2},{3,4},{4,6}});
  17. }
  18. @Test
  19. public void testMethod1() {
  20. System.out.println(i);
  21. System.out.println(j);
  22. //简单测试,只测试参数加1会不会等于预期结果
  23. Assert.assertEquals(i+1, j);
  24. }
  25. }

预期的执行结果是前两组参数测试正确,最后一组测试错误,运行后的结果为:

执行结果与预期结果相符合,OK

10、打包测试

将测试类集中起来运行,提高测试效率,代码如下:

[java] view plaincopy

  1. @RunWith(Suite.class)
  2. @Suite.SuiteClasses({
  3. DemoTest.class
  4. })
  5. public class ModuleTest {
  6. public ModuleTest() {
  7. // TODO Auto-generated constructor stub
  8. }
  9. }

1)@Suite.SuiteClasses里面的是需要打包测试的类

2)该类中可以为空,类名建议为模块名+Test结尾,如ModuleTest.java

以上是Junit4的最基本的使用,相信掌握了这些,对于编写常规的测试用例已经不是难事,同样,Junit还有更多更有意思的功能等待我们去挖掘……

时间: 2024-10-26 19:47:24

Junit4 简单使用的相关文章

Junit4简单教程

个人感觉看谁的都不如直接看官网的教程,简单.可靠 JUnit4官网教程 :点击打开链接 使用Eclipse 建立一个Java 功能,并导入一下两个JAR包(可从官网上下载两个JAR包, 注:网络连接可能存在问题,可将http连接改为https即可): 本教程功能 (1) JUnit4的基本使用方法, (2) 多个测试类一起执行的方法,Suites.class (3)一次性测试多个测试用例的情况,Parameters 工程的目录 代码说明: Caculator.java:计算类,方法包括add,

spring-boot2.0 单元测试JUnit4

spring-boot2.0 单元测试JUnit4 简单在spring-boot2.0版本中使用junit源码如下:@SpringBootTest(classes = DemoT002Application.class) 只要加上这个就能使用DemoT002Application.class是你的程序入口文件 @RunWith(SpringJUnit4Cla***unner.class) // SpringJUnit支持,由此引入Spring-Test框架支持! @SpringBootTest(

Junit4的简单使用

junit4的简单使用 测试套件的使用 测试类1 package com.westward; import static org.junit.Assert.*; import org.junit.Test; public class TaskTest1 { @Test public void test() { System.out.println("tasktest1"); } } 测试类2 package com.westward; import static org.junit.A

【原创】junit4中Assert断言的使用以及Mockito框架mock模拟对象的简单使用

编写测试代码时,我们总会有我们对被测方法自己预期的值,以及调用被测方法后返回的真实执行后的值.需要断言这两个值是否相等.抛出异常.hash码等等情况... 这里博主主要介绍一下简单的断言和mock.如果已经对junit测试有过相对了解的,请略过这篇文章. 下面是我准备的节点类: 1 package demo; 2 3 /** 4 * @author Lcc 5 * 6 */ 7 public class Node { 8 private int value; 9 10 public Node(i

junit4使用心得

没使用junit4之前,测试代码都是通过写一个main方法,在不断的new对象,调用方法来发现错误,使用junit4之后,我发现测试变得简单了,每写一个功能块就可以通过junit4来实现该功能. 那么接下来看如何使用junit4来测试方法中的代码,从而不需要写main方法,是不是非常方便. 在 JUnit4 中,测试是由 @Test 注释来识别的,以前所有版本的 JUnit 都使用命名约定和反射来定位测试,并且要继承TestCase类,使用JUnit4后,测试用例类可以不继承TestCase类,

junit4进行单元测试

一.前言 提供服务的时候,为了保证服务的正确性,有时候需要编写测试类验证其正确性和可用性.以前的做法都是自己简单写一个控制层,然后在控制层里调用服务并测试,这样做虽然能够达到测试的目的,但是太不专业了.还是老老实实的编写测试类进行测试吧. 二.Junit4依赖 <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</v

解决String TestContext下使用junit4抛出异常(java.lang.NoClassDefFoundError)的问题

Spring版本2.5.5,JUnit 版本 4.8.1,使用了 Spring TestContext 的 SpringJUnit4ClassRunner.一直使用这个版本的JUnit,在写简单的测试时不会抛错,直到今天开始尝试写规范的JUnit测试代码,抛出了如下的错误: 解决方法: 使用JUnit4.4版本.

Junit(1)在Eclipse中使用JUnit4进行单元测试

我们在编写大型程序的时候,需要写成千上万个方法或函数,这些函数的功能可能很强大,但我们在程序中只用到该函数的一小部分功能,并且经过调试可以确定,这 一小部分功能是正确的.但是,我们同时应该确保每一个函数都完全正确,因为如果我们今后如果对程序进行扩展,用到了某个函数的其他功能,而这个功能有bug的话,那绝对是一件非常郁闷的事情.所以说,每编写完一个函数之后,都应该对这个函数的方方面面进行测试,这样的测试我们称之为单元测试. 传统的编程方式,进行单元测试是一件很麻烦的事情,你要重新写另外一个程序,在

用JUnit4进行单元测试代码编写

JUnit4简介 Junit是一个可编写重复测试的简单框架,是基于Xunit架构的单元测试框架的实例.JUnit4是JUnit框架有史以来的最大改进,其主要目标便是利用JDK 5的Annotation特性简化测试用例的编写.JDK 5里可以静态导入,例如import static org.junit.Assert.*;.Annotation又称注解(或元数据),其实就是@Before.@After.@BeforeClass.@AfterClass.@Test等等. @Before @Before