可靠性测试教程(什么是,方法,工具,示例)


在给定环境中,软件在一段时间内无故障执行的可能性定义为可靠性。

在当今这个机械化的环境中,人们天真地相信任何程序。人们认为软件系统产生的任何结果都是正确的,因此他们遵循它。这是一个我们都会犯的常见错误。

用户相信显示的数据是正确的,并且软件将始终正常工作。这就是可靠性测试需求产生的原因。

可靠性测试

可靠性测试是一种软件测试程序,用于确定软件是否可以在给定环境中在一段时间内无故障运行。可靠性测试确保软件产品没有错误,并且能够执行其预期功能。

可靠性从字面上理解为“产生相同的结果”。换句话说,“可靠”一词表明某事物值得信赖,并且每次都会提供相同的结果。可靠性测试也是如此。

可靠性测试何时发挥作用?

以下是可靠性测试的目标 -

  • 找出重复故障的模式。

  • 确定在给定时间段内发生的故障次数。

  • 确定故障的主要原因

  • 在修复错误后,对软件程序的多个组件执行性能测试。

测试用例应以涵盖软件所有方面的方式编写。应定期运行测试用例,以便我们可以将当前结果与先前结果进行比较,并查看是否存在任何差异。如果它产生相同或相似的结果,则认为软件是值得信赖的。

我们还可以通过运行测试用例一段时间并查看在此时间段后结果是否在没有任何错误的情况下正确显示来测试可靠性。在执行可靠性测试时,我们必须验证环境限制,例如内存泄漏、电池电量低、网络连接不良、数据库问题等。

可靠性测试示例

零售 PC 在 8 小时内不崩溃的可能性为 99%,这称为可靠性。可靠性测试分为三类。

  • 建模

  • 测量

  • 改进

可以使用以下公式计算故障的可能性。

概率 = 故障实例数 / 评估的案例总数

影响软件可靠性的因素

  • 软件中缺陷的总数。

  • 人们与系统交互的方式

  • 可靠性测试是提高软件质量的关键之一。此测试有助于检测软件设计和功能中的许多缺陷。

  • 可靠性测试的基本目标是查看软件是否满足客户的可靠性要求。

  • 将有多个可靠性测试阶段。在单元、组件、子系统和系统级别,将对复杂系统进行测试。

可靠性测试类型

  • 功能测试 此测试评估适当性,或应用程序是否按预期用于其预期用途。它将在此处检查应用程序的互操作性,以便使用与其交互的其他组件和系统对其进行测试。它通过检查在 Beta 测试期间发现的缺陷来确保系统的准确性。除此之外,它还检查安全性和合规性。安全测试关注的是防止对应用程序的意外或故意未经授权的访问。我们将通过查看应用程序是否满足特定标准(例如标准、规则等)来验证合规性。

  • 压力测试 负载测试将确定系统相对于其他系统或性能的运行情况。它还取决于使用系统的并发用户数量以及系统对用户的行为。系统必须及时响应用户命令(例如 5 秒)并满足用户期望。

  • 回归测试 回归测试将确定系统是否正常运行,以及由于安装新的软件功能是否引入了任何缺陷。当修复错误并且测试人员需要重新测试它时,也会执行此操作。

如何测试可靠性

与其他类型的测试相比,可靠性测试成本更高。因此,在执行可靠性测试时,适当的计划和管理至关重要。其中包括将使用的测试过程、测试环境的数据、测试计划和测试点等。

要开始可靠性测试,测试人员必须跟踪以下项目 -

  • 设定可靠性目标。

  • 创建您的操作配置文件

  • 计划和执行测试

  • 根据测试结果做出判断。

正如我们之前所述,我们可以通过建模、测量和改进三个类别来执行可靠性测试。

以下是可靠性测试中的重要参数 -

  • 无故障运行的可能性

  • 无故障运行的持续时间

  • 执行它的环境

软件建模(步骤 1) 建模技术分为两类 -

  • 预测建模

  • 估计建模

可以使用适当的模型来产生有意义的结果。

为了简化问题,可以使用假设和抽象,但没有一个模型适合所有场景。

以下是在这两种模型之间主要区别 -

问题预测模型估计模型
数据参考它基于历史数据。它利用来自软件开发过程的最新数据。
在开发周期中使用时它通常在开发和测试阶段之前开发。它最常用于软件开发生命周期的末期。
时间范围它将能够预测未来的可靠性。它将预测现在或将来的可靠性。

测量(步骤 2)

由于无法直接测试软件可靠性,因此会考虑各种因素来评估软件可靠性。目前有四种软件可靠性测量方法 -

  • 产品指标 产品指标由四种不同类别的组成 -

    • 软件大小 - 代码行数 (LOC) 方法是一种估算软件大小的简单方法。此度量仅计算源代码;不包括注释和其他非可执行语句。

    • 功能点指标 - 功能点指标是一种评估软件开发功能的方法。它将考虑输入、输出、主文件等的数量。它独立于编程语言,并衡量提供给用户的功能。

    • 复杂性 - 它与软件可靠性直接相关;因此,描述复杂性至关重要。面向复杂性的指标通过将代码转换为图形表示来确定程序控制结构的难度。

    • 测试覆盖率指标 - 它是通过充分评估软件产品来查找软件产品中故障和可靠性的一种方法。软件可靠性是确定系统是否已充分验证和测试的能力。

  • 项目管理指标  研究人员发现,良好的管理可以带来更高质量的产品。通过采用更好的开发流程、风险管理流程、配置管理流程等,良好的管理可以实现可靠性的提高。

  • 流程指标 该方法对产品的质量有直接影响。可以使用流程指标估算、监控和改进软件可靠性和质量。

  • 故障和失效指标 故障和失效指标主要用于确定系统是否完全无故障。为了达到此目的,将收集、汇总和分析测试过程中(即交付前)发现的两种类型的错误以及交付后用户报告的故障。

平均故障间隔时间用于评估软件可靠性 (MTBF)。MTBF 由以下组成

  • 平均故障时间 (MTTF) 是两次连续故障之间的时间。

  • 平均修复时间 (MTTR) 是解决问题所需的时间。

MTBF = MTTF + MTTR 是计算最大故障间隔时间的公式。

对于良好的软件,可靠性是一个介于 0 和 1 之间的数字。

当修复程序中的故障或缺陷时,可靠性会提高。

步骤 3 - 增强

改进完全取决于应用程序或系统中出现的故障,或软件的功能。改进方法将根据软件模块的复杂性而有所不同。两个主要限制,时间和资金,将限制投入到提高软件可靠性中的工作量。

可靠性测试方法示例

可靠性测试是对应用程序进行全面测试,以在系统发布之前识别并消除缺陷。

可靠性测试主要有三种方法:

  • 重测信度

  • 平行形式信度

  • 决策一致性

总结

可靠性测试是可靠性工程计划中必不可少的一部分。更准确地说,它是可靠性工程工作的核心。

此外,在软件测试期间,可靠性测试主要用于揭示特定的故障模式和其他问题。

在软件工程中,可靠性测试分为三类。

  • 建模

  • 测量

  • 改进

改进因素对软件可靠性的影响

  • 软件中缺陷的总数。

  • 人们与系统交互的方式。

更新于: 2021年9月22日

793 次查看

开启您的 职业生涯

通过完成课程获得认证

立即开始
广告