- 软件测试教程
- 软件测试 - 首页
- 软件测试 - 概述
- 软件测试 - 缺陷管理
- 软件测试 - 生命周期
- 软件测试 - Bug生命周期
- 软件测试 - 误区
- 软件测试 - QA、QC和测试
- 软件测试 - 环境
- 软件测试 - 策略
- 软件测试 - 步骤
- 软件测试 - 测试条件
- 软件测试 - 测试分析
- 软件测试 - ISO标准
- 软件测试 - 类型
- 软件测试 - 技术
- 软件测试 - 方法
- 软件测试 - 指标
- 软件测试 - 层级
- 软件测试 - 估算技术
- 软件测试 - 7大原则
- 软件测试 - 严重程度和优先级
- 软件测试 - 缺陷密度
- 软件测试有用资源
- 软件测试 - 问答
- 软件测试 - 快速指南
- 软件测试 - 有用资源
- 软件测试 - 讨论
软件测试 - 7大原则
软件测试过程是软件开发成功的重要阶段之一。测试是一项相当困难、繁琐且耗时的活动。为了提高其有效性,有必要遵循一些原则,以从软件测试中获得最大收益。
以下是7大测试原则:
测试揭示缺陷的存在
当软件从开发团队转移到测试团队时,会使用各种测试层、类型和方法对其进行彻底测试。因此,软件中所有可能的错误都会被发现并最终解决。此外,软件会经历多个周期以检测尽可能多的错误。
尽管进行了所有测试工作,但不能保证交付的软件完全没有缺陷。可能存在一些未经测试的场景。因此,测试只能降低软件中遇到错误的可能性,但不能保证软件100%没有缺陷。
穷尽测试是不可能的
在测试软件时,不可能覆盖所有可能的先决条件、数据、场景、用例等的组合。此外,穷尽测试需要大量的时间、精力和成本。与其这样做,不如尝试选择最佳、最优和最有效的测试用例集,而不是测试所有组合。最佳测试用例的选择只能通过经验、软件知识以及分析所有可能的风险及其缓解措施来完成。
缺陷集中
据观察,大部分缺陷都来自软件的一小部分模块。这源于测试中的帕累托法则。它指出,80%的缺陷源于软件的20%的组件。
因此,它有助于检测容易出现错误的模块。如果从某个模块中发现了缺陷,则该区域出现更多缺陷的可能性很高。但必须注意,如果对同一模块重复执行类似的测试用例,则发现新错误的可能性会降低。
杀虫剂悖论
这基于这样一个事实:如果对植被反复使用相同的杀虫剂,那么昆虫最终会适应,一段时间后,杀虫剂对昆虫就会失效。
类似地,如果反复执行相同的测试用例组,它们就会变得毫无用处,因为它们无法检测软件中的新错误。为了克服这一点,必须经常审查测试用例,根据新的需求、模块和功能添加、修改或删除它们。此外,应针对新的组合或数据集和场景运行测试用例,以识别更多错误。
尽早测试
测试应从软件开发生命周期(SDLC)的初始阶段开始,从检测需求、设计或开发阶段的错误开始。在早期阶段识别缺陷总是比在最后阶段识别缺陷更好。在SDLC的后期阶段修复缺陷的成本更高。此外,项目截止日期会受到需要在后期阶段记录关键功能的缺陷修复的影响。
测试依赖于上下文
每个软件都有其独特的特性。例如,购票应用程序与电子商务应用程序不同。因此,验证购票应用程序的测试方法、策略和方法与电子商务应用程序始终不同。因此,通用的测试策略框架不适用于所有软件,并且因上下文而异。
无错误谬误
可能存在这样一些情况:一个完整的软件已经过彻底测试,并且有90%的可能性不会遇到任何缺陷。但是,后来可能会发现,整个测试都是基于不正确的需求进行的。因此,软件最终没有任何缺陷,但对客户来说是不可用且不可接受的。这表明,测试不仅仅是为了检测缺陷,还意味着验证软件是否符合用户的需求。
至此,我们完成了关于软件测试7大原则教程的全面概述。我们首先描述了什么是软件测试的7大原则。这使您深入了解软件测试的7大原则。明智的做法是不断实践您学到的知识,并探索与软件测试相关的其他知识,以加深您的理解并扩展您的视野。