性能测试-概念篇-性能测试分类

作者: 软件测试技能栈 | 来源:发表于2017-07-26 11:54 被阅读248次

性能测试是一个很广泛的概念,通常情况下有如下分类:

what-is-performance-testing.jpg
  • 负载测试(Load testing)
    负载测试是不断增加系统的负载,直到负载达到阈值——评估系统在预期工作负载下的性能的测试。
    这里增加负载的意思是在测试中增加并发用户数量、用户交互等,通常是在可控的环境下进行。典型的负载测试包括在负载测试过程中确定响应时间吞吐量误码率等。
    该方法可以找到系统的性能极限,可以为性能调优提供相关数据。该类方法通常要基于或模拟系统真实运行环境,且选取的业务场景也要尽可能地与实际情况相符。
    举例:
    对于具有预计1000并发用户负载的新开发的应用程序来说,则需要创建负载测试的脚本,配置1000个虚拟用户,然后持续运行1小时。负载测试完成后,再分析测试结果,确定应用程序将如何在预期的峰值负载下运行。

  • 压力测试(Stress Testing)
    压力测试是指当硬件资源如cpu、内存、磁盘空间等不充足时对软件稳定性的检查。
    压力测试属于负面测试(Negative testing),使大量并发用户/进程加载软件以使系统硬件资源不能应付。这个测试也被称为是疲劳测试(Fatigue testing),通过超出其能力的测试来捕获应用程序的稳定性。
    压力测试的主要思想是确定系统故障,关注系统如何优雅地恢复正常,这种质量被称为是可恢复性
    负面测试(Negative testing)是相对于正面测试(Positive testing)而言的。正面测试就是测试系统是否完成了它应该完成的功能;而负面测试就是测试系统是否不执行它不应该完成的操作。

  • 尖峰测试(Spike testing)
    尖峰测试(Spike testing)其实可以算作是压力测试(Stress Testing)的子集。
    尖峰测试是在目标系统经受短时间内反复增加工作负载,以至超出预期生产操作的负载量时,分析系统的行为,验证其性能特征。它还包括检查应用程序是否可以从突然增加的超预期负荷中恢复出来的测试。
    举例:
    在电商应用程序中经常有“整点秒杀”的活动,所以在整点时间前后的两三分钟时间里,会有巨大数量的用户进入到该活动中秒杀商品。尖峰测试就是为了分析这类场景。

  • 可扩展性测试(Scalability Testing)
    可扩展性测试(Scalability Testing)是一种非功能的测试,它测试软件应用程序以确定所有非功能能力的扩展能力,如用户负载支持、事务数量、数据量等。

  • 容量测试(Volume testing)
    容量测试是一种非功能的测试,它通过向应用程序中添加大量的数据来实现。可以通过向数据库插入大量的数据或让应用程序处理一个大型文件来进行测试应用程序。
    通过容量测试,可以识别应用程序中具有大数据时的瓶颈,检查应用程序的效率,进而得到不同数据量级下应用程序的性能。
    举例:
    在一个新开发的网络游戏应用程序中,在进行容量测试时,可以通过向数据库中插入数百万行的数据,然后在这些数据的基础上进行性能的测试。
    注意,这里所说的数据一定是符合其功能场景的,不是毫无关系的数据。

  • 持久测试(Endurance testing)
    持久测试(Endurance testing),也被称为是浸泡测试(Soak Testing),它也是一种非功能的测试。
    持久测试是指在相当长的时间内使用预期的负载量对系统进行测试,以检查系统的各种行为,如内存泄露、系统错误、随机行为等。
    这里的提到的相当长的时间是相对而言的,举例来说,如果一个系统设计为运行3个小时的时间,那可以使用6个小时的时间来进行持久测试;如果设计为5个小时的时间,不妨用10个小时的时间来进行持久测试。对于现在的许多网络类应用程序,通常情况下会持续运行好多天,那么进行持久测试时可以选择更长的时间段。

总结

其实很多时候并不需要把这些概念和分类搞得特别清楚,而且事实上也很少有人能搞得特别清楚。但这并不是说理清楚这些分类就没有意义。恰恰相反,理清性能测试的分类是为了能够有重点、有针对性地覆盖性能测试的方方面面。

比如容量测试,即便你不知道这个概念,也可能会根据实际的需求考虑到这种场景并进行测试。然而当你知道了这些具体的分类和侧重点,在设计性能测试方案时便会有针对性地覆盖这些方面。

在实际工作中,性能测试常常在口头上表达为压力测试,进而简称为压测。虽然这种称呼并不准确,但足以达到沟通的效果了。

而且实际工作中所做的性能测试方面的工作很多时候是上述分类的组合或衍生,以及根据实际工作的应用场景、产品的侧重点、用户的需求等综合考量后逐渐演变形成的一些测试方法和规则。因此,上述的分类更多是一种通用的、普世的分类,不必过多较真。

参考文章:

http://www.softwaretestingclass.com/what-is-performance-testing/
http://artoftesting.com/performanceTesting/types-of-performance-testing.html

更多内容

关于性能测试分类,如需更多了解,可以阅读下列文章:
https://msdn.microsoft.com/en-us/library/bb924357.aspx
http://www.cnblogs.com/fnng/archive/2012/06/09/2543274.html

相关文章

  • 2018-08-02

    性能测试-概念篇-性能测试分类

  • 笔记

    性能测试的目的:发现性能瓶颈 性能测试的分类概念:性能测试是个非常广泛的概念,包括的很多方面的测试,也可称为只为非...

  • 性能测试-概念篇-性能测试分类

    性能测试是一个很广泛的概念,通常情况下有如下分类: 负载测试(Load testing) 负载测试是不断增加系统的...

  • 性能测试-概念篇-性能测试分类

    性能测试是一个很广泛的概念,通常情况下有如下分类: 负载测试(Load testing)负载测试是不断增加系统的负...

  • 回顾性能测试的一些概念

    最近跟着研读虫师和乙醇的博客,又重新回顾一下性能测试有关的概念内容。 性能测试有哪些分类? 性能测试(狭义):性能...

  • 一,性能测试的目的及分类

    目的:发现性能瓶颈 概念:性能测试是一个非常广泛的概念,包括很多方面的测试,也可称为非功能测试 具体分类(测试范围...

  • 性能测试-相关术语理解(一)

    1.性能测试分类 性能测试不是单纯割裂的分类,应该通过分析性能测试所包含元素之间的关系,高效设计性能测试,重点关注...

  • 性能测试--性能测试概念及分类

    1.负载测试 通过逐步增加系统负载,测试系统性能的变化,并最终确定在满足系统性能指标的前提下,系统所能承受的最...

  • 性能测试的概念和分类

    性能测试的概念和分类 性能测试:是为描述测试对象与性能相关的特征并对其进行评价而实施和执行的一类测试。是通过自动化...

  • 玩转电商应用性能调优

    第1章 入门篇—性能测试基础知识 什么性能测试 性能测试类型 性能测试基本流程 性能测试需求分析 性能测试指标

网友评论

    本文标题:性能测试-概念篇-性能测试分类

    本文链接:https://www.haomeiwen.com/subject/ccinkxtx.html