【测试开发】概念篇
文章目录
- 【测试开发】概念篇
- 1. 什么是需求
- 1.1 需求的定义
- 1.2 为什么有需求
- 1.3 测试人员眼里的需求
- 1.4 如何深入了解需求
- 2. 什么是测试用例
- 2.1 为什么有测试用例
- 2.2 练习=>手机打电话
- 3. 什么是bug
- 4. 开发模型和测试模型
- 4.1 软件生命周期
- 4.2 开发模型
- 4.3 测试模型
- 4.3.1 敏捷中的测试
- 4.3.2 V模型
- 4.3.3 W模型(双V模型)
- 4.3.4 H模型
“想睡觉”,“不想上课”,“想吃饭”,这就是需求
而在互联网行业,什么是需求呢?
再例如一个软件需要有注册功能,注册这个笼统的就是用户需求,而其具体功能(输入姓名,邮箱,密码,确认密码,邮箱验证码,点击注册,是否同意协议,不同意会怎么样,输入不规范会怎么样…)这个详细的就是软件需求
我们开发一个产品,或者测试一个产品,要拿着这个软件需求进行测试/开发!
没有需求拿来目标,怎么实现目标?
而测试人员要将软件需求书里的每一个点,转化为一个个的测试点:
小练习:qq登录
- 账号
- 功能
- 账号密码正确,登录成功
- …
- 兼容
- 性能
- 安全
- 密码
- 登录按钮
- …
对测试点分类是必须要的!
在项目的需求评审会议上了解:
但在开始做项目时,我们可以查阅文档(会议记录/笔记、软件需求文档、技术文档)
沟通一下,找产品经理了解软件功能,找开发了解软件的实现
测试用例是一组集合,包含测试环境,测试数据,预期结果,操作步骤…
在工作中,常常将测试用例称为 CASE
测试用例可以提高的是人员的工作效率
测试用例可以降低测试人员工作的重复性问题
如果没有事先列举出测试用例,假设现在有两个人去测试一个功能:
- 大马自己去测试功能,质疑对方的能力,就把能测的都测了执行了,大概100条吧
- 小马也是,就把自己想到的都测了一遍,大概90条吧
这样就会出现,花费时间过长,并且两人测试重复性高的问题
所以,他们的领导要求他们写成测试用例,统计起来再去执行,大概一百条,一半给大马,一半给小马~
测试用例是建立自动化的基础,甚至是开发测试工具的基础
自动化就是把测试人员的双手解放,让代码代替人员执行测试,既然如此我们就要有测试用例的集合,让代码以这些测试用例进行测试
不严谨的说法:程序和规格说明书之间不匹配
准确的来说:当且仅当规格说明书存在的并且正确,程序与规格说明书之间的不匹配才是bug
当需求规格说明书没有提到的功能和没有考虑到的点,判断标准以最终用户为准:当程序没有实现其最终用户合理预期的功能要求时,就是bug
人的生命周期是:呱呱坠地 到 死亡
而软件的生命周期是:
需求分析(诞生)
计划
设计
编码
测试
运行维护
停服(死亡)
特定:线性的
优点:每个阶段做什么,产出什么非常清晰
缺点:风险往往迟至后期的测试阶段才显露,因此失去及时纠正的机会!
- 例如,需求分析出现问题,却在测试才被发现,一步步回溯到需求分析才发现问题,这样花费的时间、人力、精力也很大
适用的项目:
- 小型项目适用于此模型
特性:迭代的
优点:
- 每个阶段都会进行风险分析,避免一些线上问题发生
缺点:
- 可能迭代次数太多,项目迟迟无法上线
- 风险分析可能会分析错,请专家则人力和财力的投入
适用项目:
- 适用于比较大,风险比较多的项目
对于以下模块,略讲,以一个上课软件为例(登录,创建课程,上课)
敏捷宣言:
个体与交互重于过程和工具
- 个体之间面对面沟通
可用的软件重于完备的文档
开发文档,需求文档,更 关注最终的软件符不符合用户需求客户协作重于合同谈判
- 一份合同必然无法涵盖每个需求,所以要多与客户合作沟通,也就是客户协作
响应变化重于遵循计划
- 变化是特别常见的,而不是一昧追求计划,而是拥抱变化!
在每对比对中,后者并非全无价值,但我们更看重前者。
- 以上的对比,后者并不能摈弃,后者也很重要,而是更看重前者
三个角色:
- scrum由product owner(产品经理)、scrum master(项目经理)和team(研发团队)组成
其中:
- product owner负责整理user story(用户故事),定义其商业价值,对其进行排序,制定发布
计划,对产品负责。- scrum master 负责召开各种会议,协调项目,为研发团队服务。
- team 研发团队则由不同技能的成员组成,通过紧密协同,完成每一次迭代的目标,交付产品
- 后端开发,前端开发,UI设计师,测试工程师…
流程:
挑战1:轻文档
挑战2:快速迭代
- 测试工作的核心内客是没有变的,就是不断地找Bug,只是要调整好自己的心态,一切以敏捷的原则为主
- 测试人员不能依赖文档,测试用例作用减弱,更多的采用思维导图、探索性测试(强调自由度,设 计和执行同时执行,根据测试结果不断调整测试计划)、自动化测试
- 敏捷讲求合作,在敏捷项目组中,测试人员应该更主动点,多向开发人员了解需求、讨论设计、一 起研究Bug出现的原因。
特点:左边是开发,右边是测试,类似于瀑布模型(折了一下)
优点:测试被划分为许多类型
缺点:测试人员介入太晚,发现问题的时机太晚,故不适用于敏捷
特点:开发一个V,测试一个V
优点:测试人员在较早地介入了需求
缺点:
优点:
缺点:
总之,测试模型有三种,优缺点各不相同==建议一般的软件开发过程采用W模型,实施敏捷和迭代开发的可以考虑采用H模型。==
文章到此结束!谢谢观看
可以叫我 小马,我可能写的不好或者有错误,但是一起加油鸭!’希望枯燥的概念没有让你丧失对测试的兴趣!