首页 > 其他分享 >测试驱动技术(TDD)系列之1:一文带你上手测试数据驱动

测试驱动技术(TDD)系列之1:一文带你上手测试数据驱动

时间:2023-09-27 11:07:46浏览次数:32  
标签:int org 测试数据 TDD SUBSTRACT import 驱动 Type public


数据驱动的意义

数据驱动,指在自动化测试中处理测试数据的方式。通常测试数据与功能函数分离,存储在功能函数的外部位置。在自动化测试运行时,数据驱动框架会读取数据源中的数据,把数据作为参数传递到功能函数中,并会根据数据的条数多次运行同一个功能函数。数据驱动的数据源可以是函数外的数据集合、CSV 文件、Excel 表格、TXT 文件,以及数据库等。如果没有数据驱动我们想对一个方法Add(),进行三组数据的测试{1,2 },{0,2},{0,3},那么我们需要写三个测试方法;而通过数据驱动只需要写一个测试方法,然后通过循环读取测试数据的方式就能完成对三组数据的测试。数据驱动在测试框架中都是通过对测试数据的参数化来实现,本文会详细讲解测试驱动在junit4测试框架中的应用。

测试驱动技术(TDD)系列之1:一文带你上手测试数据驱动_数据

Junit4中数据驱动基础实现

代码如下:

import java.util.Arrays;

import java.util.Collection;

import org.junit.Assert;

import org.junit.Test;

import org.junit.runner.RunWith;

import org.junit.runners.Parameterized;

import org.junit.runners.Parameterized.Parameters;

//@RunWith表示测试用例将会以参数化的形式执行

@RunWith(Parameterized.class)

public class ParaDemo {

private int input1;

private int input2;

private int expected;

@Parameters

//方法prepareData()中包括需要参数化的数据,示例中有三组数据,每组数据有三个值

public static Collection prepareData(){

Object [][]object= {{1,2,3},{0,2,2},{0,3,3}};

return Arrays.asList(object);

}

//构造方法中的参数与prepareData()中的数据是一一对应的,以第一组数据{1,2,3}为例:

1对应input1,2对应input2,3对应expected

public ParaDemo(int input1,int input2,int expected){

this.input1 =input1;

this.input2 =input2;

this.expected =expected;

}

@Test

//测试用例中把测试数据进行了参数化

public void testAdd(){

int result=this.input1+this.input2;

Assert.assertEquals(this.expected,result);

}

}

 

运行测试用例,可以看到同一个测试用例被prepareData()中赋值的三组测试数据执行,如下图所示:

测试驱动技术(TDD)系列之1:一文带你上手测试数据驱动_tdd_02

 

测试数据与不同测试用例关联

假设想增加一个testSubstract()测试方法,然后使得testAdd()和testSubstract()分别用各自的参数化测试数据该如何实现呢?思路如下:

1.两个方法设计到不同的测试类中。(这里不做讨论)

2.增加标签对用例数据进行标识。使用枚举类实现enum Type {SUBSTRACT, ADD};执行用例时,根据标签判定用例是否需要执行。通过org.jnit.Assume.assumeTrue来进行判定

具体代码实现如下:

import static org.junit.Assert.assertEquals;

import java.util.Arrays;

import java.util.Collection;

import org.junit.Assume;

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 ParaJunit4Demo {

enum Type {SUBSTRACT,ADD};

@Parameters

public static Collection data(){

return Arrays.asList(newObject[][] {

{Type.SUBSTRACT, 3, 2, 1},

{Type.SUBSTRACT, 4, 2, 2},

{Type.SUBSTRACT, 4, 2, 2},

{Type.ADD, 3, 2, 5},

{Type.ADD, 3, 2, 5},

});

}

private Type type;

private int a, b, expected;

public ParaJunit4Demo(Typetype,int a,int b,int expected){

this.type =type;

this.a=a;this.b=b;this.expected=expected;

}

@Test

public void testAdd(){

Assume.assumeTrue(type == Type.ADD);

assertEquals(this.expected,this.a+this.b);

}

@Test

public void testSubstract(){

Assume.assumeTrue(type == Type.SUBSTRACT);

assertEquals(this.expected,this.a-this.b);

}

}

 

上面的例子是testAdd()和testSubstract()拥有相同的测试参数个数(都是3个),如果在增加一个测试用例testOthers(),而它只需要两个测试参数,又该如何实现呢?

尝试方法一:直接设置参数数据为{Type.OTHERS, 3,3},代码如下:

public static Collection data(){

return Arrays.asList(newObject[][] {

{Type.SUBSTRACT, 3, 2, 1},

{Type.SUBSTRACT, 4, 2, 2},

{Type.SUBSTRACT, 4, 2, 2},

{Type.ADD, 3, 2, 5},

{Type.ADD, 3, 2, 5},

{Type.OTHERS, 3,3}

});

}

//用例设置如下:

@Test

public voidtestOthers(){

Assume.assumeTrue(type == Type.OTHERS);

assertEquals(this.a,this.b);

}

 

运行代码,提示参数个数错误

测试驱动技术(TDD)系列之1:一文带你上手测试数据驱动_数据_03

 

尝试方法二:尝试添加一个构造方法,代码如下:

public ParaJunit4Demo(Typetype,int a,int b){

this.type =type;

this.a=a;

this.b=b;

}

运行代码,提示只能有一个构造方法的错误

测试驱动技术(TDD)系列之1:一文带你上手测试数据驱动_tdd_04

 

尝试方法三:添加一组数据,将最后一个数据设置为3,3,0

