谈谈端到端测试(End-to-End Testing)

谈谈端到端测试(End-to-End Testing)

当今的软件系统是复杂的,并且与许多子系统相互关联。如果任何子系统出现故障,整个软件系统都可能崩溃。这是一个主要的风险,可以通过端到端测试来避免。

端到端测试是一种技术,它从头到尾测试整个软件产品,以确保应用程序流按预期运行。它定义了产品的系统依赖关系,并确保所有集成的部分按预期协同工作。

端到端(E2E)测试的主要目的是通过模拟真实的用户场景,验证被测系统及其组件的集成性和数据完整性,从最终用户的体验进行测试。

今天的软件越来越复杂。应用程序构建在子系统的层和整个网络上,包括UI和API层、外部数据库、网络,甚至第三方集成。当一个组件失败时,整个产品也会失败,这使得每个组件的稳定性对于应用程序的成功至关重要。这意味着有一个明确的需要测试整个应用程序,从开始到结束-在API和UI层。端到端测试应该同时使用自动测试和手动测试策略来运行-允许您的团队最大化他们的覆盖范围,同时以探索的方式发现新的bug。

端到端测试是软件开发生命周期(SDLC)中使用的一种方法,用于在类似产品的环境下测试应用程序的功能和性能,并使用数据复制实时设置。

目标是模拟真实用户场景从头到尾的样子。

完成此测试不仅是为了验证被测系统,而且是为了确保其子系统按预期工作和行为

什么是端到端测试(End-to_End Testing)?

端到端测试是一种软件测试方法,它从开始到结束验证整个软件,以及与外部接口的集成。

端到端测试的目的是测试整个软件的依赖性、数据完整性以及与其他系统、接口和数据库的通信,以实现完整的生产场景。

与软件系统一起,它还验证来自其他上游/下游系统的批处理/数据处理。因此,有了“端到端”的名称。

端到端测试通常在功能和系统测试之后执行。它使用实际的生产数据和测试环境来模拟实时设置。

端到端测试也称为链测试。

谈谈端到端测试(End-to-End Testing)_第1张图片

为什么要进行端到端测试?

端到端测试验证完整的系统流,并通过检测问题和增加子系统的测试覆盖率来增加信心。

现代软件系统是复杂的,并且与多个子系统相互关联,这些子系统可能不同于当前的系统。

任何子系统的故障都可能导致整个系统崩溃,这是通过端到端测试可以避免的重大风险。

端到端测试的好处

端到端测试因以下优点而更为可靠和广泛采用:

  • 扩大测试覆盖范围
  • 确保应用程序的正确性
  • 缩短发布时间
  • 降低成本
  • 检测Bug

进行端到端测试将帮助您确保软件已准备好生产,并避免发布后的风险。这个过程对于您的应用程序的成功至关重要,有几个关键原因:

  • 确认您的应用程序运行状况:端到端测试将验证您的软件在各个级别(从前端到后端以及在多个系统上)的功能,并提供跨不同环境的性能视角。
  • 扩展测试覆盖范围:通过在测试过程中合并许多不同的子系统,您将有效地扩展测试覆盖范围,并创建以前可能没有考虑过的其他测试用例。
  • 检测错误并提高应用程序生产率:在端到端测试中,软件通常在每次迭代后都会进行测试,这意味着您可以更快地发现和修复任何问题。这将减少bug进一步进入测试过程(以及生产过程)的机会,从而确保应用程序工作流无缝运行。
  • 减少测试工作量和成本:由于每一步都有较少的bug、故障和全面的测试,端到端测试还将减少重复测试的需要,并最终减少与重复测试相关的成本和时间。

现代软件系统通过技术进步允许子系统交互。无论子系统与主系统相同或不同,在组织内部或外部,子系统故障都会对整个系统造成不利影响。

通过执行以下操作可以避免系统风险:

  • 验证系统流程
  • 增加测试覆盖区域
  • 检测与子系统相关的问题

