5. 测试用例与测试类型以及测试深度

Paste_Image.png
上图是一个一般的执行流程,下面会介绍一下每个测试执行的侧重点,用例选取参考方式。5.1 准入测试用例
准入测试用例,面向于最基本功能的验证,检验主要的功能分支,无特殊输入输出,无特殊中断交互,无高压,无兼容性,用例的覆盖面向于该用例的fail不会引起较多的用例被block。
书写方式上,用例相比系统级测试用例,撰写内容经过抽象,单条用例的覆盖面高于一般的系统测试用例。面向于功能的检查,而暂时忽略展现的检查。
这部分用例,需要QA在RD提测前一周左右,提交到icafe并发起审核,RD和PM需要确认该用例的合理性以及完整性。
准入测试出了准入测试用例还有另外一部分称之为“其他约束条件”。在测试执行时,测试对版本的需求会一轮高过一轮,准入的条件也会在准入用例基础上层层叠加。如:在执行网络兼容性测试前,需要增加各个接入点都可以访问得到数据的约束;对于稳定性测试前,比如android会先约束per-monkey的时间超过某个值,如半小时;对于sprint迭代的版本,要约束前一sprint的bug修复率;对于最终版本整体体测前,需要约束所有的bug修复,检验未修复的直接打回。
5.2 系统测试用例
5.3 Bug验证测试用例
5.4 基本功能回归测试用例
基本功能回归测试,内容上无边界检验,无特殊中断交互,无压力测试。和准入测试用例的覆盖类型相当,用例为系统测试的一部分,通常为标记各个功能点下basic的测试内容,然后适当选取强关联的中断,比如热插拔SD之于音乐播放器。
5.5 功能+bug回归测试用例
下表为几种测试用例的要素整理:
| 类型 | 覆盖范围 | 用例规模 | 特点 |
|---|---|---|---|
| SNT-SmokeTest | 最基本功能的验证,无特殊输入输出,无特殊中断交互,无高压,无兼容性 | 大约为系统级测试用例的10-15% | 用例相比系统级测试用例,撰写内容经过抽象,单条用例的覆盖面高于一般的系统测试用例 |
| ST | 全面的,完整的测试用例 | 视app的规模, | 用例撰写详细,全面,细致点出检查点 |
| DVT | 面向已经修复的bug,检验其是否修复,有无side effect | 无测试用例 | 参考内容为bug report |
| RGT | 基本功能测试,无边界检验,无特殊中断交互,无压力测试 | 大约为系统级测试用例的25-35% | 和准入测试用例的覆盖类型相当,用例为系统测试的一部分, |
| RGDVT | 接近于RGT+DVT,但这里的DVT不是本轮次的bug,而是标记在测试用例执行中,被标记出现过bug的用例 | 用例规模的40-50% | 在RGT的基础上,验收版本曾发生过的问题的用例 |
| 类型 | 覆盖范围 | 用例规模 |
|---|---|---|
| 平台兼容性测试 | 面向于平台适配,用例范围一般为RGTC | 大约为系统级测试用例的10-15% |
| 分辨率兼容性测试 | 面向于分辨率适配,用例范围一般为RGTC,确保个页面展现 | 大约为系统级测试用例的10-15% |
| 网络兼容性测试 | 面向于网络接口适配,用例范围一般为RGTC,确保个接口的覆盖 | 大约为系统级测试用例的10-15% |

Paste_Image.png
6. 测试用例和bug提交的关系
6.1 如何书写bug report
当前提交bug的内容大概包含一些几个方面;
- Title,就是bug的简单描述,用一句话大概描述清楚问题是什么。
- 复现步骤,是我们能将bug复现的操作路径。操作路径要求简明清晰,并且尽量找到最短、最必然的复现路径。
- 正确的操作后预期,一般写明按照以上的操作步骤之后,应该看到的现象应该是如何的。
- 当前问题的操作结果,一般写明当前的操作导致了那些不能接受的后果。
- 附件,一般是错误产生时候的系统log以及不方便描述时上传的图片或者视频等,方便RD同仁debug。
- Add 1—在移动产品测试部分,我们应该加入问题发生时使用的手机平台版本、型号以及相关的网络环境等等。
- Add2—写清楚该问题被复现的概率有多大,比如2-20,表示我复现了20次,我能复现两次该问题。
· Add3—note,一些关于修改的建议,或者该问题可能导致的更多问题
· Add4—基于前两条,在验证bug是,一定标记验证使用的手机型号、版本相关的网络环境,复现多少次而判定通过的
我们可能面临一个问题就是,在起初发现的一个问题,在当时也许所有的平台上都会发现,但是在验证时却是该问题在某一只收集上解掉了。但是在另外一只手机上,过段日子你用的时候,发现又有这个问题。因为我们却是有比较小的可能,不同的平台版本上,有的函数高版本有,低版本没有;有的函数不同版本用法有差异。虽然都是小概率时间,但是我们的标记非常有利于将来定位问题。
【建议模板】
【问题描述】“一句话总结一些问题”
【手机版本】Galaxy S7 (android 7.0)+ CU4G
【初始化条件】“bug复现必要准备的动作”
【复现频率】X-Y
【复现步骤】
1st
2nd
3rd
【预期结果】
【实际问题】
【note】
这么写bug会不会太累了,尤其我们一天有时候一下提报十多个bug,这时候我们可以制作一个模板,具体模板创建方式见下文。而对那些诸如MRD不符的bug,你知道他化成灰也在那里,建议的模板也不必拘泥于形式。
参考范本:

Paste_Image.png

Paste_Image.png
【附件的使用】在提交bug时,难免越到一些不太方便描述的问题,或者容易描述,但是不容易第一时间定位问题的位置。附件的内容:
Crash log,crash有些时候作为非必然复现的问题,一定要记得添加log到附件中
截图,视频,容易提示问题的症结点,另外一些不好描述的操作,可以通过视频清晰展现。
如图:如果我的描述单纯是告诉RD,播放的icon未能同步,你觉得不看图能一下子就定位问题吗?

Paste_Image.png
【更多想法】向RD发出request,
· Add1—在RD修复bug是写明root cause,就是写明该问题发生的原因。QA的职责在于发现问题,进而定位问题,最终是给出修改意见。透过现象看本质,不同的复现步骤导致的问题可能源于相同的问题,相同复现步骤以及相同的表象也可能源于不同错误。所有向RD了解问题的症结点是我们能快速提高经验,并在以后的测试中强化问题定位能力的不错办法。
· Add2—在RD修复bug时写明解决方案,在1的基础上写明如何解决该问题。写明解决方案的好处不只是在于能了解某些症结点如何被修复、回避,也能逐渐思考该解决办法是不是可能导致 side effect而导致其他问题。
以上两点,有些习惯好的RD是会写在note里的。但是明显人总是会懒惰的,更多的RD并没有写,这方面出了能期望他们写好note外。我们也可以抽出来一些时间和RD坐下来一起review bug,不但RD能在沟通中减少对bug的误解,也能让QA参与到bug修复的讨论中,从而获益。
6.2 如何映射bug到测试用例
先验到后验的转型。书写测试用例,或者执行测试之前,我们的每一条用例都会认为是等概率的认为,可以发现问题。但是在一定的执行经验积累后,我们会倾向于认为,某些特定的功能容易发生问题,这部分对应的用例也就成了我们有限去执行测试的对象。
这个适用于相同类型的产品或者不同产品但是其中相同的模块间,以往发生的问题仍旧有较大的风险发生在当前的项目上。
6.3 如何利用bug强化用例
测试工作中,我们应该执行一个 case撰写—>case评审—>case执行—>bug review-->强化测试用例—>case评审—>case执行的循环过程。随着不停的case迭代,覆盖度会越来越高,迭代周期也会变长,越来越有保障。
基于ad hoc
Ad hoc的发起一般是认为case有疏漏的,或者case无法描述的。所以ad hoc之后,要根据执行的ad hoc test补充测试用例。注意不单单是那些发现了bug的测项,我们要根据bug report反馈去添加到测试用例中,那些没有发现bug的case,我们也要做梳理。因为相同的测试内容,此次没有问题,不代表以后的改动不会影响到他。
基于用户体验
用户体验章节,我们已经简单描述过,可以将内测用户作为小白鼠帮忙实现某些低概率问题的测试覆盖。另外用户体验时候又会反馈一些我们想不到的内容。所以这部分我们会分为两部分工作,第一控制用户体验(升华内容,试验阶段),第二用户问题转化测试用例。
第一部分,我们可以以用例的方式,一开始就准备相应的用例,作为督促用户实现检验覆盖
第二部分,用户的反馈会有两部分,bug和建议,bug看是否为遗漏,遗漏的内容需要做case补充,如果是建议且被采纳,相应的功能调整也需要修缮测试用例。
7. 测试用例技巧
7.1 测试用例复用
7.2 通用测试用例
不过切记,通用测试用例是经过抽象的用例,而且也只是公共模块中相对通用的测试内容,所以需要我们摘除不需要的部分,添加自身特制的部分,并将其丰富化。
7.3 RGDVT
7.4 BO2
7.5 思考方式(公式化书写)
供思路提炼的公式:一个aa的MRD需求,(按bb条件为前提),(在cc平台上)通过dd的手段支持用户以(ee的方式)实现ff功能,(最终以gg的方式展现在用户面前)
一个曲目切换的MRD需求,以该平台支持BTAVRCP为前提,在android+BT2.1 EDR平台上,通过蓝牙耳机接入方式支持用户以点击按键的方式实现切歌功能,最终以beep提示音和页面水平平滑跳转的方式展现在用户面前。
切记:此公式并非要大家直接套用,书写累赘的测试用例,而是要提炼大家的思路。比如:
需求aa:切换曲目
按bb条件为前提:针对蓝牙这样的方式需要支持BTAVRCP,如果是手势切换,可能要考虑Gsensor
在cc平台上:同样的需求,当前在android上测试,同样为将来移植到ios而准备
通过dd的手段:蓝牙耳机是一种线控方式,也许还可以支持蓝牙遥控器等
已ee的方式:按键是一种方式,也许还可以声控
实现ff功能:切歌也分多种状况,播放中切换,暂停时切换,快进快退时切换
gg的方式展现:提示音也许可有可无,但是MRD需要给定义,亦或者是mrd其他的方式展现给用户。
