鉴源论坛 · 观模丨基于软件性质的自动化测试技术

2023-10-09 17:28

本文主要是介绍鉴源论坛 · 观模丨基于软件性质的自动化测试技术,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者 | 熊一衡 华东师范大学软件工程学院博士

         苏亭 华东师范大学软件工程学院教授

版块 | 鉴源论坛 · 观模

社群 | 添加微信号“TICPShanghai”加入“上海控安51fusa安全社区”

在软件开发的生命周期中,测试是至关重要的一环。为了确保软件产品的质量,开发团队需要进行全面的测试,以发现和修复软件中潜在的缺陷和问题。传统的人工测试虽然有效,但却耗时耗力,且成本较高。为了提高测试效率和准确性,自动化测试已经成为一个重要的研究领域。

图片

图1 自动化测试技术

图1介绍了现有的几种自动化测试方法 [1]。X轴表示Feature compliance,即测试是否覆盖测试人员想要测试的功能,而Y轴表示 Input scope covered, 表示测试输入的覆盖程度。可以看出,在图的右上角缺了一块,即同时满足high feature compliance和full input scope covered 的测试技术。这个技术就是接下来要介绍的基于性质的测试技术(property-based testing)。

01

什么是基于软件性质的自动化测试技术

基于软件性质的测试(property-based testing)是一种很受欢迎的自动化测试技术,其原理是测试人员编写适用于待测软件的真实逻辑语句(即性质),然后使用自动化测试工具生成大量的测试输入,以充分测试待测软件,并验证测试人员编写的性质是否得以满足 [2]。如果性质被违反,则表明软件可能存在错误(bug)。例如,下图是一个待测程序`my_sort()`,其功能是对输入的序列进行排序,并返回排序后的序列。

图片

图2 待测程序

为了测试`my_sort()`, 通常测试人员会编写单元测试用例。编写传统的单元测试需要人工指定测试输入和预期输出。如下图所示,有6个测试用例来测试待测程序。然而,这种方法的缺点在于它非常耗人力,因为对于每一个测试输入,我们都需要手动去指定相应的测试输出。此外,测试的输入有限,依赖于测试人员的知识,因此难以充分测试待测程序。

图片

图3 单元测试用例

然而,如果使用property-based testing,我们仅仅编写一个测试方法就可以覆盖所有的测试输入。一开始,我们根据待测程序的理解,给出待测程序应该有的性质(property)。比如,my_sort()应该满足的一个性质为:返回list中的每一个元素都不应该大于它们之后的一个元素。根据这个性质,我们就可以编写出一个测试用例。注:我们以面向python语言的property-based testing 框架hypothesis为例来编写。

图片

图4 Property-based testing测试用例

如上图所示,代码的第一行 `@given(st.lists(st.integers())` 是一个装饰器,表示一旦测试开始,Hypothesis 将生成大量随机的list作为`test_prop_ordered()`函数的输入。每一个生成的list都将作为参数xs传递给`test_prop_ordered()`函数,并执行函数体,然后验证assert 语句是否为真。这样,我们就可以自动化生成足够多的list来验证待测程序是否满足我们设定的性质,而不用人为地去指定具体的测试输入和输出数据,大大提高了测试效率。

02

如何进行基于软件性质的自动化测试

上节介绍了Property-based testing的概念,这节介绍如何进行基于软件性质的自动化测试。我们用一个通用的模板来解释如何进行property-based testing:

图片

图5 property-based testing模板 

第一步:确定你想要测试的程序性质。如图5中第三行所示,测试人员通过对待测程序的理解来确定想要测试的程序性质。例如,在图4中,该测试用例旨在验证以下程序性质:排好序的list中每一个元素都不应该大于其后的元素。如果在测试过程中违反了这个性质,那么表明待测程序可能出现了一个Bug。

第二步:确定测试输入类型及范围。在完成第一步后,测试人员应该确定将要传递给待测程序的测试输入的类型和范围,如图5中第一,二行所示。例如,在图4中,由于待测程序的功能是对list中的元素的大小进行排序,那么测试输入应该是list。同时,由于排序涉及到元素的大小比较,因此列表中的元素应该是数字。在这里,我们选择了整数(integer)作为元素类型。

第三步:编写并运行测试用例。目前,针对不同的软件或者程序语言,开发人员已经开发出了多种基于性质的测试框架(Java: QuickTheories, Python: Hypothesis, C++: RapidCheck, Scala: ScalaCheck, JavaScipt: fast-check, Ruby: Rantly, Swift: Swiftcheck等等)[3-9]。一旦选择了适合的测试框架,我们就可以利用测试框架编写出相应的测试用例并且运行它们。

03

何选择合适的软件性质

前两节介绍了property-based testing的概念以及如何进行property-based testing,我们可以看出property-based testing是一个非常高效的测试技术。然而,当测试人员真正开始编写测试用例的时候,他们经常会碰见一个问题:应该选择什么样的性质来进行测试?因此,在本节中,我们将介绍一下比较通用的性质 [10],希望可以启发到测试人员如何选择合适的软件性质。

