专栏首页资深Tester你所不知道的软件测试七项原则

你所不知道的软件测试七项原则

前几天测试群有个小伙伴去鼎桥面试,回来分享时提到笔试题中有一道是软件测试的七项原则的题。

这是一道关于软件测试理论的题,大部分测试人员并不care软件测试理论,遵循理论无用论。

以前刚做软件测试时,确实并不关心软件测试理论,觉得只要能做就行,有技术就足够了,但到了后面却越来越重视理论了,这也是为什么目前公众号里理论的文章以测试理论为最多,这是估计是建立建全的软件测试思维与软件测试理论息息相关的原因吧。

在面试面谈过程中遇到软件测试理论的问题的并不多,但是在笔试中却经常遇到,比如什么是自动化测试?画出V模型,阿尔法测试和贝塔测试的区别等,这些是经常会碰到的,但关于问到软件测试的七项原则却是一个比较鲜少遇见的题。

那我们一起来数数软件测试的七项原则分别是什么:

01

测试尽早介入

从分析不同的测试模型来看,测试介入的越早越好。

为什么测试要尽早介入呢?

这要先弄清楚软件测试的目的是什么?简单的来说就是保证软件质量,降低成本。

测试人员一般都在需求阶段就开始介入,这时测试的对象就是需求。

软件测试的目的是保证质量,预防风险,降低成本,其中成本包括缺陷的修复成本,缺陷有一个特点就是越早发现的缺陷,修复成本越低,这也是为什么测试要尽早介入,就是为了能够在需求阶段就能找出需求与设计方面的缺陷,降低后期的修复成本。

02

穷尽测试是不可能

现在的软件规模越来越大,复杂度越来越高,想做到完全性的测试就完全不可能的。就是软件的规模和复杂度有所减少,但要做完全也测试也是不能做到。

那在测试阶段,软件测试人员可以根据风险和优先级来进行集中测试和高强度测试,从而保证软件的质量。

03

测试显示软件存在缺陷

软件测试只能证实软件中存在缺陷,但是并不能证明软件中不存在缺陷,只能降低软件存在缺陷的可能性。

如果说公司的决策层想通过软件测试来证明软件中不存在缺陷,那是行不通的。测试人员只能证明软件中存在缺陷,但并不能证明软件中没有缺陷,软件完美。

软件测试人员可以通过软件测试活动,找出软件中大部分缺陷,避免软件在上线后给用户带损失,给公司带来风险。

04

缺陷集群性(2/8原则)

世界上万事万物都符合二八原则,比如著名的财富理论:世界20%的人掌握了世界上80%的财富。

还有成长理论:判断一个人是否成功,主要看他20%的业余时间做什么事情。

软件测试也符合二八原则:

1.功能:一个软件20%为主要功能,会花费软件测试人员80%的时间。

2.缺陷:一个功能模块发现的缺陷越高,那存在的未被发现的缺陷也越高,故,发现的缺陷与未发现的缺陷成正比。

05

杀虫剂悖论

只要做过软件测试的测试人员都会发现一个有趣的现象:

开发刚转测当天,测试人员是一个bug接一个bug的提,但随着测试进度的推进,每天发现在的缺陷会越来越少,到最后简直就是不能够发现缺陷了。

但是能说这个软件中不存在缺陷么?王豆豆相信哪个测试人员都没有这样的自信保证自己测试的软件中没有bug了,那为什么存在中明明不存在缺陷,而测试人员就是发现不了呢?

这是因为测试人员对缺陷产生了免疫能力,就算是一个bug放在测试人员面前,测试人员也不一定能发现。这就像害虫对杀虫剂产生了免疫,杀不死一样的。

那应该怎么解决这个问题呢?王豆豆相信这是所有测试人员都关注的一个问题。

解决方案有:

1. 内部测试人员交叉测试,这也是王豆豆经常提到的一个方法。

2.测试用例常用常更新,在测试过程中根据软件的特性修改测试用例。

3.不变地变化测试方法,不要使用单一的测试方法去测试软件,根据软件内容使用不同的测试手段、测试方法。

根据上面三种方法交叉执行,从而发现更多的缺陷,保证软件质量,降低风险。

06

测试活动依赖于测试内容

在面试过程中有时总会遇到面试官部“做软件测试什么最重要”,想来做过测试的都知道“需求”最重要,对测试人员来说是需求,对公司来说就是业务。

根据业务的不同,软件测试内部也分不同的行业,比如游戏行业,金融行业,电商行业等等。

不同的行业,测试活动的开展都有所有不同,比如工具的选择,测试流程都不尽相同,所以软件测试活动的开展依赖于所测试的内容。

07

无错就是好是谬论

无错,对软件测试人员来说可望不可即的。

那真的无错的软件就是好的软件么?

假设一个软件完全没有bug,完美无缺,但是不符合用户的需求,那能说这个软件是OK的么?

判断一个软件的好与不好,主要依据的还是用户需求,是否实现用户所期盼的结果,并不是仅仅依赖于软件中是否存在缺陷。

本文分享自微信公众号 - 资深Tester(zishentester),作者:王豆豆

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2017-12-01

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 软件测试职业发展:软件测试人员该何去何从

    王豆豆
  • 从做蛋黄酥谈测试思维

    王豆豆
  • 软件测试人员每天的工作日常

    王豆豆
  • 解析《中国互联网软件测试行业2018年度调研报告》

    之前收到了一份TesterHome的调查问卷邀请:2018年度中国测试行业问卷调研。最近问卷的汇总结果出来了,有2000+的测试童鞋参与了问卷调查。从幸存者偏差...

    写博客的老张
  • 选择手动测试还是自动化测试?

    在软件测试行业中,争议最大的话题是“更好的是手动测试还是自动化测试”。尽管自动化测试最常谈论流行语,并且正在慢慢主导测试领域,手动测试的重要性不可忽视。

    八音弦
  • 安全基线,让合规更直观

    10月7日,爱尔兰数据保护委员会(Data Protection Commission)的一名发言人周一表示,该机构已经结束了针对Facebook旗下Whats...

    FB客服
  • 有关测试流程中的问题

    最近在带一个学生,是一个超级认真、努力的学生,布置的作业和学习点都会认真去完成,我能感受到他是在尽心尽力地去做好,从提出的问题中就能看到这个变化,由以前的很外行...

    王豆豆
  • 如何通过缺陷分析来改进软件工程?

    “项目结束后的总结工作中,是否对bug做过详细的总结和分析呢?如果有,是怎么做的呢?”

    张树臣
  • 手动测试存在的重要原因

    在移动应用测试方面,手动测试是不可避免的。在这个快速数字化转型的时代,移动应用程序已成为最有利的商业模式。不断变化的情景也影响了测试空间。在可能的情况下应用自动...

    八音弦
  • 测试人员常用借口

    无论我们试图建立一个网站多么完美,我们都一定会犯一些错误。错误是不可避免的,无论多么微小。这就是为什么我们不能保证没有错误的发布,甚至在进行了不同类型的全面测试...

    八音弦

扫码关注云+社区

领取腾讯云代金券