为什么集成测试被人瞧不起?我不理解还是?

Posted 软件测试test

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为什么集成测试被人瞧不起?我不理解还是?相关的知识,希望对你有一定的参考价值。

软件测试 是软件开发周期中的一个阶段,在此阶段中,对关键业务软件进行正确性,质量和性能验证。

软件测试中有四个基本级别,每个级别都在开发过程中从独特的角度检查软件功能。下图显示了软件测试的四个级别。

本文详细介绍了集成测试,这是软件测试的第一级。 

什么是集成测试?

集成测试是软件测试的一个级别,其中将各个单元组合并进行测试,以验证它们在集成时是否按预期工作。这里的主要目的是测试模块之间的接口。

由于多种原因,仅单元测试是不够的,例如:

  • 模块/单元通常由单独的软件开发人员设计,其技术和编程逻辑与其他程序员不同

  • 通常在模块开发时,用户需求会发生变化,并且这些新需求可能未经过单元测试。这引发了问题

  • 在单元测试期间,有时会遗漏诸如数据格式,错误陷阱,硬件接口和第三方服务接口之类的问题

因此,无论每个模块/单元的运行效率如何,如果它们未正确集成,都会影响软件程序的功能。作为解决方案,集成测试得以实施。本文“什么是集成测试?” 进一步列出了集成测试的优势。

集成测试的优势

进行集成测试有很多好处。下面列出了其中一些:

  • 确保集成模块按预期正常工作

  • 一旦要测试的模块可用,测试人员就可以开始测试

  • 它检测与模块之间的接口有关的错误

  • 帮助模块与API和其他第三方工具进行交互

  • 通常覆盖大量系统,因此效率更高

  • 增加测试范围并提高测试的可靠性

软件工程师执行集成测试。有时,公司会聘请独立的测试人员来为他们做。但是,实际上如何进行集成测试?它是否与其他测试过程相似?让我们看看“什么是集成测试”的下一部分。文章。

集成测试如何完成?

集成的含义非常简单–将经过单元测试的模块一个接一个地组合,然后测试组合单元的功能。通常,集成测试是在单元测试之后进行的。一旦创建并测试了所有单个单元,我们便开始组合那些经过测试的模块并开始执行集成测试。这里的主要目标是测试单元/模块之间的接口。以下是一些简单的步骤,可帮助您开始进行集成测试:


  • 准备测试整合计划

  • 确定集成测试方法的类型

  • 相应地设计测试用例,测试场景和测试脚本

  • 一起部署所选模块并运行集成测试

  • 跟踪缺陷并记录测试结果

  • 重复上述步骤,直到测试完整个系统

请记住,必须优先考虑模块或单元之间的集成接口链接。如您所见,在第二步中,您需要确定集成测试方法的类型。在“什么是集成测试”中前进 文章,让我们了解如何执行这些测试策略,它们的优缺点。

集成测试的类型

在开始讨论可用的集成测试类型之前,我们需要了解存根和驱动程序的概念。在测试期间,有时我们会遇到某些模块仍在开发中的情况。这些用于测试目的的模块已替换为一些虚拟程序。这些虚拟程序称为存根和驱动程序。

想象一下,我们有一个包含两个模块的应用程序,即Login Page(模块A)Admin Page(模块B)

情况1:您必须测试已开发并发送给测试团队的登录页面。登录页面取决于管理页面。但是管理页面尚未准备好。为了克服这种情况,开发人员编写了一个虚拟程序,充当管理员页面。这个伪程序是Stub。存根是“被称为程序”。

情况2:您必须测试管理页面,但登录页面尚未准备好。为了克服这种情况,开发人员编写了一个虚拟程序,其作用类似于“登录页面”。该虚拟程序是Driver。驱动程序是“调用程序”。

现在您已经了解了这些必要的概念,让我们检查一下不同类型的集成测试。集成测试类型分为以下列出的不同组:

为什么集成测试被人瞧不起?我不理解还是?

大爆炸整合测试

