测试的各种类型你都了然于胸么
乙醇 创建于 8 months 之前
最后更新: less than a minute 之前
阅读数: 563
验收测试
进行这种类型的测试是为了确定产品的功能是否符合产品需求了。这通常涉及客户的反馈或具体的产品规格。
对于Web应用程序,可以通过模拟用户期望的行为直接使用Selenium来完成此测试的自动化。可以通过记录/回放或通过需求文档中说明的不同受支持的语言来完成此模拟。注意:验收测试是功能测试的子类型,某些人可能还会提到。
功能测试
进行这种类型的测试是为了确定产品的功能是否正常运行而没有问题。
这通常包括:系统可以正常运行(正确的重定向),没有错误(404,异常…), 以及产品的实现符合需求的具体要求(请参见上面的验收测试)。
对于Web应用程序,可以通过模拟具体返回的方式直接使用Selenium来完成此测试的自动化。 可以通过记录/回放或通过本文档中介绍的不同受支持的语言来完成此模拟。
性能测试
顾名思义,进行性能测试是为了衡量应用程序的性能。
性能测试有两种主要的子类型:
负载测试
进行了负载测试,以验证应用程序在不同定义的负载(通常是一次连接的特定数量的用户)下的运行状况。
压力测试
进行了压力测试,以验证应用程序在压力下(或高于最大支持负载)的运行状况。
通常,性能测试是通过执行一些Selenium用例来完成的,这些测试模拟了不同的用户使用Web应用程序的特定功能并收集了一些有意义的指标。
通常,这是由其他获取指标的工具完成的。 JMeter就是这样一种工具。
对于Web应用程序,要测量的详细信息包括吞吐量,延迟,数据丢失,单个组件加载时间…
注意1:所有浏览器的开发人员工具部分均具有“性能”标签(可通过按F12进行访问)
注2:是非功能测试的子类型,因为它通常是按系统而不是按功能/功能进行测试。
回归测试
该测试通常在更改,修复或添加功能之后进行。
为了确保所做的更改没有破坏任何现有功能,将再次执行一些已经执行的测试。
重新执行的测试集可以是全部或部分,并且可以包括几种不同的类型,具体取决于应用程序和开发团队。
测试驱动开发(TDD)
TDD本身不是测试类型,而是一种迭代开发方法,其中测试驱动功能的设计。
每个周期都从创建一组最终应通过该功能的单元测试开始(它们应该在首次执行时失败)。
此后,进行开发以使测试通过。再次执行测试,开始另一个循环,此过程一直持续到所有测试通过为止。
这样做的目的是基于这样的事实,即缺陷越早发现成本越低,从而加快了应用程序的开发。
行为驱动开发(BDD)
BDD还是基于上述TDD的迭代开发方法,其目的是让所有各方参与到应用程序的开发中。
每个周期都从开发一些需求开始(应该失败)。然后创建失败的单元测试(也应该失败),然后进行开发。
重复此循环,直到所有类型的测试通过。
为此就要使用领域特定的规范语言。各方都应该理解它,这种语言必须简单,标准和明确。大多数工具都使用Gherkin作为这种语言。
测试的目标是通过也针对潜在的接受错误,并使各方之间的通信更加顺畅,能够检测出比TDD甚至更多的错误。
当前有一组工具可用于编写规范并将其与代码功能(例如Cucumber或SpecFlow)匹配。
在Selenium之上构建了一组工具,可通过将BDD规范直接转换为可执行代码来使此过程更快。其中一些是JBehave,Capybara和Robot Framework。