软件测试词典

首页

A

验收测试 可访问性测试 主动测试 实际结果 临时测试 老化测试 敏捷测试 全对测试 Alpha 测试 API 测试 Arc 弧测试 异常测试 断言测试 审计测试 自动化软件测试

B

向后兼容性测试 基线工件 基础路径测试 基础测试集 调试 行为测试 基准测试 Beta 测试 大爆炸测试 二进制可移植性测试 黑盒测试 自下而上测试 边界测试 分支测试 广度测试 Bug测试 构建验证 业务流程 业务需求

C

能力成熟度模型 捕获/重放工具 因果图 代码覆盖率 代码冻结 代码检查 代码审查 代码演练 基于代码的测试 代码驱动测试 无代码测试 比较测试 兼容性测试 合规性测试 并发性测试 条件覆盖测试 配置测试 一致性测试 上下文驱动测试 控制流路径 转换测试 正确性 覆盖项目 循环复杂度

D

数据完整性测试 数据驱动测试 数据流测试 数据库测试 调试 决策覆盖测试 缺陷 缺陷记录和跟踪 缺陷生命周期 Delta 发布 依赖性测试 深度测试 破坏性测试 开发环境 文档测试 域测试 耐久性测试 动态测试

E

模拟器 端到端测试 耐久性测试 准入标准 等价分区测试 错误 错误猜测 错误植入 详尽测试 退出标准 预期结果 探索性测试

F

故障转移测试 失败 故障 故障注入测试 可行路径 功能测试 功能分解 功能要求 功能测试 模糊测试 前端测试

G

玻璃盒测试 全球化测试 Gorilla 测试 灰盒测试 GUI 测试

H

测试工具 启发式测试 混合集成测试

I

实施测试 增量测试 独立测试 不可行路径 检查 安装/卸载测试 集成测试 接口测试 国际化测试 系统间测试 互操作性测试 隔离测试 问题

K

关键字驱动测试 关键绩效指标 已知问题

L

LCSAJ 测试 负载生成器 负载测试 本地化测试 逻辑覆盖率测试 循环测试

M

可维护性 手动测试 大型机测试 基于模型的测试 修改条件测试 模块化驱动测试 猴子测试 突变测试

N

负面测试 非功能性测试 非破坏性测试

O

操作测试 正交阵列测试

P

配对测试 成对测试 并行测试 部分测试自动化 被动测试 路径测试 同行评审 渗透测试 性能测试 试点测试 可移植性测试 积极测试 后置条件 前提条件 预测结果 优先级 流程周期测试 渐进式测试 原型测试

Q

质量保证 质量控制 质量管理

R

随机测试 恢复测试 回归测试 候选版本 发布说明 可靠性测试 需求测试 基于需求的测试 需求可追溯性矩阵 结果 重新测试 Review 审查 风险测试 风险管理 根本原因

S

安全性测试 健全性测试 可扩展性测试 场景测试 时间表 Scrum 测试 脚本 安全测试 模拟 冒烟测试 浸泡测试 峰值测试 软件需求规范 稳定性测试 状态转换 静态测试 统计测试 存储测试 压力测试 结构测试 结构化演练 存根 符号执行 语法测试 系统集成测试 系统测试 被测系统

T

技术评审 测试方法 测试自动化 测试基础 测试平台 测试用例 测试用例设计技术 测试套件 测试完成标准 测试完成报告 测试完成矩阵 测试数据 测试数据管理 测试驱动开发 测试驱动程序 测试环境 测试执行 测试管理 测试成熟度模型 测试计划 测试步骤 测试策略 测试工具 线程测试 自上而下的集成测试 全面质量管理 可追溯性

U

单元测试 无法访问的代码 可用性测试 用例测试 用户验收测试 用户界面测试

V

V 模型 验证测试 验证测试 虚拟用户 容量测试 漏洞测试

W

Web 应用程序测试 白盒测试 工作流测试

有用的资源

