Javatpoint标志
Javatpoint标志

软件测试的类型

在本节中,我们将了解各种类型的软件测试,它们可以在软件开发生命周期中使用。

正如我们所知,软件测试是根据客户的前提条件分析应用程序功能的过程。

如果我们想要确保我们的软件是无bug或稳定的,我们必须执行各种类型的软件测试,因为测试是使我们的应用程序无bug的唯一方法。

软件测试的类型

不同类型的软件测试

软件测试的分类是不同测试活动的一部分,例如测试策略,测试可交付成果,定义好的测试目标等等.而软件测试就是在软件的执行过程中发现缺陷。

测试类型的目的是确认AUT(测试中的应用程序)。

要开始测试,我们应该有一个需求、应用程序就绪、可用的必要资源.为了保持责任感,我们应该给不同的测试工程师分配相应的模块。

软件测试主要分为以下两部分:

软件测试的类型
  • 手工测试
  • 自动化测试

什么是手动测试?

根据客户的需要测试任何软件或应用程序,而不使用任何自动化工具被称为手工测试

换句话说,我们可以说这是一个过程验证和确认.手动测试用于验证应用程序或软件与需求规范相矛盾的行为。

软件测试的类型

我们不需要任何测试工具的精确知识来执行手动测试用例。在对任何应用程序执行手动测试时,我们可以轻松地准备测试文档。

要获得关于手动测试的详细信息,请单击以下链接://m.047138.com/manual-testing。

手工测试的分类

在软件测试中,手动测试可以进一步分为三种不同类型的测试,具体情况如下:

  • 白盒测试
  • 黑盒测试
  • 灰盒测试
软件测试的类型

为了更好地理解,让我们一个一个来看:

白盒测试

在白盒测试中,开发人员将检查每一行代码,然后将其交给测试团队或相关的测试工程师。

软件测试的类型

随后,在整个测试过程中,代码对开发人员来说是显而易见的;这就是为什么这个过程被称为WBT(白盒测试)

换句话说,我们可以说开发人员为特定的软件执行完整的白盒测试,并将特定的应用程序发送给测试团队。

实现白盒测试的目的是强调软件上的输入和输出流,并增强应用程序的安全性。

软件测试的类型

白盒测试也被称为开箱测试、玻璃箱测试、结构测试、透明盒测试、透明盒测试

要获得关于白盒测试的深入知识,请参考以下链接://m.047138.com/white-box-testing

黑盒测试

另一种类型的手动测试是黑盒测试.在这个测试中,测试工程师将根据需求分析软件,识别缺陷或错误,并将其发送回开发团队。

软件测试的类型

然后,开发人员将修复这些缺陷,进行一轮白盒测试,并将其发送给测试团队。

在这里,修复bug意味着解决了缺陷,并且特定的特性可以根据给定的需求工作。

实现黑盒测试的主要目标是指定业务需求或客户的需求。

换句话说,我们可以说黑盒测试是根据客户需求检查应用程序功能的过程。源代码在此测试中不可见;这就是为什么它被称为黑盒测试

软件测试的类型

有关黑盒测试的更多信息,请参考以下链接://m.047138.com/black-box-testing

黑盒测试的类型

黑盒测试又分为两部分,具体讨论如下:

  • 功能测试
  • 非功能性测试
软件测试的类型

功能测试

测试工程师将根据需求规范系统地检查所有组件功能测试.功能测试也称为组件测试

在功能测试中,通过给出值、定义输出以及用预期值验证实际输出来测试所有组件。

功能测试是黑盒测试的一部分,因为它强调应用程序需求而不是实际代码。测试工程师必须只测试程序而不是系统。

要获得关于功能测试的详细信息,请参考以下链接://m.047138.com/functional-testing

功能测试的类型

就像另一种类型的测试分为几个部分一样,功能测试也分为不同的类别。

不同的功能测试的类型包含以下内容:

  • 单元测试
  • 集成测试
  • 系统测试
