首页 > 其他分享 >测试基础

测试基础

时间:2022-10-08 09:35:18浏览次数:82  
标签:边界值 基础 等价 灰度 测试 条件 输入

各测试分类详解

 

  1. 各测试分类详解

    单元测试(UT,unit testing),是指对软件中的最小可测试单元进行检查和验证。对于单元测试中单元的含义,一般来说,要根据实际情况去判定其具体含义。并且单元测试,粒度最小,一般由开发小组采用白盒方式来测试,主要测试单元是否符合设计。一般的,在django中,最小的单元是函数。

    白盒测试主要应用在单元测试阶段,主要是对代码级的测试,针对程序内部逻辑构,测试手段有:

    • 语句覆盖

    • 判定覆盖

    • 条件覆盖

    • 路径覆盖

    • 条件组合覆盖

    白盒测试也称结构测试或逻辑驱动测试,它是按照程序内部的结构测试程序,通过测试来检测产品内部动作是否按照设计规格说明书的规定正常进行,检验程序中的每条通路是否都能按预定要求正确工作。 这一方法是把测试对象看作一个打开的盒子,测试人员依据程序内部逻辑结构相关信息,设计或选择测试用例,对程序所有逻辑路径进行测试,通过在不同点检查程序的状态,确定实际的状态是否与预期的状态一致。

    对比黑盒测试,白盒测试更严谨,对软件的源码和架构进行测试,需要软件源代码,流程图等设计文档。​

    def foo(a, b):
        if a == 1 or b ==2:
            print('aaaa', a, b)
        else:
            print('bbbbbbbbbb', a, b)
    ​
    foo(a=1, b=3)
    foo(a=2, b=2)
    foo(a=2, b=3)
     

    集成测试(IT,system integration test),又称为组装测试,界于单元测试和系统测试之间,起到桥梁作用,一般由开发小组采用白盒加黑盒的方式来测试,既验证设计,又验证需求主要用来测试模块与模块之间的接口,同时还要测试一些主要业务功能。集成测试(也叫组装测试,联合测试)是单元测试的逻辑扩展。它最简单的形式是:把两个已经测试过的单元组合成一个组件,测试它们之间的接口。从这一层意义上讲,组件是指多个单元的集成聚合。在现实方案中,许多单元组合成组件,而这些组件又聚合为程序的更大部分。方法是测试片段的组合,并最终扩展成进程,将模块与其他组的模块一起测试。最后,将构成进程的所有模块一起测试。此外,如果程序由多个进程组成,应该成对测试它们,而不是同时测试所有集成测试进程。

    系统测试(ST,system test)粒度最大,一般由独立测试小组采用黑盒方式来测试,主要测试系统是否符合需求规格说明书。在经过以上各阶段测试确认之后,把系统完整地模拟客户环境来进行的测试。系统测试是将已经确认的软件、计算机硬件、外设、网络等其他元素结合在一起,进行信息系统的各种组装测试和确认测试,其目的是通过与系统的需求相比较,发现所开发的系统与用户需求不符或矛盾的地方,从而提出更加完善的方案。它的的任务是尽可能彻底地检查出程序中的错误,提高软件系统的可靠性,其目的是检验系统"做得怎样?"。这阶段又可分为三个步骤:

    • 模块测试,测试每个模块的程序是否有错误。

    • 组装测试,测试模块之间的接口是否正确。

    • 确认测试,测试整个软件系统是否满足用户功能和性能的要求。

    验收测试(AT,acceptance test)与系统测试相似,主要区别是测试人员不同,验收测试由用户执行。一般分为:

    • α测试(内测):Alpha测试模拟实际操作环境下验收测试,如删档内测试,软件只是初步完成的产品,bug可能较多,不会进行上线提供用户访问。

    • β测试(公测):Beta测试系统已经通过内部测试,大部分错误已经修复,即将正式发布,在多个真实环境下发布,如不删档公测。 对比α版本已经有了较大改进,但仍可能存在一些bug,需要大规模测试,例如DNF公司更新一个地图,提供公测免费下载,由专业游戏玩家进行游戏结果反馈,开发者再进行修复。

    • γ版本:Gamma版本,指的是软件版本正式发行的候选版本,与即将发布的正式版相差无几。Gamma版也可以称为RC(Release Candidate)版本。

    • UAT测试:UAT测试(user acceptance test),UAT(用户验收测试)阶段的测试就不是软件开发商自己的测试来做了,而是由客户根据自己的实际业务场景,(或派人员)来使用软件,对具体的功能进行测试。

     

    随机测试也称为探索测试。

    主要是对被测软件的一些重要功能进行复测,也包括测试那些当前测试用例没有覆盖到的部分。除此之外,对于软件的更新和新增功能进行重点测试,尤其是对一些特殊情况点、特殊的使用环境、并发性等进行测试,还包括以前测试中发现的重大bug进行再次测试。

    随机测试可以结合回归测试一起进行。

 

