一、软件测试基本概念(什么是软件测试,软件测试的目的、目标、原则、质量、度量)
术语:
缺陷(bug)、缺陷(defect)、 错误(error)、失效(failure)、 故障(fault)、错误(mistake)、 质量(quality)、风险(risk)、 软件(software)、测试(testing)。
A.bug 程序缺陷 电脑系统或者程序中存在的任何一种破坏正常运转能力的问题或者缺陷,都可以叫做 “bug”,有时也被泛指因软件产品内部的缺陷引起的软件产品最终运行时和预期属性的偏离。
B.defect 缺陷 既指静态存在于软件工作产品(文档、代码)中的错误,也指软件运行时由于这些错误被激发引起的和软件产品预期属性的偏离现象。
C.error 错误 指编写错误的代码,一种语法错误(syntax error),另一种是逻辑错误(logic error)。
D.fault 故障 软件运行中出现的状态,可引起意外情况,若不加处理,可产生实效,是一个动态行为。
E.failure 失效 软件运行时产生的外部异常行为结果,表现与用户需求不一致,功能能力终止,用户无法完成所需要的应用。
代码(code)、调试(debugging)、(软件)开发(development)、需求(requirement)、评审(review)、测试依据(test basis)、测试用例(test case)、测试(testing)、测试目标(test objectives)。
一、软件测试基本概念
1.什么是软件测试
(1)广义的概念:指软件生存周期中所有的检查、评审和确认工作,其中包括了对分析、设计阶段,以及完成开发后维护阶段的各类文档、代码的审查和确认;
(2)狭义概念:识别软件缺陷的过程,即实际结果与预期结果的不一致;
(3)软件测试通常包括验证(verification)和确认(validation):
验证指保证软件正确的实现了某一特定功能的一系列活动;
确认指的是保证软件的实现满足了用户需求的一系列活动;
2.软件测试的目的
(1)测试的目的就是发现软件中的各种缺陷;
(2)测试只能证明软件存在缺陷,不能证明软件不存在缺陷;
(3)测试可以使软件中缺陷降低到一定程度,而不是彻底消灭;
(4)以较少的用例、时间和人力找出软件中的各种错误和缺陷,以确保软件的质量;
3.测试的目标
(1)最终目的是确保软件的功能符合用户的需求,把尽可能多的问题在发布或交付前发现并改正:
确保软件完成了它所承诺或公布的功能;
确保软件满足性能的要求;
确保软件是健壮的和适应用户环境的;
(2)为软件的质量评估提供依据;
(3)为软件质量改进和管理提供帮助;
4.软件测试的原则
(1)Good-enough: 一种权衡投入/产出比的原则;
(2)保证测试的覆盖程度,但穷举测试是不可能的;
(3)所有的测试都应追溯到用户需求;
(4)越早测试越好,测试过程与开发过程应是相结合的;
(5)测试的规模由小而大,从单元测试到系统测试;
(6)为了尽可能地发现错误,应该由独立的第三方来测试;
(7)不能为了便于测试擅自修改程序;
(8)既应该测试软件该做什么也应该测试软件不该做什么;
5.软件测试的质量
(1)软件测试可以发现以下软件缺陷:
软件实现的功能不正确(发现第一类软件缺陷的过程 --“验证”);
“缺少”:软件没有实现某项功能(发现后两类软件缺陷的过程 --“确认”);
“多余”,软件实现的某项功能在需求中没有定义(发现后两类软件缺陷的过程 --“确认”);
(2)软件测试本身的质量在于:
发现软件缺陷并能区分其类型;
提供关于软件质量和开发过程质量的信息;
6.软件测试的度量
(1)测试覆盖率:有多少需求、代码已经被测试了;
(2)缺陷发现率:缺陷是何时被发现,并且有多少缺陷已经被发现。缺陷可以根据严重性来分类。需记录:缺陷数目、缺陷的严重性;
(3)测试成功率:有多少测试已经通过了,并且有多少是运行正常的?需记录:已通过的测试用例的数目、可利用的测试用例的数目;
7.在软件开发、维护和运行中测试的角色?
(1)对软件系统和文档进行严格的测试,可以减少软件系统在运行环境中的风险,假如在软件正式发布之前发现和修正了缺陷,就可以提高软件系统的质量。
(2)进行软件测试也可能是为了满足合同和法律法规的需求,或者是为了满足行业标准。
8.测试的作用(测试是否充分)
(1)在判断测试是否足够时,需要考虑下面的因素:风险(包括技术风险、商业产品风险和项目的风险等)以及项目在时间和预算上的限制等。
(2)测试需要给利益相关者提供足够的信息,帮助他们决定是否发布被测的软件或系统,是否继续进行下阶段的开发或直接将产品交给用户。
9.测试和质量
(1)通过测试,就可能发现软件系统在功能(functional)和非功能(non-functional)需求方面的缺陷,对软件质量(software quality)进行评判。
非功能需求包括:可靠性(reliability)、可用性(usability)、效率(efficiency)和可维护性(maintainability)等方面。
(2)当测试发现很少或者没有发现缺陷的时候,就会对软件的质量充满信心。一个设计正确、合理的测试过程完成并顺利通过,可以降低整个系统存在问题的风险。而对测试过程中发现的缺陷进行了修正,则软件系统的质量就会提高。
(3)我们应该从以前的项目中总结经验教训。通过分析在其他项目中发现的缺陷和引起缺陷的根本原因,我们就可以改进测试过程(process)。相继地,过程的改进又可以预防相同的缺陷再次发生,从而提高以后系统的质量。
(4)测试应该作为质量保证的一个不可或缺的一部分。
10.调试和测试
调试和测试是两个不同的概念。
测试可以发现由于软件存在的缺陷引起的失效。
而调试是一种开发活动,用来识别引起缺陷的原因,修改代码以及验证是否正确的修改了软件的缺陷。
随后由测试员进行的确认测试(confirmation testing)是为了确认修改的代码已经解决了失效问题。
每个活动的职责是截然不同的,即测试员进行测试,开发人员进行调试。
-------------------分割线
不知不觉毕业都好几年了,也一直从事测试这个岗位,感觉测试的一些基础知识其实对日常工作还是很有帮助的,整理一下以前在学校做的笔记,记录一下...
本文来自博客园,作者:可乐要加冰啊,转载请注明原文链接:https://www.cnblogs.com/zhuo-90/p/16534972.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix