Java单元测试框架(一)——JUnit4

简介: Java单元测试框架(一)——JUnit4

1.基础架构


被测代码:Calculator.java

package JUnit.com.jerry;
public class Calculator {
    private static int result; // 静态变量,用于存储运行结果
    public void add(int n) {
        result = result + n;
    }
    public void substract(int n) {
        result = result - n;  
    }
    public void multiply(int n) {
      result = result * n;
    } 
    public void divide(int n) {
        result = result / n;
}
public void square(int n) {
     result = n * n;
}
public void squareRoot(int n) {
    for (; ;) ;            //Bug : 死循环
}
public void clear() {     // 将结果清零
    result = 0;
}
public int getResult() {
    return result;
}
}


基本的测试代码:CalculatorTest.java

package JUnit.com.jerry;
import static org.junit.Assert.*;
import org.junit.Before;
import org.junit.Test;
public class CalculatorTest {
    private static Calculator calculator = new Calculator();
    @Before
    public void setUp() throws Exception {
        calculator.clear();
    }
    @Test
    public void testAdd() {
        calculator.add(2);
        calculator.add(3);
        assertEquals(5, calculator.getResult());
    }
    @Test
    public void testSubstract() {
        calculator.add(5);
        calculator.substract(3);
        assertEquals(2, calculator.getResult());
    }
    @Test
    public void testMultiply() {
        calculator.add(3);
        calculator.multiply(2);
        assertEquals(6, calculator.getResult());
    }
@Test
    public void testDivide() {
        calculator.add(9);
        calculator.divide(3);
        assertEquals(3, calculator.getResult());
    }


2. JUnit4的修饰符


修饰符

含义

@Before

每个用例前执行

@Test

下面是一个测试用例

@After

每个用例后执行

@BeforeClass

类中所有用例前执行

@AfterClass

类中所有用例后执行

@Ignore

测试类或测试方法不执行

@Categories

表示单元测试类别


3. JUnit4的断言


断言方法

断言描述

assertEquals([String  message],expected,actual)

expected==actual,测试通过(用于整型数字)

assertEquals([String  message],expected,actual,tolerance)

expected==actual,测试通过,tolerance为浮点数的精度

assertTrue ([String  message],Boolean condition) 

condition条件成立,测试通过

assertFalse([String  message],Boolean condition) 

condition条件不成立,测试通过

assertNull([String  message],Object object)

object为空,测试通过

assertNotNull([String  message],Object object)

Object不为空,测试通过

assertSame ([String  message],expected,actual) 

expectedactual相同,测试通过

assertNotSame  ([String message],expected,actual) 

expectedactual相同,测试通过

fail([String  message]) 

直接直接失败


4. 延迟测试


@Test(timeout=1000 ) //1000毫秒
    Public void squareRoot()  {
        calculator.squareRoot(4);
        assertEquals(2 , calculator.getResult());
     }


由于squareRoot方法是一个死循环,为了保证测试用例不至于无限制等待,在@Test后使用(timeout=1000),意思是等待1000毫秒,如果1000毫秒内没有出结果,默认测试失败


5. 参数化测试


package JUnit.com.jerry;
import  static  org.junit.Assert.assertEquals;
import  org.junit.Test;
import  org.junit.runner.RunWith;
import  org.junit.runners.Parameterized;
import  org.junit.runners.Parameterized.Parameters;
import  java.util.Arrays;
import  java.util.Collection;
@RunWith(Parameterized.class )
public   class SquareTest {
private static final Object[] String = null;
private  static  Calculator calculator  =   new  Calculator();
private   int  param;
private   int  result;
@Parameters
public static Collection data()  {
    return  Arrays.asList( new  Object[][] {
            { 2 ,  4 } ,
            { 0 ,  0 } ,
            {-3 ,  9 } ,
            {-15 ,  225 } ,
    } );
}
// 构造函数,对变量进行初始化 
public SquareTest( int param, int result)  {
      this.param=param;
      this.result =result;
} 
@Test
public  void  square()  {
     calculator.square(param);
     assertEquals(result, calculator.getResult());
  } 
}


参数化测试必须使用Parameterized.class运行器,参数化方法使用

@Parameters装饰器。


6. @BeforeClass和@AfterClass


public class CalculatorTest {
@BeforeClass
public void setUp() throws Exception {
    db.connect();
}
@Before
@test
@After
@AfterClass
public void tearDown() throws Exception {
    db.disconnect();
}