灰度发布(或称金丝雀发布,或称灰度测试),是指在黑与白之间能够平滑过渡的一种发布方式。在其上可以进行A/B testing,即让一部分用户继续用产品特性A,一部分用户开始用产品特性B,如果用户对B没有什么反对意见,那么逐步扩大范围,把所有用户都迁移到B上面来。

灰度发布是对某一产品的发布逐步扩大使用群体范围,也叫灰度放量。灰度发布可以保证整体系统的稳定,在初始灰度的时候就可以发现、调整问题,以保证其影响度。

灰度期:灰度发布开始到结束期间的这一段时间,称为灰度期。

灰度发布的意义

灰度发布能及早获得用户的意见反馈,完善产品功能,提升产品质量,让用户参与产品测试,加强与用户互动,降低产品升级所影响的用户范围。

灰度发布的步骤

  • 定义目标

  • 选定策略:包括用户规模、发布频率、功能覆盖度、回滚策略、运营策略、新旧系统部署策略等

  • 筛选用户:包括用户特征、用户数量、用户常用功能、用户范围等

  • 部署系统:部署新系统、部署用户行为分析系统(web analytics)、设定分流规则、运营数据分析、分流规则微调

  • 发布总结:用户行为分析报告、用户问卷调查、社会化媒体意见收集、形成产品功能改进列表

  • 产品完善

  • 新一轮灰度发布或完整发布

 

参考:https://www.cnblogs.com/Neeo/articles/11795967.html

 

 

测试方法

黑盒测试常用方法:

  • 等价类划分法

  • 场景法

  • 边界值

  • 因果图

  • 判定表

白盒测试,参考:https://www.cnblogs.com/Neeo/articles/11795996.html

  • 语句覆盖

  • 条件覆盖

  • 路径覆盖

 

程序插桩

简单来说,程序插桩就是我们在调试程序时,常常要在程序中插入一些打印语句(想想我们在程序中常用的print语句),其目的是希望在程序执行中打印出我们最为关心的信息,然后进一步通过这些信息了解程序执行过程中程序的一些动态特性。

从这一思想发展出程序插桩技术能够按照用户的要求,获取程序的各种信息,成为测试工作的有效测试手段。

 

我们一般从以下五个维度来区分:

  • 测试阶段不同:

    • 单元测试阶段主要利用白盒测试方法。

    • 集成测试阶段主要利用灰盒测试方法。

    • 系统测试阶段主要利用黑盒测试方法。

  • 测试依据,因为测试阶段的不同,采用的测试方法也不同,那它们的测试依据也不同:

    • 白盒测试主要依据详细测试说明书(LLD)。

    • 黑盒测试主要依据需求规格(设计)说明书(SRS)。

    • 灰盒测试主要依据概要规格(设计)说明书(HLD)。

  • 测试方法:

    • 白盒测试方法可以有静态和动态,控制流、信息流、数据流、各种覆盖率、插桩处理。

    • 黑盒测试方法有各种测试类型(功能型、负载、恢复性),以及应用等价类、边界值、流程图法、正交法等。

    • 灰盒测试这里即用白盒的,也用黑盒的。

  • 评估基准:

    • 白盒根据逻辑覆盖率来评估。

    • 黑盒主要看需求规格的覆盖率。

    • 灰盒主要看接口覆盖率。

  • 特点不一样:

    • 白盒测试,特点是及早的发现问题,定位问题也很快,缺点是对接口、对设计、程序之间的调用、用户感受也不是很好。

    • 黑盒解决问题的代价比较大,很大发现模块内部的问题。

等价类划分法

 