public static Collection<Object[]>data(){

return Arrays.asList(new Object[][] {

{Type.SUBSTRACT, 3, 2, 1},

{Type.SUBSTRACT, 4, 2, 2},

{Type.SUBSTRACT, 4, 2, 2},

{Type.ADD, 3, 2, 5},

{Type.ADD, 3, 2, 5},

{Type.OTHERS, 3,3,0}

});

}

 

运行测试,测试通过。

由此可见,想要实现拥有不同测试参数个数的测试用例的参数化,需要使参数个数统一,参数少的用例,需要添加参数进行占位(是否被使用无所谓),实例中,通过添加0来实现参数个数统一,{Type.OTHERS, 3,3,0}

总结

有人会说在junit5或者TestNG中都可以很方便地实现该功能(后面会接受TestNG参数化技术),有必要搞得这么麻烦吗?大家说得没错,在这里我只是给大家展示一个解决问题的思路而已,好多测试同学不知道通过代码怎样解决问题!其实最简单有效的就是完善目前架构中的功能,遇到问题不要置之不理,觉得架构不提供,我们就没有必要再继续深入了,我们应该好好想一想通过编码能否解决问题,多动手多思考,慢慢的编码能力就会提升了!

标签:int,org,测试数据,TDD,SUBSTRACT,import,驱动,Type,public
From: https://blog.51cto.com/liwen629/7621626

相关文章

  • 极光笔记 | 聊一聊推送系统中事件驱动架构的应用
    微服务间通信方式主要有2种:RPC和消息传递。通常来说在请求/响应的场景下使用RPC更加合适,具体实现通常是RESTAPI或者基于长链接的协议(例如gRPC/Thrift/ZeroICE等)。两个服务有比较强的依赖关系,调用者依赖被调用者的处理结果,调用者处理该请求被堵塞以等待响应结果,同时还要进行负载......
  • AP2400 DC-DC降压恒流驱动器 汽车摩托LED大灯电源驱动 全亮半亮瀑闪三功能循环
    产品特点宽输入电压范围:5V~100V可设定电流范围:10mA~6000mA固定工作频率:150KHZ内置抖频电路,降低对其他设备的EMI干扰平均电流模式采样,恒流精度更高0-100%占空比控制,无电流节点跳变输出短路保护过温保护三功能模式:全亮/半亮/爆闪/三功能循环SOP8封装   产品描述AP24......
  • 实时数据驱动:可视化大屏的交互革命
    在当今数字化时代,数据和信息是企业成功的关键。可视化大屏已经成为各个行业中数据呈现和决策支持的重要工具。然而,随着技术的发展,用户对于数据可视化的期望也在不断演变。仅仅呈现数据已经不再足够,用户希望能够更深入地与数据互动,以获得更多洞察力。本文将深入探讨可视化大屏的交......
  • PSAM嵌入式驱动——概念
    0.前序刚好最近忙了几项目的部分驱动都与PSAM相关,且不同项目硬件设计原因,涉及软件纯模拟PSAM驱动和硬件USART支持ISO7816的硬件PSAM驱动,顺便边做边总结,纯个人理解,方便交流,其中许多内容也是从别人摘录而来便于理解。1.背景PSAM卡是一种安全模块,用于验证用户卡的合法性,同时保护终......
  • PSAM嵌入式驱动——原理
    前言本部分内容是前一篇《PSAM嵌入式驱动——概念》的后续篇,本节主要是PSAM做驱动开发要了解的一些基本原理,在此一一阐述,部分内容也是借鉴前辈基础上,加上实践中整理及理解,与项目实际密切相关。一、PSAM基本交易过程 一般含PSAM的交易终端交互过程如上图,对于嵌入式驱动而言,前......
  • VMware ESXi 8.0U2 macOS Unlocker & OEM BIOS 集成网卡驱动和 NVMe 驱动 (集成驱动版
    VMwareESXi8.0U2macOSUnlocker&OEMBIOS集成网卡驱动和NVMe驱动(集成驱动版)发布ESXi8.0U2集成驱动版,在个人电脑上运行企业级工作负载请访问原文链接:https://sysin.org/blog/vmware-esxi-8-u2-sysin/,查看最新版。原创作品,转载请保留出处。作者主页:sysin.org发布......
  • Ubuntu安装CUDA Driver(显卡驱动)
    方法如链接https://blog.csdn.net/qq_34972053/article/details/126707938——————————————————————————————显卡,显卡驱动,nvcc,cudadriver,cudatoolkit,cudnn到底是什么?https://www.cnblogs.com/marsggbo/p/11838823.html—————————......
  • 芯片驱动选择
    看src/soc/common/cm.c->soc_dev_info这个全局变量,这个才是最准确最标准的,其结构体定义如下:/*informationaboutadevicetype*/typedefstructsoc_cm_device_info_s{uint16dev_id; /*ChipIDasfoundintable*/uint8rev_id;......
  • linux 驱动向应用程序发射信号
    系统支持信号在linux终端输入kill-l可以查看系统所支持的信号,可以看出,每个信号的名字都是以SIG开头:root@zhengyang:/work/sambashare/linux-5.2.8#kill-l1)SIGHUP2)SIGINT3)SIGQUIT4)SIGILL5)SIGTRAP6)SIGABRT7)SIGBUS8......
  • I2c_Adapter驱动框架讲解与编写-11
    参考资料:Linux内核文档:Linux-4.9.88\Documentation\devicetree\bindings\i2c\i2c-gpio.txtLinux-5.4\Documentation\devicetree\bindings\i2c\i2c-gpio.yamlLinux内核驱动程序:使用GPIO模拟I2CLinux-4.9.88\drivers\i2c\busses\i2c-gpio.cLinux-5.4\driver......