  • 由于所有的测试用例开始都要连接数据库,结束后都要断开数据库,这个时候如果使用@Before和@After装饰符势必会测试执行的速度,JUnit4提供了@BeforeClass和@AfterClass,可以帮助解决这种情况。


7. 批量运行


import org.JUnit.runner.RunWith;
import org.JUnit.runners.Suite;
@RunWith(Suite.class)
@Suite.SuiteClasses({
CalculatorTest.class,
SquareTest.class 
} )
public class  AllCalculatorTests{
}


使用Suite.class运行器,可以依次运行Suite.SuiteClasses定义类中的所有测试用例。


目录
相关文章
|
2月前
|
Java 数据库
在Java中使用Seata框架实现分布式事务的详细步骤
通过以上步骤,利用 Seata 框架可以实现较为简单的分布式事务处理。在实际应用中,还需要根据具体业务需求进行更详细的配置和处理。同时,要注意处理各种异常情况,以确保分布式事务的正确执行。
|
2月前
|
消息中间件 Java Kafka
在Java中实现分布式事务的常用框架和方法
总之,选择合适的分布式事务框架和方法需要综合考虑业务需求、性能、复杂度等因素。不同的框架和方法都有其特点和适用场景,需要根据具体情况进行评估和选择。同时,随着技术的不断发展,分布式事务的解决方案也在不断更新和完善,以更好地满足业务的需求。你还可以进一步深入研究和了解这些框架和方法,以便在实际应用中更好地实现分布式事务管理。
|
25天前
|
存储 安全 Java
Java 集合框架中的老炮与新秀:HashTable 和 HashMap 谁更胜一筹?
嗨,大家好,我是技术伙伴小米。今天通过讲故事的方式,详细介绍 Java 中 HashMap 和 HashTable 的区别。从版本、线程安全、null 值支持、性能及迭代器行为等方面对比,帮助你轻松应对面试中的经典问题。HashMap 更高效灵活,适合单线程或需手动处理线程安全的场景;HashTable 较古老,线程安全但性能不佳。现代项目推荐使用 ConcurrentHashMap。关注我的公众号“软件求生”,获取更多技术干货!
41 3
|
9天前
|
并行计算 算法 Java
Java中的Fork/Join框架详解
Fork/Join框架是Java并行计算的强大工具,尤其适用于需要将任务分解为子任务的场景。通过正确使用Fork/Join框架,可以显著提升应用程序的性能和响应速度。在实际应用中,应结合具体需求选择合适的任务拆分策略,以最大化并行计算的效率。
36 23
|
2月前
|
存储 缓存 安全
Java 集合框架优化:从基础到高级应用
《Java集合框架优化:从基础到高级应用》深入解析Java集合框架的核心原理与优化技巧,涵盖列表、集合、映射等常用数据结构,结合实际案例,指导开发者高效使用和优化Java集合。
59 4
|
2月前
|
开发框架 Java 关系型数据库
Java哪个框架适合开发API接口?
在快速发展的软件开发领域,API接口连接了不同的系统和服务。Java作为成熟的编程语言,其生态系统中出现了许多API开发框架。Magic-API因其独特优势和强大功能,成为Java开发者优选的API开发框架。本文将从核心优势、实际应用价值及未来展望等方面,深入探讨Magic-API为何值得选择。
96 2
|
2月前
|
Java 数据库连接 API
Spring 框架的介绍(Java EE 学习笔记02)
Spring是一个由Rod Johnson开发的轻量级Java SE/EE一站式开源框架,旨在解决Java EE应用中的多种问题。它采用非侵入式设计,通过IoC和AOP技术简化了Java应用的开发流程,降低了组件间的耦合度,支持事务管理和多种框架的无缝集成,极大提升了开发效率和代码质量。Spring 5引入了响应式编程等新特性,进一步增强了框架的功能性和灵活性。
67 0
|
5月前
|
XML Java 测试技术
Spring5入门到实战------17、Spring5新功能 --Nullable注解和函数式注册对象。整合JUnit5单元测试框架
这篇文章介绍了Spring5框架的三个新特性:支持@Nullable注解以明确方法返回、参数和属性值可以为空;引入函数式风格的GenericApplicationContext进行对象注册和管理;以及如何整合JUnit5进行单元测试,同时讨论了JUnit4与JUnit5的整合方法,并提出了关于配置文件加载的疑问。
Spring5入门到实战------17、Spring5新功能 --Nullable注解和函数式注册对象。整合JUnit5单元测试框架
|
3月前
|
Java 程序员 测试技术
Java|让 JUnit4 测试类自动注入 logger 和被测 Service
本文介绍如何通过自定义 IDEA 的 JUnit4 Test Class 模板,实现生成测试类时自动注入 logger 和被测 Service。
53 5
|
4月前
|
SQL JavaScript 前端开发
基于Java访问Hive的JUnit5测试代码实现
根据《用Java、Python来开发Hive应用》一文,建立了使用Java、来开发Hive应用的方法,产生的代码如下
87 6