- 专注于分享软件测试干货内容,欢迎点赞 收藏 ⭐留言 如有错误敬请指正!
- 软件测试面试题分享: 1000道软件测试面试题及答案
- 软件测试实战项目分享: 纯接口项目-完整接口文档
- 软件测试实战项目分享:WEB 测试自动化项目实战
- 软件测试学习教程推荐:火遍全网的《软件测试》教程
在产品项目的最后推进过程中,会经过一系列的测试来判断以及优化产品,在测试中使产品的属性特征最优化,最终达到吸引更多客户的目的;本文作者分享了三种软件测试的主流方式,我们一起来了解一下。
在产品概念阶段,开展“电梯测试”是为了确定定位策略,将产品特征转化成显著的客户利益;在产品设计阶段,只有产品模型,测试目的是如果使产品的属性特征最优化,从而更吸引客户。
当产品最终完成但还没有引入市场时,实施产品测试是为了控制产品质量,维持产品生命。在产品正式上市前进行小范围的市场测试,目的在于识别竞争对手的实力和弱势(如果产品有做进一步改进的潜力的话,还可进行改进测试),确定产品在目标市场中的位置。
产品测试的目的随着被测试产品的发展或生命周期的不同阶段而不同,决定采用哪种测试研究方式是建立在研究的目的之上的,所以并没有一种测试可以称得上是最好的。
阿尔法α(Alpha)、贝塔β(Beta)、伽马λ(Gamma)测试常用来表示软件测试过程中的三个阶段,用于在开发流程中和上市前夕测试新产品:
α是第一阶段,一般只供内部测试使用;
β是第二个阶段,已经消除了软件中大部分的不完善之处,但仍有可能还存在缺陷和漏洞,一般只提供给特定的用户群来测试使用;
λ是第三个阶段,此时产品已经相当成熟,只需在个别地方再做进一步的优化处理即可上市发行。
由于样本选择缺乏统计基础,这种市场研究方式不提供具体的统计置信度,即这种方式不是严格意义上的定量分析,但它确实能够提供客户在使用产品后的详细反馈;此处,客户面对的是最终产品,或非常接近最终形态和功能的产品,测试有助于对产品进行验证和改进修正。
以下为大家详加介绍阿尔法、贝塔、伽马和试销主流测试方式:
阿尔法测试类似于可用性测试(在软件领域称之为软件测试),通常由内部测试人员完成;在极为少见的情况下,阿尔法测试是由客户过外部人员完成的,阿尔法测试发布的版本被称之为阿尔法版本(在软件领域常被称之为DAT开发测试[张乐飞1] 环境应用)。
阿尔法测试是由一个用户在开发环境下进行的测试,也可以是公司内部的用户在模拟实际操作环境下进行的受控测试,试图发现错误并修正,阿尔法测试由程序员或测试员完成。
阿尔法测试的关键在于——尽可能逼真地模拟实际运行环境和用户对软件产品的操作,并尽最大努力涵盖所有可能的用户操作方式。
阿尔法测试的目的是评价软件产品的FLURPS(即功能、局域化、可用性、可靠性、性能和支持),尤其注重产品的界面和特色。
阿尔法测试可以从软件产品编码结束之时开始,或在模块(子系统)测试完成之后开始,也可以在确认测试过程中产品达到一定的稳定和可靠程度之后再开始,有关的“测试用例”应该在阿尔法测试前准备。
软件测试是在软件交付用户使用或投入运行前,对软件需求规格说明、设计规格说明和编码的最终复审,是软件质量保证的关键步骤,软件测试是为了发现错误而执行程序的过程。
软件测试在软件生命周期中横跨两个阶段:通常在编写出每一个模块之后就需要对它做必要的测试(称为单元测试),编码和单元测试属于软件生命周期中的同一个阶段;在结束这个阶段后对软件系统还要进行各种综合测试,如集成测试、系统测试、性能测试和配置测试等,这是软件生命周期的另一个独立阶段,即测试阶段。
只有当阿尔法测试达到一定的可靠程度时,才能开始贝塔测试,阿尔法测试即为非正式验收测试,经过Alpha测试调整的软件产品称为贝塔版本。
贝塔测试是一种验收测试,所谓验收测试是软件产品完成了功能测试和系统测试之后,在产品发布之前所进行的软件测试活动,它是技术测试的最后一个阶段。
通过了验收测试,产品就会进入发布阶段,贝塔测试后发布的版本被称为贝塔版本(在一些企业称之为UAT用户测试[张乐飞2] 环境应用);可以说,贝塔测试是“预发布测试”。
软件的贝塔测试版本将会被在网上发布,提供给广大用户,从而使该程序进人“真实世界”测试,并为下一个发布版本提供部分预览。贝塔测试的主要目的在于,获得不同客户群体的反馈以及检查在不同类型的网络和硬件下产品的兼容性。
贝塔测试由软件的最终用户们在一个或多个客户场所进行。与阿尔法测试不同,开发者通常不在贝塔测试的现场,因贝塔测试是软件在开发者不能控制的环境中的“真实”应用。
用户贝塔测试过程中遇到的一切问题(真实在或想像的),并且定期把这些问题报告给开发者。接收到在贝塔测试期间报告的问题之后,开发者对软件产品进行必要的修改,并准备向全体客户发布最终的软件产品。
在B2B环境中,贝塔测试通常包含以下4个方面。
确定一小群“种子”客户,这群客户常被称为领先客户或领先用户。
构建一个测试计划,并确定产品开发、市场营销、销售和产品管理中的关键角色和职责。测试计划要包含试验的持续时间和试验后处置结果。
客户与产品公司之间的合同包含项目计划,以便客户能明白目标、持续时间和延期补偿。另外,保密条款也应该包括在内。
客户应该了解要测试什么及如何反馈结果。团队需要确保能收集客户数据,能组织任何最后的访谈,并能把产品带回实验室。
验收测试要通过一系列黑盒测试。验收测试一般根据产品规格说明书严格检查产品,逐行逐字地对照说明书上对软件产品所做出的各方面要求, 确保所开发的软件产品符合用户的各项要求。
通过综合测试之后,软件已完全组装起来,接口方面的错误也已排除,软件测试的最后一步——验收测试即可开始;验收测试应检查软件能否按合同要求进行工作,即是否满足软件需求说明书中的确认标准。
验收测试同样需要制定测试计划和过程,测试计划应规定测试的种类和测试进度,测试过程则定义一些特殊的测试用例,旨在说明软件与需求是否一致。
无论是计划还是过程,都应该着重考虑软件是否满足合同规定的所有功能和性能,文档资料是否完整、准确人机界面和其他方面(例如,可移植性、兼容性、错误恢复能力和可维护性等)是否令用户满意。
验收测试的结果有两种可能,一种是功能和性能指标满足软件需求说明的要求,用户可以接受;另一种是软件不满足软件需求说明的要求,用户无法接受。项目进行到这个阶段才发现严重错误和偏差一般很难在预定的工期内改正,因此必须与用户协商,寻求一个妥善解决问题的方法。
大型通用软件在正式发布前,通常需要执行Alpha和Beta测试,目的是从实际终端用户的使用角度,对软件的功能和性能进行测试,以发现可能只有最终用户才能发现的错误。
伽马测试是终级测试,测试之后,该软件几乎就是上市的最终版本了;此时,不再进行软件的功能开发或改进。
在这一阶段唯一可能修改的是限定范围内的代码错误,当该软件已经准备好发布且能够满足各类要求后,就开始进行伽马测试,测试时无须进行其他任何内部测试。
除了在开发周期时间极短、上市速度要求极快的高压情境下(由于伽马测试并不常见,因此在此不做太多赘述)。
最后我邀请你进入我们的【软件测试学习交流群:785128166】, 大家可以一起探讨交流软件测试,共同学习软件测试技术、面试等软件测试方方面面,还会有免费直播课,收获更多测试技巧,我们一起进阶Python自动化测试/测试开发,走向高薪之路
作为一个软件测试的过来人,我想尽自己最大的努力,帮助每一个伙伴都能顺利找到工作。所以我整理了下面这份资源,现在免费分享给大家,有需要的小伙伴可以关注【公众号:程序员二黑】自提!