在这种测试方法中,一旦所有模块分别开发和测试,它们将被集成一次并立即一起测试。这种测试的唯一优点是,它非常适合于较小的系统。

缺点

  • 故障定位很困难

  • 测试之前有很多延迟

  • 关键问题没有得到优先解决

  • 很难找到问题的根本原因

增量集成测试

通过将逻辑上相关的两个或更多模块连接在一起来执行增量测试。后来又添加了更多模块,并对其功能进行了测试。直到完成所有模块的集成并成功测试为止。它又分为自上而下方法,自下而上方法和三明治方法。

自上而下的集成测试

自上而下的方法从测试最顶层的模块开始,然后逐步地逐步降到最低的一组模块。测试按照软件系统的控制流程从上到下进行。由于在测试顶层模块时有可能未开发出较低级别的模块,因此我们使用存根而不是那些尚未就绪的模块。对于简单的应用程序,存根将简单地将控件返回其上级模块。对于复杂的应用程序,他们将模拟整个响应范围。

优点:

  • 故障定位更容易

  • 测试产品极为一致 

  • 与驱动程序相比,可以以更少的时间写存根

  • 关键模块经过优先级测试

  • 尽早发现主要设计缺陷

缺点

  • 需要几个存根 

  • 对早期发布的支持不佳

  • 在周期结束时测试基本功能

自下而上的集成测试

自下而上的方法从测试应用程序的最低单元开始,然后逐步地逐步进行。从控制流的底部到向上进行测试。同样,在测试较低的模块时,可能尚未开发出较高级别的模块。在这种情况下,我们通过使用驱动程序来模拟缺少的模块的功能。这些驱动程序执行一系列任务,例如调用被测模块,传递测试数据或接收输出数据。 

为什么集成测试被人瞧不起?我不理解还是?

优点

  • 在这里,开发和测试可以一起完成,从而使产品高效

  • 测试条件很容易创建

缺点

  • 需要几个驱动程序

  • 数据流测试很晚 

  • 需要驱动程序使测试数据管理变得复杂

  • 对早期发布的支持不佳

  • 关键接口缺陷发现较晚

三明治集成测试

为了克服这些限制并利用自顶向下和自底向上方法的优势,使用了集成测试的混合方法。这种方法称为三明治集成测试或混合集成测试。在这里,系统被视为三层。主目标层位于中间,目标层上方的另一层,目标层下方的最后一层。自上而下的方法用于从顶层到中间层的层。自下而上的方法用于从底部到中间的层。大爆炸方法用于中间的模块。 

为什么集成测试被人瞧不起?我不理解还是?

优点

  • 自上而下和自下而上的测试技术可以并行执行,也可以一个接一个地执行

  • 对于大型企业和大型项目(还有几个子项目)非常有用

缺点


  • 成本要求很高

  • 不能用于模块之间相互依存性强的小型系统

  • 不同级别的测试人员需要不同的技能

这些是可用于根据测试要求执行集成测试的不同方法。您应该检查可以采用的测试策略,并相应地准备测试数据和测试计划。集成测试虽然很有用,但并非没有缺点。您需要了解实施它时可能面临的挑战。

集成测试的挑战

  • 有时由于诸如数据库,平台,环境等各种因素,管理集成测试很困难

  • 将新系统集成到旧系统或集成两个旧系统需要大量测试工作和更改

  • 两家不同公司开发的两种系统之间的兼容性较弱,这对程序员来说是一个挑战

  • 有太多不同的路径和排列方式无法应用于测试集成系统

往期推荐


为什么集成测试被人瞧不起?我不理解还是?


为什么集成测试被人瞧不起?我不理解还是?

点个在看你最好看

以上是关于为什么集成测试被人瞧不起?我不理解还是?的主要内容,如果未能解决你的问题,请参考以下文章

什么是集成测试?如何运用集成测试?

Spring 的 MockMvc 是用于单元测试还是集成测试?

Spring @Transactional 和回滚不起作用,弹簧集成测试

集成测试

一个简单的 Dao 集成测试不起作用

Spring启动集成测试回滚不起作用