专栏首页mySoulJava 之单元测试
原创

Java 之单元测试

单元测试编写

Junit 单元测试框架

对于Java语言而言,其单元测试框架,有Junit和TestNG这两种,

下面是一个典型的JUnit测试类的结构

package com.example.demo;

import org.junit.jupiter.api.*;

import static org.junit.jupiter.api.Assertions.*;

@DisplayName("售票器类型测试")
class DemoTest {
    // 定义测试的实例
    private Demo demo;

    // 定义前缀 整个测试类开始执行的地方
    @BeforeAll
    public static void init(){

    }

    // 定义后缀,整个测试类完成后执行的操作
    @AfterAll
    public static void cleanup(){

    }


    // 定义每个测试用例开始执行前的操作
    @BeforeEach
    public void create(){
        this.demo = new Demo();
    }


    // 定义在每个测试用例完成后执行的操作
    @AfterEach
    public void destory(){

    }

    // 执行测试用例
    @Test
    @DisplayName("售票后的余额减少")
    public void shouldReduceInventoryWhenticketSoldOut(){

    }

    

    @Test
    public void ming(){

    }
}

测试结果如图所示

层次性表达测试用例

测试用例较多的情况下,为了层次性表达测试用例,使用Junit的Nested注解有层次的表达测试用例

package com.example.demo;

import org.junit.jupiter.api.*;

@DisplayName("交易服务测试")
class DemoTest {
    @Nested
    @DisplayName("用户交易测试")
    class Test02{

        @Test
        @DisplayName("交易检查测试")
        public void test01(){

        }

    }
}

使用Tag标签区分测试用例

在执行Maven打包的时候,使用tage注解,可以有选择的执行一些测试命令

package com.example.demo;

import org.junit.jupiter.api.*;

@DisplayName("交易服务测试")
class DemoTest {
    
    @Test
    @DisplayName("售票后额度减少")
    @Tag("fast")
    public void test01(){
        
    }
    
    @Test
    @DisplayName("一次性减少车票")
    @Tag("slow")
    public void test02(){
        
    }
}

添加相关的插件

<plugin>
                <artifactId>maven-surefire-plugin</artifactId>
                <version>2.22.0</version>
                <configuration>
                    <properties>
                        <includeTags>fast</includeTags>
                        <excludeTags>slow</excludeTags>
                    </properties>
                </configuration>
            </plugin>

断言

使用Junit命令进行断言处理

    @Test
    @DisplayName("售票后额度减少")
    @Tag("fast")
    public void test01(){
        String s = "ming";
        Assertions.assertTrue(s.startsWith("ming"));
        Assertions.assertTrue(s.endsWith("g"));
        Assertions.assertEquals(5, s.length());
    }

此时断言错误。

单元测试的目的

提升软件质量

优质的单元测试可以保障,开发质量和程序的健壮性,在大多数互联网企业中,开发工程师,都会频繁的执行测试用例。

促进代码的优化

单元测试是由开发工程师编写和维护的,这会促进开发工程师不断的重新审视自己的代码质量。

提高研发效率

单元测试,虽然占用的大量的时间,但是对后续的联调,集成等,都可以进一步的提高研发的效率。

增加重构的自信

代码重构往往是牵一发而动全身的,当修改底层代码的时候,通过不断的单元测试,可以增加重构的软件的自信。

单元测试的基本原则

单元测试要符合AIR原则。单元测试,符合以下三个原则

  1. 自动化
  2. 独立性
  3. 可重复

单元测试覆盖率

语句覆盖

又称行覆盖(LineCoverage),段覆盖(SegmentCoverage),基本块覆盖(BasicBlockCoverage),这是最常用也是最常见的一种覆盖方式,就是度量被测代码中每个可执行语句是否被执行到了。

判定覆盖

又称分支覆盖(BranchCoverage),所有边界覆盖(All-EdgesCoverage),基本路径覆盖(BasicPathCoverage),判定路径覆盖(Decision-Decision-Path)。它度量程序中每一个判定的分支是否都被测试到了。

条件覆盖

它度量判定中的每个子表达式结果true和false是否被测试到了

路径覆盖

又称断言覆盖(PredicateCoverage)。它度量了是否函数的每一个分支都被执行了

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 设计模式-行为型模式-命令模式

    客户每次都要单独找一个,非常复杂,设置一个负责人,负责和客户和需求,美工之间的连接。

    mySoul
  • 设计模式 里氏替换原则

    在场景中,三毛需要什么枪支,就直接new 出一个枪支即可,然后其内通过抽象类获取到对象,然后对齐进行修饰

    mySoul
  • 设计模式 接口隔离原则

    接着,要进行更改了。对好看的定义,发生了改变,那么就应该改变PettyGirl中的内容,但是已经在接口中定义了。那么就有问题了。即,接口承担的内容过多导致

    mySoul
  • 【已解决】Xcode代码提示变量为Error Type

    我之前使用Masonry布局时候经常需要设置偏移量,但是呢在设置布局哪里设置死数据不方便进行调试更换就想用一个变量。

    君赏
  • (保存)C#基础概念二十五问

    注:本文部份资料来自网络,如有侵权,请与我联系,我会在第一时间声明引用或将其删除!     当初学 C# 时是找个人大概问了一下数据类型和分支语句就开始做项目了...

    用户1172164
  • 状态模式

    状态模式允许在内部状态时改变它的行为,在外部看起来好像修改了类。状态模式可以延伸出状态机的概念,状态机据我自己所知在电商系统中用来控制订单状态的流转。关于状态机...

    shysh95
  • BeanWrapper解析

    爱撒谎的男孩
  • 用最低的成本,提高你的代码稳壮性。

    肥朝小声逼逼:提高代码稳壮性,肥朝认为最好的办法就是提前预防。实际项目中,我们在配置文件配置了各种参数。但是大家也知道,不同环境的配置参数,是会不一样的,难免会...

    黄泽杰
  • SpringBoot 配置文件编写及使用方式 (拒绝硬编码)

    我们经常在项目开放中需要进行很多配置, 那么这些配置基本上都是动态的, 如果我直接写在代码中, 修改起来很麻烦, 如果该配置在多处进行引用啦, 你估计会杀了写代...

    憧憬博客
  • 简单易学的机器学习算法——谱聚类(Spectal Clustering)

        网络簇结构(network cluster structure)也称为网络社团结构(network community structure),是复杂网...

    zhaozhiyong

扫码关注云+社区

领取腾讯云代金券