选取少数具有代表性的数据作为测试用例,这种测试用例我们称为等价类(类别)划分法

优点:

  • 将不能穷举的测试过程进行合理的分类,从而保证设计出来的测试用例具有完整性和代表性。

  • 在有限的测试资源的情况下,用少量有代表性的数据得到比较好的测试效果。

等价类划分分为(基本概念):

  • 有效等价类,指符合《需求规格说明书》,输入合理的数据集合。

  • 无效等价类,指不符合《需求规格说明书》,输入不合理的数据集合。

等价类思考步骤:

  • 首先确定有效等价类和无效等价类

  • 有效等价类就是一目了然的题目条件(比如在0~20之间测试),要考虑到两端的极值(边界值)和中间值。

  • 无效等价类先划分与条件相反的情况(比如不在0~20范围内),再去找特殊情况,如中英文,符号、空格、空等。

等价类划分发的测试思想

  • 穷举测试:把所有可能的数据全部测试一遍称为穷举测试,虽然穷举测试是最全面的测试,但是很明显不现实,因为测试效率太低了,数据量巨大,根本测不过来(思考前面计算器的例子)。但又因为没有做过穷举测试,所以会有遗漏缺陷的风险,如果时间允许,尽可能的做补充测试(觉得有风险有问题的做补充测试)。

  • 理想的测试思想,使用最少的测试数据,达到最好的测试质量,毕竟性价比还是要追求的嘛。

  • 而等价类划分法则是从大量的数据中,划分范围(或分类),每个范围内的数据测试效果是等价的,所以每个范围是一个等价类,然后从每个范围内挑选出具有代表性的数据,这些代表数据能反映这个范围内的测试结果。

  • 等价类划分法的基本思想是:

    • 有效等价类,对于程序来说,是有意义的,合理的输入数据集合,然后测试功能是否符合预期。

    • 无效等价类,对于程序来说,是无意义的,不合理的输入数据集,用来测试程序是否具有强大的异常处理能力,也就是测试程序的健壮性。

 

 

 

边界值

什么是边界值?

边界是指对于输入等价类和输出等价类而言,稍高于边界值和稍低于边界值的一些特定情况,边界值分析法常应用于黑盒测试中。边界值也可以称为极值。

根据以往的经验来看:大量的错误是发生在输入或者输出范围的边界上,而不是再输入范围的内部。所以,为了保证测试质量,我们需要重点关注测试边界。

 

确定边界值的一般思路

  • 确定边界情况,也就是确定输入或者输出等价类的边界

  • 选取正好等于、刚刚大于、刚刚小于边界值作为测试数据

边界值的方法思考:

  • 如果输入条件规定了范围,则应该取这个范围的边界值,比如1~100,边界值应该取0 1 100 101

  • 如果输入条件规定了输入值的个数。比如密码长度为8~24,边界值应该取7 8 9 23 24 25位字符来判断。

  • 边界值和等价类的区别,边界值分析不是从等价类中随便找一个作为代表,而是整个等价类的每个边界都要作为测试条件。

  • 边界值的思想是在结合实际环境,应该选出到边界和刚超过的值作为测试依据。边界值和等价类是相辅相成的,共同使测试用例更加完善。

常见的边界值:

  • 循环中的第1、2次和倒数第1、2次。

  • 数值元素的第一个和最后一个值。

  • 报表的第一行和最后一行。

  • 文本框接收字符个数,用户名长度啊,密码长度等。

 

 

 

因果图和判定表

无论是等价类还是边界值,都重点的考虑的是输入输出的情况。但很少考虑输入(多个输入)输出之间的组合和制约情况。

因果图(Cause-Effect Graph)法是一种利用图解法分析输入的各种组合情况,从而设计测试用例的方法,它适用于检查程序输入条件的各种组合情况。 因果图法的特点

  • 考虑输入条件的相互制约及组合关系

  • 考虑输出条件对输入条件的依赖关系

因果图法产生的背景

  • 等价类划分法和边界值分析方法都是着重的考虑输入条件,但是极少的考虑输入条件的各种组合、输入条件之间的相互制约关系,这样虽然各种输入条件可能出错的情况已经测试到了,但是多个输入条件组合起来可能出错的情况却很难发现。

  • 如果在测试的时候,必须考虑输入条件的组合情况,那么可能的组合情况将非常的多,导致测试任务繁重。因此,我们必须考虑一种适合于描述多种条件的组合,相应产生多个动作的形式来进行测试用例的设计,这就用到了因果图,也就是设计逻辑模型。