软件测试的类型

现在,让我们来逐个了解它们:

1.单元测试

为了测试任何软件,单元测试是功能测试的第一级。在这种情况下,测试工程师将独立测试应用程序的模块或测试调用的所有模块功能单元测试

执行单元测试的主要目标是确认单元组件的性能。在这里,单元被定义为软件或应用程序的单个可测试功能。并且在整个指定的应用程序开发阶段对其进行验证。

点击下面的链接来获得关于单元测试的完整信息://m.047138.com/unit-testing

2.集成测试

一旦我们成功地实现了单元测试,我们就可以开始了集成测试.这是功能测试的第二层,我们测试依赖模块之间的数据流或两个特性之间的接口集成测试

执行集成测试的目的是测试每个模块之间语句的准确性。

集成测试的类型

集成测试也进一步分为以下几个部分:

  • 增量测试
  • 增量测试
软件测试的类型

增量集成测试

只要模块之间有明确的关系,我们就进行增量集成测试。假设我们有两个模块,并分析它们之间的数据流,如果它们工作正常或不正常。

如果这些模块工作正常,那么我们可以再添加一个模块并再次测试。我们可以继续同样的过程以得到更好的结果。

换句话说,我们可以说增量地添加模块并测试模块之间的数据流称为增量集成测试

增量集成测试的类型

增量集成测试可以进一步分为以下两部分:

  1. 自顶向下增量集成测试
  2. 自底向上增量集成测试
软件测试的类型

让我们来看看这些集成测试类型的简要介绍:

1.自顶向下增量集成测试

在这种方法中,我们将一步一步或增量地添加模块,并测试它们之间的数据流。我们必须确保我们添加的模块是正确的早期的孩子

2.自底向上增量集成测试

在自底向上方法中,我们将以增量方式添加模块,并检查模块之间的数据流。同时,确保我们要添加的模块是早期的父元素

非增量集成测试/大爆炸方法

每当数据流很复杂并且很难对父级和子级进行分类时,我们将采用非增量集成方法。非增量方法也称为大爆炸方法

要获得关于集成测试及其类型的完整信息,请参考以下链接://m.047138.com/integration-testing

3.系统测试

只要我们完成了单元和集成测试,我们就可以继续进行系统测试。

在系统测试中,测试环境与生产环境是平行的。它也被称为端到端测试。

在这种类型的测试中,我们将经历软件的每个属性,并测试最终功能是否符合业务需求。并将软件产品作为一个完整的系统进行分析。

点击下面的链接,获取关于系统测试的完整信息://m.047138.com/system-testing

非功能性测试

黑盒测试的下一部分是非功能性测试.它提供了关于软件产品性能和使用技术的详细信息。

非功能测试将帮助我们将软件的生产风险和相关成本降至最低。

非功能测试是以下方面的组合性能、负载、压力、可用性和兼容性测试

有关非功能测试的更多信息,请参阅以下链接://m.047138.com/non-functional-testing

非功能测试的类型

非功能测试分为测试的不同部分,我们将进一步讨论:

  • 性能测试
  • 可用性测试
  • 兼容性测试
软件测试的类型

1.性能测试

在性能测试中,测试工程师将通过施加一些负载来测试应用程序的工作情况。

在这种类型的非功能测试中,测试工程师将只关注几个方面,例如响应时间、负载、可伸缩性和稳定性软件或应用程序的。

性能测试分类

性能测试包括各种类型的测试,具体如下:

  • 负载测试
  • 压力测试
  • 可伸缩性测试
  • 稳定性测试
软件测试的类型
  • 负载测试

在执行性能测试时,我们将对特定应用程序施加一些负载,以检查应用程序的性能,即负载测试.在这里,负载可能小于或等于所需的负载。

它将帮助我们检测软件的最高运行容量和瓶颈。

要获得负载测试相关的完整信息,请参考以下链接:

//m.047138.com/load-testing

  • 压力测试