E2E测试广泛地吸引了许多群体:

  • 开发人员从中受益,因为大部分测试都被转移给了其他人。
  • 测试人员发现它很有用,因为编写验证真实世界行为的测试可以帮助他们避免问题并获得更大的成就感。
  • 管理者喜欢它,因为用户模拟测试让他们知道失败的测试将如何影响用户。

何时应用端到端测试?

有许多场景可以应用端到端测试。举个例子:

在测试之前,设计人员和开发人员创建一个列表,列出需要执行的UI、函数或特性。应跟踪系统之间的数据流,以发现依赖性、缺陷和不准确之处。团队还必须在测试前准备条件(可能改变任何接口选项的因素)。

定期对成品和系统进行E2E测试,使每次评审成为对已完成系统的测试。如果系统没有输出预期的结果或发现问题,将进行第二次测试。在这种情况下,团队必须记录和分析数据,以确定问题的根源;然后修复并重新测试它们。

端到端测试和功能测试的对比

端到端测试不仅仅是几个单元测试和功能测试串联在一起——它们更复杂,也带来更多风险。为了进一步说明这一点,我列出了功能测试和E2E测试之间的主要区别。

功能测试 端到端测试
测试仅限于一段代码或应用程序。 测试跨越多个应用程序和用户组。
确保测试软件符合验收标准。 确保流程在进行更改后继续工作。
测试单个用户参与应用程序的方式。 测试多个用户跨应用程序工作的方式。
验证每个输入和输出测试的结果。 验证流程中的每个步骤是否已完成。

 

端到端测试和系统测试的对比

系统测试和端到端测试的对比,如表格所示:

 

端到端测试流程(End to End Testing Process)

如下图所示:

 

端到端测试生命周期由四个组件组成:测试规划、测试设计、测试执行和结果分析。

测试计划:指定关键任务、相关时间表和资源

测试设计:测试规范、测试用例生成、风险分析、使用分析和调度测试

测试执行:执行测试用例并记录测试结果

结果分析:分析测试结果,评估测试,必要时进行附加测试

端到端测试步骤:

  • 第一步:分析需求。对应用程序应该如何在各个方面工作有一个清晰的想法
  • 第二步:建立一个符合所有需求的测试环境
  • 第三步:分析软件和硬件需求
  • 第四步:列出每个系统需要如何响应
  • 第五步:列出测试这些响应所需的测试方法。包括每个测试中要遵循的标准(语言、工具等)的明确描述。
  • 第六步:设计测试用例
  • 第七步:运行测试、研究并保存结果

端到端测试方法

水平E2E测试

跨多个应用程序的上下文水平出现的一种常用方法,很容易在单个ERP(企业资源规划)应用程序中发生。

一个例子:基于Web的电子商务系统应用程序包括帐户、产品库存状态和装运详细信息。

垂直E2E测试

这种方法指的是分层测试,这意味着测试按顺序、层次顺序进行。为了确保质量,系统或产品的每个组成部分都要从头到尾进行测试。

垂直测试通常用于测试复杂计算系统的关键组件,这些组件通常不涉及用户或接口。

端到端测试的指标

E2E测试使用的许多指标包括:

  • 测试用例准备状态:用于确定正在准备的测试用例相对于计划的测试用例的具体位置。
  • 测试进度跟踪:应每周跟踪测试进度。此步骤将提供测试完成百分比的常规详细信息,如通过/失败、已执行/未执行、有效/无效测试用例等。
  • 缺陷状态和细节:它给出每周打开和关闭缺陷的百分比。而且,每周的缺陷分布是基于严重性和优先级的。
  • 环境可用性:实际操作小时数和每天计划用于测试的小时数。

在软件工程中,端到端测试是验证软件系统及其子系统的过程。在这个测试中最大的挑战是对整个系统以及一个相互连接的子系统有足够的了解。

 

你可能感兴趣的:(软件测试方法论,Agile,Testing,软件测试)