因果图的核心

  • 因果图法适用于输入条件较多的情况,测试所有输入条件的排列组合。因果图所谓的因就是输入,而果就是输出。

    • 因果图之,即输入条件。

    • 因果图之,即输出结果。

因果图法要注意考虑的要点

  • 所有输入/输出条件的相互制约关系及组合关系。

  • 输出结果对输入条件的依赖关系,也就是什么样的输入组合会产生怎样的输出结果,即因果关系

因果图只是一种辅助工具,我们通过因果图分析出一个表,这个表就是判定表,然后通过判定表编写测试用例。但是有的时候,画因果图非常麻烦,影响测试效率,所以,我们很多时候都是直接写判定表,进而编写测试用例。

判定表的组成

  • 条件桩:问题的所有条件,即所有的条件组合。

  • 动作桩:问题的所有输出,即所有的输出组合。

  • 条件项:针对条件桩的取值。

  • 动作项:条件项的各种取值情况下的输出结果。

判定表制作步骤

  • 列出所有的条件桩和动作桩。

  • 填入条件项与动作项,得到初始判定表。

  • 简化判定表(合并相似规则(相同动作))。

 

 

 

 

 

 

 

 

 

 

标签:边界值,基础,等价,灰度,测试,条件,输入
From: https://www.cnblogs.com/erhuoyuan/p/16767973.html

相关文章

  • java类与对象课后测试
    1.测试ClassAndObjectTest.javapublicclassClassAndObjectTest{publicstaticvoidmain(String[]args){//创建类的实例,定义一个对象变量引用......
  • 第二阶段:高级核心基础知识·第4章shell特性·2
    1.统计日志,日志内容39.96.187.239--[11/Nov/2019:10:08:01+0800]"GET/HTTP/1.1"3020"-""Zabbix"211.162.238.91--[11/Nov/2019:10:08:02+0800]"GET/api......
  • NIO基础-Netty系列-1
    概览NIO三大核心组件:1,Channel2,Buffer3,Selector先概述一下三者的概念和之间的关系,再逐个了解组件的API打个基础。对于IO通信,必然需要连接起来才能通信,Channel可以理解......
  • python写脚本测试执行为什么要写if __name__ == '__main__'
    我的博客在写python脚本的时候,例如,我写一个test1.pydeftest(n):print(n)if__name__=='__main__':n=1test(1)接下来打开cmd命令窗口,执行命令python......
  • 2.mysql基础
    说明:学习视频参考尚硅谷--康师傅第一章.数据库概述1.为什么使用数据库?why?     持久化(persistence):把数据保存到可掉电式存储设备中以供之后使用。大多数情......
  • 2022-2023 20221403《计算机基础与程序设计》第六周学习总结
    2022-202320221403《计算机基础与程序设计》第六周学习总结作业信息作业模板作业要求教材学习内容总结Polya如何解决问题理解问题设计方案执行方案回顾(分析......
  • sql server 锁(lock) 基础及应用(引文)
     sp_getAppLock 获取程序资源锁,简单的说就是调用此函数可以达到我们程序中.NET的lock锁的作用.作用域是当前数据库下四个参数:@resource(必填):资源名称,类型nvarchar(......
  • 基础06:聚合函数
    一、聚合函数介绍什么是聚合函数聚合函数作用于一组数据,并对一组数据返回一个值。聚合函数类型AVG();SUM();MAX();MIN();COUNT();1.1AVG和SUM函数可......
  • 基础05:单行函数
    一、函数的理解1.1什么是函数函数在计算机语言的使用中贯穿始终,函数的作用是什么呢?它可以把我们经常使用的代码封装起来,需要的时候直接调用即可。这样既提高了代码效......
  • 2022-2023-1学期 20221417魏正一 《计算机基础与程序设计》第6周学习总结
    第六周学习目标·Polya如何解决问题·简单类型与组合类型·复合数据结构·查找与排序算法·算法复杂度·递归·代码安全学习资源·教材·阅读「反作弊」:任何时......