它用于分析软件在一般功能限制之外的用户友好性和鲁棒性。

压力测试主要用于关键软件,但它也可以用于所有类型的软件应用程序。

有关压力测试的深入知识,请参考以下链接://m.047138.com/stress-testing

  • 可伸缩性测试

为了分析,应用程序通过增强或减少特定平衡的负载的性能被称为可伸缩性测试

在可伸缩性测试中,我们还可以检查系统、过程或数据库的能力满足向上的需要在这里,这个测试用例有效地设计和实现。

点击下面的链接,获取与可伸缩性测试相关的详细信息:

//m.047138.com/scalability-testing

  • 稳定性测试

稳定性测试是通过在精确的时间内施加负载来评估应用程序性能的过程。

它主要检查应用的稳定性问题和开发产品的效率。在这种类型的测试中,我们可以快速地发现系统的缺陷,即使是在有压力的情况下。

有关稳定性测试的详细信息,请参考以下链接:

//m.047138.com/stability-testing

2.可用性测试

另一种类型非功能性测试可用性测试.在可用性测试中,我们将分析应用程序的用户友好性,并检测软件终端用户界面中的错误。

这里,这个项用户友好性定义应用程序的以下方面:

  • 应用程序应该易于理解,这意味着终端用户必须能够看到所有的特性。
  • 应用程序的外观和感觉应该是好的,这意味着应用程序的外观应该是令人愉快的,并让最终用户有使用它的感觉。

有关可用性测试的更多信息,我们可以参考以下链接:

//m.047138.com/usability-testing

3.兼容性测试

在兼容性测试中,我们将检查应用程序在特定硬件和软件环境中的功能。一旦应用程序在功能上稳定了,我们就去兼容性测试

在这里,软件这意味着我们可以在不同的操作系统和其他浏览器上测试应用程序硬件这意味着我们可以在不同的尺寸上测试应用程序。

要获得兼容性测试的全面知识,请参阅以下链接:

//m.047138.com/compatibility-testing

灰盒测试

另一部分手工测试灰盒测试.这是一个黑盒和白盒测试的协作

因为,灰盒测试包括了对设计测试用例的内部编码的访问。灰盒测试是由既懂编码又懂测试的人执行的。

软件测试的类型

换句话说,我们可以说,如果一个人的团队做到了这两点白盒测试和黑盒测试,它被认为是灰盒测试

要获得关于灰盒测试的详细信息,我们可以参考以下链接:

//m.047138.com/grey-box-testing

自动化测试

软件测试中最重要的部分是自动化测试。它使用特定的工具来自动化手动设计测试用例,没有任何人为干扰。

自动化测试是提高软件测试的效率、生产力和覆盖率的最好方法。

它用于重新运行手动、快速和重复执行的测试场景。

软件测试的类型

换句话说,我们可以说无论何时通过使用某些工具测试应用程序都被称为自动化测试

我们将在应用程序或软件上进行各种版本或几个回归周期时进行自动化测试。如果不理解编程语言,我们就不能编写测试脚本或执行自动化测试。

有关自动化测试的更多信息,我们可以参考下面的链接:

//m.047138.com/automation-testing

一些其他类型的软件测试

在软件测试中,我们还有一些其他类型的测试,它们不是上述任何测试的一部分,但在测试任何软件或应用程序时都需要这些测试。

  • 冒烟测试
  • 完整性测试
  • 回归测试
  • 用户验收测试
  • 探索性测试
  • 特别的测试
  • 安全性测试
  • 全球化测试

让我们来逐个了解这些类型的测试:

软件测试的类型

冒烟测试,在进行一轮深入而严格的测试之前,我们将测试应用程序的基本和关键功能。

在检查所有可能的正负值之前被称为冒烟测试.分析应用程序的核心和主要功能的工作流程是执行烟雾测试的主要目标。

有关烟雾测试的更多信息,请参阅以下链接:

//m.047138.com/smoke-testing

完整性测试