有用的资源 讨论


软件测试 - 循环复杂度

软件测试包括白盒黑盒测试技术。在白盒测试中,代码的内部结构得到验证。循环复杂度是白盒测试下的概念之一,由 Thomas McCabe 开发。它是一种软件度量,通过获取决策点的总数来衡量程序的复杂度。

什么是循环复杂度?

循环复杂度是通过绘制代码的控制流图获得的,它计算贯穿整个程序的线性独立路径的总数。圈复杂度数值越高,更新和维护代码的风险就越高,发现问题的概率就越高,并且理解代码的难度也就越大。循环复杂度衡量代码的可读性,以及程序中不同线性独立路径的总数,从而了解实现逻辑的复杂程度。

计算循环复杂度的公式

有三个计算循环复杂度的公式,如下所示 −

公式 1

对于程序代码控制图 (G),用 V(G) 表示的循环复杂度等于 E - N + 2 * P,其中 E 等于边的总数,N 等于节点的数量,P 等于图中连通分量的总数。

公式 2

对于程序代码控制图 (G),用 V(G) 表示的循环复杂度等于 P + 1,其中 P 等于决策或条件节点的总数。决策或条件节点导致在控制流图中产生两个分支。

公式 3

对于程序代码控制图 (G),用 V(G) 表示的圈复杂度等于 R + 1,其中 R 是控制流图内封闭区域的总数。

示例

让我们以下面的代码块为例,我们将使用上面讨论的公式计算圈复杂度。

IF X = 300
   THEN IF Y > Z
   THEN X = Y
ELSE X = Z
   END IF
END IF
PRINT X

上述代码行的控制流图如下所示 −

cyclomatic complex graph

在上述控制流图中,有七个节点(N),以蓝色圆圈表示。请注意,代码中的总行数等于节点总数。控制流图中红色表示有八条边(E),由于只有一种方法,图中连通分量(P)的总数为 1。因此根据公式,

V(G) = E - N + 2 * P
= 8 - 7 + 2 * 1 = 3

在上述代码及其控制流图中,有两个条件语句,IF X = 300,THEN IF Y > Z,因此有两个条件节点(P),即 1 和 2,在控制流图中以绿色表示。因此根据公式,

V(G) = P + 1
= 2 + 1 = 3

在上面的控制流图中,有两个封闭区域(R),用两个透明圆圈表示,即控制流图中用橙色表示的 1 和 2。因此,根据公式,

V(G) = R + 1
= 2 + 1 = 3

因此,使用这三个公式,我们得到的圈复杂度值与 3 相同。

圈复杂度的用途

圈复杂度的用途列于下方 −

  • 检测所有独立路径对开发人员和测试人员都非常有帮助。
  • 它确认代码中的每条路径都至少被验证过一次。
  • 它有助于检测程序代码中未覆盖的路径。
  • 它有助于提高代码覆盖率。
  • 它有助于识别潜在风险并减轻风险。

优点圈复杂度的优点如下 −

  • 它用作软件开发代码的质量指标。
  • 它比 Halstead 指标更快。
  • 它有助于确定测试的工作量和关键领域。
  • 它指导测试过程。
  • 它可以轻松应用。

圈复杂度的缺点

圈复杂度的缺点如下 −

  • 它只关心软件代码的复杂性,而不关心它处理的数据。
  • 嵌套程序代码的圈复杂度值不易确定。
  • 圈复杂度可能在简单比较时产生错误值,并且决策结构。

结论

至此,我们对软件测试 Mccabe 的圈复杂度教程进行了全面的介绍。我们首先描述了什么是圈复杂度、计算圈复杂度的公式、获取圈复杂度的示例、圈复杂度的用途、圈复杂度的优点和缺点。这使您具备了软件测试 - Mccabe 的圈复杂度的深入知识。明智的做法是继续练习您学到的知识并探索与软件测试相关的其他知识,以加深您的理解并拓展您的视野。