Java单元测试工具:JUnit4——JUnit详解之运行流程及常用注解

本文主要是介绍Java单元测试工具:JUnit4——JUnit详解之运行流程及常用注解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.JUnit的运行流程

1.1 新建测试类
右键被测试类,新建一个测试类。弹出框中,首先改变测试类所在的代码目录,然后勾选4个方法:

1.2 修改测试类代码
如下:
package jtzen9.util;
import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;public class JunitFlowTest {@BeforeClasspublic static void setUpBeforeClass() throws Exception {System.out.println("this is setUpBeforeClass()...");}@AfterClasspublic static void tearDownAfterClass() throws Exception {System.out.println("this is tearDownAfterClass()...");}@Beforepublic void setUp() throws Exception {System.out.println("this is setUp()...");}@Afterpublic void tearDown() throws Exception {System.out.println("this is tearDown()...");}@Testpublic void test() {System.out.println("this is test()...");}}

控制台输出如下:


在测试类中,增加一个test2()测试方法:
......
@Test
public void test2(){System.out.println("this is test2()...");
}
......

        再出运行,控制台输出结果如下:

1.3 总结说明
        ①@BeforeClass修饰的方法会在所有方法被调用前被执行,而且该方法是静态的,所以当测试类被加载后接着就会运行它,而且在内存中它只会存在一份实例,它比较适合加载配置文件,进行初始化等等
        ②@AfterClass所修饰的方法会在所有方法被调用后被执行,通常用来对资源的清理,如关闭数据库的连接
        ③@Before和@After会在 每个测试方法的前后各执行一次。

2.JUnit常用注解

        * @Test:将一个普通的方法修饰成为一个测试方法
                           @Test(expected=XX.class)
                           @Test(timeout=毫秒)
        * @BeforeClass:它会在所有的方法运行前被执行,static修饰
        * @AfterClass:它会在所有的方法运行结束后被执行,static修饰
        * @Before:会在每一个测试方法被运行前执行一次
        * @After:会在每一个测试方法运行后被执行一次
        * @Ignore:所修饰的测试方法会被测试运行器忽略
        * @RunWith:可以更改测试运行器 org.junit.runner.Runner
2.1 @Test、@Ignore的测试
例子代码:
package jtzen9.util;import static org.junit.Assert.assertEquals;import org.junit.Ignore;
import org.junit.Test;public class AnotationTest {@Test(expected=ArithmeticException.class)public void testDivide() {assertEquals("除法有问题",3, new Calculate().divide(6, 0)); //将除数设置为0}@Test(timeout=2000)public void testWhile() {while(true) {System.out.println("run forever...");  //一个死循环}}@Test(timeout=3000)public void testReadFile(){try {Thread.sleep(2000);       //模拟读文件操作} catch (InterruptedException e) {e.printStackTrace();}}@Ignore("...")@Testpublic void testIgnore() {System.out.println("会运行吗?");  }
}


输出结果:


说明:
①testDivide()方法中,将除数设为0,本会抛出Error,但设置了@Test(expected=ArithmeticException.class),说明我们预期它会抛出一个算术异常,所以程序结果也符合我们的预期。
②testWhile()方法是一个死循环,但设置了@Test(timeout=2000),即2秒之后,自动结束循环
③testReadFile()方法模拟读取文件操作,设置读取超时时间为3秒,等于或大于测试时间则认为不成功,而程序睡眠了2秒,没有超时。这里表示用作一些性能的测试。
④testIgnore()方法,因为使用的@Ignore注解,所以不会运行。
2.2 @RunWith
当类被@RunWith注解修饰,或者类继承了一个被该注解修饰的类,JUnit将会使用这个注解所指明的运行器(runner)来运行测试,而不是JUnit默认的运行器。

这篇关于Java单元测试工具:JUnit4——JUnit详解之运行流程及常用注解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/722080

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物