它用于确保所有的错误都已修复,并且不会由于这些更改而产生额外的问题。健全性测试是无脚本的,这意味着我们不能记录它。它检查新添加的特性和组件的正确性。

要获得关于完整性测试的详细信息,我们可以参考下面的链接:

//m.047138.com/sanity-testing

回归测试

回归测试是最常用的软件测试类型。这里,这个项回归这意味着我们必须重新测试未受影响的应用程序的这些部分。

回归测试是最适合自动化工具的测试。根据项目类型和资源的可访问性,回归测试可以类似于重新测试

每当开发人员修复了一个错误,然后测试应用程序的其他功能时,这些功能可能会因为修复错误而被模拟回归测试

换句话说,我们可以说,每当某个项目有新版本时,我们就可以执行回归测试,并且由于新特性可能会影响早期版本中的旧特性。

要全面了解回归测试相关知识,请参考以下链接:

//m.047138.com/regression-testing

用户验收测试

用户验收测试(UAT)由被称为领域专家/客户或客户的个人团队完成。在接受最终产品之前了解应用程序被称为用户验收测试

在用户验收测试中,我们分析不同环境上的业务场景和实时场景UAT环境.在这个测试中,我们将在UAI获得客户批准之前测试应用程序。

有关用户验收测试的更多信息,请点击以下链接:

//m.047138.com/acceptance-testing

探索性测试

每当需求缺失时,就需要早期的迭代,当我们有一个关键的应用程序时,测试团队有经验丰富的测试人员。新的测试工程师加入了我们的团队探索性测试

为了执行探索性测试,我们将首先以所有可能的方式检查应用程序,制作测试文档,理解应用程序的流程,然后测试应用程序。

点击下面的链接来获得关于探索性测试的完整信息:

//m.047138.com/exploratory-testing

特别的测试

一旦构建处于选中的序列中,就随机测试应用程序特别的测试

也被称为猴子测试和大猩猩测试.在Adhoc测试中,我们将检查与客户需求相矛盾的应用程序;这就是为什么它也被称为负面的测试

当最终用户随意使用应用程序时,他/她可能会检测到一个错误。尽管如此,专业测试工程师还是会彻底使用该软件,因此他/她可能无法识别类似的检测。

关于Adhoc测试的详细信息,请参考以下内容:

//m.047138.com/adhoc-testing

安全性测试

它是软件测试的重要组成部分,用于确定软件应用程序中的弱点、风险或威胁。

安全测试的执行将有助于我们避免来自外部的恶意攻击,确保我们的软件应用程序的安全性。

换句话说,我们可以说安全测试主要是用来定义数据将是安全的,并承受软件的工作过程。

要获得关于安全测试的完整细节,请参阅下面的链接://m.047138.com/security-testing

全球化测试

另一种类型的软件测试是全球化测试。全球化测试用于检查所开发的软件是否支持多种语言。这里,文字全球化意味着为各种语言的应用程序或软件提供启发。

全球化测试用于确保应用程序支持多种语言和多种特性。

在目前的场景中,随着应用程序准备在全球范围内使用,我们可以看到几种技术的增强。

请参考以下链接获取完整的全球化测试相关信息:

//m.047138.com/globalization-testing

结论

在本教程中,我们讨论了各种类型的软件测试。但是仍然有超过100个测试类别的列表。然而,并不是每种测试都用于所有类型的项目。

我们已经讨论了最常用的软件测试类型,例如黑盒测试、白盒测试、功能测试、非功能测试、回归测试、Adhoc测试等

此外,在不同的组织中也有不同的分类或过程,但总体概念在各地都是相似的。

当项目、需求和范围发生变化时,这些测试类型、过程和执行方法也会不断变化。


下一个话题 测试级别





Youtube 观看视频请加入我们的Youtube频道:现在加入

反馈


帮助他人,请分享

脸谱网 推特 pinterest

学习最新教程


准备


热门的技术


B.Tech / MCA






Baidu
map