建立高效质量评估模型与测试覆盖度全解析

前言

笔者所在的公司是一家创业型公司,项目发布标准基本是项目时间时间到了+缺陷修复率达到某个值+case执行完成就准备发布了,每次发布线上都是提心吊胆,总当心哪里没有测到,哪种场景没有想到,心里没底,为啥会有这种当心呢?究其原因就是指标过于单一、缺少分析。那该如何改善这种情况呢?我们一起往下看。

质量评估模型

优秀的产品质量评估模型特质

在笔者读过的测试书籍中是这样写的:

1、多维度:能覆盖质量评估的各个维度,能帮助评估者全面分析和考虑

2、定量+定性:指标和分析相结合,能够有效避免在只有指标的情况下,被"绕"过去,变得形同虚设(为了绩效)。

3、过程+结果:不仅评估测试的结果,还的对过程进行分析和评估

如何建立产品质量评估模型

可以从三个方面来建立:

1、测试覆盖度评估:对测试范围及测试的深度与广度进行分析和评估。可以从需求覆盖度评估路径覆盖两个纬度进行分析和评估,这就是定量指标

2、测试过程评估:对测试过程和测试投入进行分析和评估。可以从测试用例分析测试方法分析 以及测试投入分析三个纬度进行分析评估,既包含了定量指标,又包含了定性分析

3、缺陷分析:对测试结果进行分析与评估。可以从缺陷密度分析缺陷修复情况分析缺陷趋势分析缺陷年龄分析 以及缺陷出发因素分析5个纬度对测试结果进行分析评估,既包含了定量指标,又包含了定性分析

测试覆盖度评估

上面提到,我们可以从需求覆盖度评估路径覆盖两个纬度来分析,那怎么理解这两个纬度呢?

需求覆盖度

需求覆盖度是"已经测试验证的产品需求数"和"产品需求规格总数"的比值。

需求覆盖度当然 得达到100%,保证没有漏测需求,如果未达到100%,就需要分析出现了什么问题。那如何来统计需求覆盖度呢?常见的两种方式:Excel手动统计和借助三方工具自动统计。

Excel手动统计:

将待测需求点整理到Excel表格中,测试过程中边测试边记录需求点验证情况。看demo:

需求编号 需求点 是否验证 测试结果 测试人
001 验证码登录 是/否 通过/失败/阻塞 QA

自动统计

使用第三方工具,比如TAPD、云效等,将需求点拆分写在这些工具中,编写case时将case与需求点进行关联,这样需求对应的case执行通过,就可以代表这个需求被验证通过了。

路径覆盖度

路径覆盖度是"已经测试到的语句的数量"和"程序中可执行语句的总数量"的比值。

如何进行路径覆盖度统计呢?这里就需要用到路径分析法。路径分析法有以下几种方法:

1、语句覆盖:覆盖系统中所有判定和过程的最小路径集合

2、分支覆盖:覆盖系统中每个判定的所有分支所需的最小路径数

3、全覆盖:100%的覆盖系统所有可能的路径的集合

4、最小线性无关覆盖:保证流程图中每个路径片段能够被至少执行一次的最少路径组合

从定义上可以看出,使用不同的方法得到结果是不同的。

首先,确定路径覆盖策略。不同的功能点使用的路径分析法也会有所不同。可以将最小线性无关覆盖作为基本的路径覆盖方式,然后根据需求点的优先级、重要程度,在此基础上增加或减少一些路径。我们可以做个表格记录,像这样

功能 路径覆盖策略
需求点1 最小线性无关覆盖

然后,使用路径分析法设计测试用例

最后,跟踪测试用例执行情况。

最后

本片内容主要阐述了质量评估模型如何建立,以及测试覆盖度的评估如何进行,我觉得需求覆盖度还是比较容易统计的,唯一的难点可能是需求文档更新不及时,需求变更比较频繁,路径覆盖度的话可能比较难一些,需要能看懂代码才能更全面的涉及路径相关用例。测试过程评估和缺陷分析我们放到之后的文章。

相关推荐
帅得不敢出门3 天前
安卓使用memtester进行内存压力测试
android·压力测试·测试·硬件测试
每周都想吃火锅8 天前
如何在postman中传入文件参数
postman·测试
HinsCoder10 天前
【测试】——Selenium API (万字详解)
自动化测试·笔记·学习·selenium·测试工具·web·测试
大柏怎么被偷了12 天前
【测试】什么是需求?
测试
郝同学的测开笔记13 天前
PyQt6 中的布局管理
后端·python·测试
南风与鱼14 天前
软件测试 BUG 篇
bug·测试
四格14 天前
如何使用 Bittly 进行基于串口的自动化测试
嵌入式·测试
Lossya16 天前
【自动化测试】常见的自动化遍历工具以及如何选择合适的自动化遍历工具
自动化测试·功能测试·测试工具·自动化·测试
HinsCoder16 天前
【渗透测试】——Upload靶场实战(1-5关)
笔记·学习·安全·web安全·渗透测试·测试·upload靶场
大柏怎么被偷了17 天前
【软件测试】测试的岗位有哪些?
软件测试·测试