性质1:对称性(Symmetry。如下图所示。如果能够将某些值转换成其他值,然后再转换回来,那么它应该和原值保持一致。例如,序列化(Serialization)就是一个典型的例子。将文本转化成一个对象,然后将该对象转换回来,则文本应该保持不变。

图片

图 6 对称性

性质2:交换性(Commutativity。该性质指的是改变执行操作的顺序,但是最终结果不会变化。例如,如下图所示,将一个list头部加入一个元素,再将其尾部加入一个元素,如果将这两个操作的顺序交换,最终得到的list应该是相同的。

图片

图 7 交换性 

性质3:不变性(Invariants。该性质指的是执行某些操作后,并不会改变测试对象的某些性质。例如,如下图所示,将一个数组排序后,该数组的长度应该保持不变。

图片

图 8 不变性 

性质4:幂等性(Idempotence。该性质一般指多次执行某种操作和执行一次某种操作带来的效果应该是一样的。例如,如下图所示,对于一个列表,对其进行一次排序和多次排序,最终结果应该是相同的。

图片

图 9 幂等性

性质5:推导性(induction。该性质通常指的是,如果一个大的对象可以分成更小的对象,并且对于某些性质来说在这些小的对象上成立,那么可以证明这些性质在大的对象上也成立。例如,如下图所示。如果黑色集合中含有某个元素,那么红色、蓝色、绿色、黑色的大集合中也应该有某个元素。

图片

图 10 推导性

04

总结

基于性质的测试在近些年已经成为了一个非常受欢迎的测试技术,并且开发者们已经开发出了多种基于性质的测试框架。这种技术有非常多的优点,例如,理论上它可以覆盖所有的可能的测试输入,更充分地测试用户关心的功能,以及降低测试成本。然而,由于其特性,也存在一些挑战。例如,由于其只关心想要测试的性质,那么就导致对于某个性质测试得很充分,对于其他性质就根本没有测试到。此外,测试人员需要足够了解待测软件,以抽象出应该保持的性质,这对测试人员的要求比较高。另外,开发一个高效的基于性质的测试框架对于开发人员来说也是一个大的挑战。开发人员需要思考如何使测试人员更轻松地编写性质,以及如何才能开发出更好的数据生成器等。最重要的是,基于性质的自动化测试技术并不意味着取代其他测试技术(例如,单元测试),而是可以与其他测试技术共存。测试人员应该根据测试的需求,选择合适的测试技术,使其更好地服务于软件测试。

参考文献:

[1]https://medium.com/criteo-engineering/introduction-to-property-based-testing-f5236229d237

[2] Claessen, K., Hughes, J.: QuickCheck: a lightweight tool for random testing of Haskell programs. In: Proceedings of the Fifth ACM SIGPLAN International Conference on Functional Programming (ICFP’00), ACM, pp. 268–279 (2000). https://doi.org/10.1145/ 351240.351266

[3] QuickTheories. https://github.com/quicktheories/QuickTheories

[4] Hypothesis. https://hypothesis.works/

[5] RapidCheck. https://github.com/emil-e/rapidcheck

[6] ScalaCheck. https://github.com/typelevel/scalacheck

[7] fast-check. https://github.com/dubzzz/fast-check

[8] Rantly. https://github.com/rantly-rb/rantly

[9] SwiftCheck. https://github.com/typelift/SwiftCheck

[10] https://fsharpforfunandprofit.com/posts/property-based-testing-2/

这篇关于鉴源论坛 · 观模丨基于软件性质的自动化测试技术的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Jenkins中自动化部署Spring Boot项目的全过程

《Jenkins中自动化部署SpringBoot项目的全过程》:本文主要介绍如何使用Jenkins从Git仓库拉取SpringBoot项目并进行自动化部署,通过配置Jenkins任务,实现项目的... 目录准备工作启动 Jenkins配置 Jenkins创建及配置任务源码管理构建触发器构建构建后操作构建任务

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

Ubuntu 怎么启用 Universe 和 Multiverse 软件源?

《Ubuntu怎么启用Universe和Multiverse软件源?》在Ubuntu中,软件源是用于获取和安装软件的服务器,通过设置和管理软件源,您可以确保系统能够从可靠的来源获取最新的软件... Ubuntu 是一款广受认可且声誉良好的开源操作系统,允许用户通过其庞大的软件包来定制和增强计算体验。这些软件

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

金融业开源技术 术语

金融业开源技术  术语 1  范围 本文件界定了金融业开源技术的常用术语。 本文件适用于金融业中涉及开源技术的相关标准及规范性文件制定和信息沟通等活动。

软件设计师备考——计算机系统

学习内容源自「软件设计师」 上午题 #1 计算机系统_哔哩哔哩_bilibili 目录 1.1.1 计算机系统硬件基本组成 1.1.2 中央处理单元 1.CPU 的功能 1)运算器 2)控制器 RISC && CISC 流水线控制 存储器  Cache 中断 输入输出IO控制方式 程序查询方式 中断驱动方式 直接存储器方式(DMA)  ​编辑 总线 ​编辑