通用技术 测试的一些误区

扫地僧 · 2016年10月23日 · 最后由 hr 回复于 2016年10月26日 · 3438 次阅读

我相信认真看过社区内帖子和回帖的测试行家心里知道,目前还存在很多同行,对业务测试也好,自动化测试也好,都可能存在一些认知上的误区,而且这种误区会像病毒一样传播,我觉得作为一名热爱测试的人,有责任站出来普及一些常识性误区。

关于 QA 和 QC 的区别

现实情况有很多人会把 QC 也理解成 QA,我人微言轻就直接引用网上的定义:Quality Assurance vs. Quality Control。可能接触过 CMMI 的同行对两者的区别有更深的体会。我的理解是:QA 是整个软件生产过程的执法者,对整个过程的质量体系负责,偏管理但又必须懂技术;QC 是为检验产品而实施的具体的产品测试活动,包括业务测试、自动化测试等。
为了更容易理解,举个例子:一家生产精密仪器的制造商,制定了一套确保生产质量的流程规范,各个生产、装配环节必须严格遵守,确保这个流程规范按既定执行的角色就是 QA。还是以这个例子为例,流水线最后精密仪器制造出来了,要有人去检验其是否能按设计标准正常工作,这个角色就是 QC。

自动化的目的是什么

我看到一些回帖在解答提问者疑惑时竟然多次提到 “自动化测试的目的不是为了发现 Bug”,他们可能也是受到了一些加精文章的影响。其实,仔细想想,这个概念是不值得推敲的,自动化测试是执行测试的一种手段,那测试的目的是什么?也许我的理解还不够到位,但至少包括以下几点:

  • 把测试从枯燥的重复劳动中解放出来,例如:回归测试等;
  • 协助手工测试完成很难模拟或无法模拟的的工作,例如:篡改服务返回的数据验证前端对各种数据场景的处理,弱网模拟、特殊协议数据包解析验证等;
  • 尽早发现 Bug,例如:数据层的存储过程、Package 批量调用验证、接口自动化等偏底层的问题;
  • 协助定位问题,现在的自动化提出了更高的要求,例如:接口层发现问题了,可以通过添加的 traceID 定位到日志错误或错误代码行,app 运行中异常可捕获错误日志等;
  • 线上监控报警,现在的自动化不仅限于线下,线上的也已覆盖,测试和运维的工作可能存在交集,我们不能把质量问题寄托于他人,一旦发现问题,让损失到最小。
  • 提高工作效率,这个面有点广,例如,测试环境的自动化编译、打包、部署、持续集成甚至持续交付等

关于测试用例的理解

我在一篇文章中看到,把测试用例设计定为初级阶段,这绝对是技术至上的一种偏见和对测试用例的一种无知。敏捷可能对测试用例有弱化,但这和测试用例设计属于何种阶段是两码事,在传统企业,测试用例的设计好坏会直接关系到产品质量。即便是敏捷也会有简化的测试用例,其设计好坏也直接影响到测试盲区。所以说,测试用例设计的质量好坏,直接能反映出设计者的测试功底、技术功底、测试经验。

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
共收到 62 条回复 时间 点赞

测试用例是测试工作的基石。好的测试用例,会让整个项目组都松一口气。

#1 楼 @Lihuazhang 对于腾讯 WeTest 发文的严谨性表示怀疑,这是要坑害多少人

#2 楼 @quqing 可以在帖子里直接提出来。

我认为对于公司来说不一定要严格区分 QA 和 QC ,但用例 确实是测试的关键,不过现在用例的尴尬在于到底是写出指导思想 还是精细到 可以移交给第三方执行。

#4 楼 @dongdong 初期,我们公司在评审测试用例的时候,一律要求精细到可以移交给第三方执行。两年过去了,公司就不管了,说能不重不漏即可

@quqing 为啥要喷 WeTest 呢?我倒是觉得 wetest 还有些深度。。。
个人觉得测试用例设计完全看人,但技术门槛确实不高,大部分互联网公司也没那么多精力养那么多人去死抠质量,简单问题线上修复。。。

#4 楼 @dongdong 如果有条件,可以把 QA 和 QC 的活都干了,这是组织架构的设计问题。但作为一篇广而告之的技术文章,两者概念不能混淆。我想表达的是做测试需要有严谨的态度,弄清楚两者的区别而已。

#6 楼 @yangchengtest 你也说了是大部分互联网公司,能代表全部互联网公司吗,能代表整个行业吗?我表达方式比较直接,请包涵。

#3 楼 @Lihuazhang http://wetest.qq.com/lab/view/169.html,表面上看是给社区做软广,长远来看,可能会起到相反的效果。

#4 楼 @dongdong 完全不用写到交给第三方执行的,还不如直接测试外包呢。我是没见过写用例和执行用例的人是 2 个,基本都是 1 个人,我觉得更多是一个思路的提现和提醒的作用。

#7 楼 @quqing 确实 QA 和 QC 的概念现在很模糊了,有必要做个提醒。

我比较认同最后的观点,不管是何种研发流程,测试用例设计的好与坏,不仅仅体现了测试团队的可靠度,专业性,以及测试结果的可信度。不论是传统企业也好,互联网企业也罢,测试用例是最基本的保障,虽然互联网野蛮式的奔跑让测试在各个环节变得越来越被动,但是每个测试同行都应该保留和坚持自己的底线,用例设计要用心、严谨、可靠,该 review 的要 review,该弄清楚的必须弄清楚,这不仅仅是基本功,还是一份职业操守和对质量的坚守。

#9 楼 @quqing @ycwdaaaa 的文章。。高飞来辩论了。

我的理解是随着企业对效率的要求. 负责质量的部门不会太多. 可以 QA QC 或者测试都会逐渐合并为一个部门. 加强沟通.

自动化测试不是用来发现 bug, 这个是行业一直以来的误区, 你提出来很好. 自动化测试的价值被低估. 大多是因为行业里面的人没有用好而已. 举个极端的例子. 有的产品是无法手工操作的, 必须写自动化用例. 所以 bug 也全是自动化发现的. 对于用户端的产品, 技术也会逐渐突破到能发挥更大的价值.

测试用例和自动化不冲突. 写自动化本身也是测试用例. 区分下就是用例设计是基础, 在此之上, 可以人工可以自动化.也可以大数据对比分析.

#13 楼 @Lihuazhang 有些东西我不想明说,但既然你都艾特我了,我觉得我还是来给你讲讲我跟这位仁兄的恩怨。要说我俩的恩怨可以追溯到我刚来 tester home 的时候了,那是我测试开发之路的第一篇帖子,那时候这位仁兄就因为我的帖子上来引战。然后前几天我们在一个技术贴的讨论上他又开始了嘲讽模式,那一次我没忍住,跟他吵了起来,现在他是专门来再一次开贴引战了。 别的不多说,我上几个截图。




我和这位仁兄的恩怨

还有很多的记录我不发了,这位仁兄最近专门挑我写过的帖子找事。 你可以看到留言根本没说我为什么错了。只是没有任何营养的来那么很装逼的一句:你丫的错了。每一次我都懒得理他,只是他不停在找事而已。自动上次我俩吵完以后,我便本着老死不相往来的态度来对待这个人,你发你的贴,我更我的文章。井水不犯河水。 所以在我俩有这么大仇怨的前提下,又是这么带有个人针对性帖子,我真的是懒得理。如果大家真把这篇帖子当成纯粹的技术讨论那我也没办法。你也看到我第一张截图上的聊天记录了,不只我一个人觉得他卖弄文字游戏。上一次我俩吵是因为他强调修改和劫持的问题,指责我不严谨。 呵呵,所以这篇文章一出来你可以看到,又是一个文字游戏大战。说起 QA 和 QC 的区别来了, 随便找了个国外大牛的文章来佐证他的观点。这个东西怎么说吧,我给你举个例子,在瑞典加班是犯法的,我如果引用瑞典人的说法是不是咱们中国所有公司都在犯法?我心里是呵呵的。 在国外的某些软件公司环境下 QA 和 QC 是这么定义的,所以不理中国国情把他生搬硬套到国内来,我心里更是呵呵的。大家可以扪心自问一下你们见过几家公司是这么区分 QA 和 QC 的,甚至会真正区分 QA 和 QC 的。如果你的老板让你做一件事,你说那是 QC 干的,我不干,你说你是不是疯了。随便在书里网上看一些理论知识,根本没怎么实践过就强行拿出来分享并让他人按你的理念实行的做法我是真醉了。

关于自动化的目的

此仁兄的文字游戏功底之强悍我叹为观止。引用我文章中自动化的目的不是为了发现 bug 这半句话,决然不提后半句。 我后半句写的明明白白,为了节省人力,节省资源,节省成本。可这位仁兄半字不提,断章取义。然后又引入到自己的节奏去了,我心里是呵呵呵呵呵呵呵的。我觉得大家还是看看我原来文章比较好,不要被人误导

关于测试用例是初级阶段

这明显又是一个断章取义。我只在文章开头的第一句提过一嘴。之后我列举了当前行情下 QA 应该有的 7 大能力。跟这 7 大能力相比,设计用例明显就是个初级阶段。而且这位仁兄又开始玩文字游戏了,他开始偷换概念了,他把我说测试用例是初级阶段偷换概念为我不尊重测试用例,事实上我文章中没有提过哪怕一嘴这样的话,我只说了设计测试用例的能力是 QA 的基础而已。这文字游戏玩的。。我继续呵呵。 退一万步讲,抛开我的文章来说, 设计用例不是 QA 的基础能力? 初级 QA 可以不用设计好用例? 难道这个世界已经疯狂到把设计测试用例当成高级 QA 才有的本事了? 如果是,我道歉是我对 QA 的要求太高了。

总结

所以这篇文章,我理解只是这位仁兄来报仇来了。 各位当笑话看看就好。对于只是因为转发了我文章就喷 WeTest 的状况,我表示我们大家都很懵逼。对于这位仁兄,我说一句话:你有你的逼格,我有我的原则,三十六重天天,一重一境界。前路走好不送。

#14 楼 @seveniruby 思寒看一下我的回复

#15 楼 @ycwdaaaa
#7 楼 @quqing

技术恩怨就像华山论剑一样,只在武功上见真章,不能在线下撕破脸,那没必要。在我看来,两位对测试都有自己独到的见解,我个人理念和 @quqing 比较接近,但是我也能接受 @ycwdaaaa 的理念。两位抱怨的话就不要说了,化干戈为玉帛,结合一下,完善更好的理念,不是更好?

#17 楼 @Lihuazhang 我本就是这个理念。只是这位仁兄专门在我的帖子下放狠话也就罢了。我也没理他,现在又开贴几乎指名道姓的引战,而且你还艾特我了。我就来澄清一些事情而已。 他在泄他的私愤,我不能就这么背黑锅。

#18 楼 @ycwdaaaa 我只是针对你的文章不够严谨,我也注意到有人在其他回帖中引用了错误的观点,一些混淆的观点会影响到小白,这种扩散效应有必要制止,可能是我多管闲事,但这也是来这里的初心。也许话术是我的弱项,容易让人不爽,但恭维的好听的话不一定会让人进步。你别以为我只针对你,我也对其他文章发表过我的看法,我就不说具体是哪几篇了,互动很正常,但如你反应强烈还是第一个,如果把技术 PK 搞成是泄私愤,并进行直白的言语攻击,是不是有点激动了。欢迎你对我那篇关于 Mock Better 的文章进行再次技术 PK,看看是你没理解还是我在装逼,接招吗?

#19 楼 @quqing 如果你不是针对我,为何在我之前的帖子里只放狠话,不讨论技术细节? 如果你不是针对我,为何故意曲解我的文章? 如果你不是针对我,为何专门开帖子引战? 你想撕逼明说,说的好像谁怕你一样

#20 楼 @ycwdaaaa 你的文章本来就存在概念混淆的问题,没有曲解啊,我对其他文章也评论过,难不成都是要开贴引战?难道你只想听恭维的话?你说我在 Mock Better 的文章中装逼,你拿点论据出来,摆事实讲道理,行吗?

#21 楼 @quqing 你是又想玩文字游戏么,又跑来说概念混淆问题了。 你指出我概念混淆的地方我都在刚才的回帖中说明了。 你这断章取义做的很漂亮。 如果你想讨论一下。 能回答我刚才说的问题么?

#22 楼 @ycwdaaaa 我没断章取义啊,你刚才的回帖还是有概念上的混淆,写测试用例是 QA 要干的活吗,不一一举例了,你先说一下我哪里在装逼?

#23 楼 @quqing 呵呵,说不过开始换话题了么? 来,你详细说说我哪概念混淆了? 关于 QA,关于自动化测试,关于测试用例。我在这里都回帖澄清了? 你回答一下啊? 怎么不说了? 你这篇文章不就是在说这些事么?

#24 楼 @ycwdaaaa 前面不是说了吗,写测试用例是 QA 要干的活吗?所谓 QA 的 7 大能力的描述都涉及到了具体的测试工作,测试=QA 吗?看来你是 10 头驴也拉不回了,我回答完了,你也不要转移话题,说说我那篇文章哪里在装逼,像我一样给出论据和事实

#25 楼 @quqing 呵呵,文字游戏玩的真六,转移话题也六,咱们在讨论这个帖子的内容,你却跑去说另一个帖子。 文字有些界的大拿。 你文章中写了我再文章中对自动化测试的理解不对,轻视自动化测试用例,这些我都反驳了,我都澄清了。 你咋不之声了? 至于测试=QA? 我就更呵呵了,我回帖写的清清楚楚了你说 QA 和 QC 的区别的错误。 你现在又来反问我? 跟你这种人说话真是浪费时间。

#26 楼 @ycwdaaaa 我就是根据你在这里的回帖答复你的,感觉你的思路好乱,能不能不扯一些没用的,来点具体的?

#15 楼 @ycwdaaaa 有争议才有看点 你该谢谢他😀

可是现在好多公司都把 qa、qc 混一起用。
有些人明明做 qc 还可以的,非要拿 qa 的角度去评定。

我觉得怎么让这些人可以分清楚一下 qc/qa 的区别会更好一点。

QC 其实也是把控者,还有本书叫 QC 手法运用实务,执行者是 tester.国内这种定义都比较混淆,有些是 hr 给定义的。
我想提的误区是杀虫剂悖论(用交叉测试规避是其中一种),很多都是怎么简单怎么好培训怎么来,其实大量重复工作充斥(不光是手工测试)

#27 楼 @quqing 呵呵,你自己思维混乱还跑来说我么。算了,不跟你浪费时间了。你真的除了嘴炮什么都不会了。再见

早年,我在一个台资的软件企业里面,05 年的时候就通过了 CMMI3,有 CCB 小组,流程很是规范,有专门的 QA 的角色,负责项目中的各种流程的合规性,检查这种文档等。

那个时候 QC 还是工厂里的说法。

#28 楼 @dongdong 有争议时好了。但有人来故意捣乱就是坏的

talk is cheap,show me the code。go on!~

三年测试,不知 QA 与 QC,只知测试。

#34 楼 @yangchengtest 可以简单翻译为,不会写代码不要逼逼么😀

我觉得测试做 qa,就是给项目经理擦屁股的。😤

#33 楼 @ycwdaaaa 故意一词用的太草率了吧,我针对你除了得罪人有什么好处?

@erick 你可以去 google 下这是谁说的,我觉得这才是做技术撕 x 的最高境界。

别因为争论影响了工作心情啊,很少能看到这种盛况→测试技术人在 TesterHome 争论的面红耳赤,可能对于二位不太好把,但是对于大部分人来说,学到了很多,总之我是学到挺多的!最简单的方法→列个条目 1、2、3 一次只回答一条,1 条没结束讨论,就不开始下一条。😜

#39 楼 @yangchengtest 厉害了,word 哥

@quqing @ycwdaaaa
感谢两位社区大 V 的交流. 让我们这吃瓜群众能通过挑战来看到更多的技术细节

江湖高手, 社区大 V 之间因为观点不同导致的不合, 在各个社区甚至是普通的社会中都非常的多见. 以我们雪球上的炒股高手为例, 有的大 V 之间已经水火不容, 扬言退出雪球平台去对手平台的人也有好几位了. 他们这些大 V 在雪球有较大的商业利益考虑. 并不是纯技术和纯社区的理念. 我想我们这些技术人还不至于和那些商人一样.

首先争论会是一直存在的, 就如美国的两党制一样. 我们要理性的去看待这个事情. 正是因为观点的碰撞才有了思维的创新. 才让一个社区充满了无尽的活力和创新源泉. 所以不要对别人的挑战保持敌意

大多数的矛盾, 并不是诞生于真正的技术流派之争, 而是诞生于对人格的攻击. 成功来自于细节, 恩怨也来自于细节.
评价一篇文章, 需要用公正客观负责的态度. 鼓励大家充分的使用赞扬和批评. 但是并不鼓励人格攻击和不负责任的嘲讽.
二位的不合也大多是起因于对方简单轻浮的总结或者嘲讽.

我建议两位大拿以后按照这样的标准要求自己.

  • 要有一个共识. 没有任何观点是 100% 正确的. 1+1=2 都能被反驳, 何况我们自己的表达. 不要对别人的挑战有记恨. 每次都要就事论事.
  • 当对一种观点不认可的时候. 请据理力争去质疑和挑战.
  • 当彼此无法达成共识的时候, 请最后注明你赞同哪部分反对哪部分. 这是为了负责任的去表明自己的立场, 不至于以偏概全. 也是为了让时间和实践去证明.
  • 不要在别人的帖子里引导舆论. 人们自有是非对错的判断. 每个帖子都是自己观点的宣讲舞台. 可以被质疑, 但不应该被干扰. 要尊重彼此的表达机会.

金庸小说里面提到, 华山派有气宗和剑宗之争, 纠缠数百年, 最后打的你死我活导致门派高手陨落殆尽, 最后只有令狐冲得到两派真传从而笑傲江湖.
也许你们两个的争论最后没有绝对的胜负, 但是会影响无数看帖的新人. 进而促进他们的成长.
我代表社区下一代的无数"令狐冲"们感谢你们两个

#42 楼 @seveniruby 今天是我又一些激动,这里我道歉了。 毕竟被人无理取闹了这么久。一时没忍住。

@seveniruby 赞思寒的风范,更赞同这句『当彼此无法达成共识的时候, 请最后注明你赞同哪部分反对哪部分. 这是为了负责任的去表明自己的立场, 不至于以偏概全. 也是为了让时间和实践去证明.』

#43 楼 @ycwdaaaa 你们双方也都认为对方是无理取闹或者故意找茬. 我建议你们平静一个月, 再回头看自己的文章和评论. 到时候会有另一番体会的. 时间是最好的镜子.

#45 楼 @seveniruby 本来是在冷静的,对于他在我的帖子里喷我的话我也没有反击,这些事就当这么过去了,但是他今天已经发帖子几乎指名道姓的喷我了,我觉得不能再继续沉默下去,才会激动的反击了一下。你说的对,我们都认为对方在无理取闹。我们都该冷静一下。我本不欲相争,毕竟影响工作影响心情,能想息事宁人是最好了,只要这位仁兄别再公然发帖子,黏上我的文章,说我在坑害别人就好。

61楼 已删除

#47 楼 @harsayer 饱和哪有时间吵,并且测试何苦为难测试😂

这两位见面就打,我怀疑他们其实是同一个人,只是患有精神分裂

#49 楼 @jet 黑的如此有诗意,其实两位并不是同一人,说话方式以及逻辑思维方式都不同~

63楼 已删除

#49 楼 @jet 额。我灰常喜欢你黑的方式。。。。。

测试领域有些定义已经很明确了,就如白盒和黑盒,黑白岂能颠倒。只有敢于面对自己的不足,才有勇气更上一个台阶。

#15 楼 @ycwdaaaa 😂😂😂

—— 来自 TesterHome 官方 安卓客户端

把测试用例设计定为初级阶段,这绝对是技术至上的一种偏见和对测试用例的一种无知 。点赞!

#56 楼 @hrtester 这其实武功中的内功,贯彻了整个测试人的一生。

那为啥我面试的时候说测试用例设计得好,人家 piapia 滴把我赶走了。。

@woshizh 给多少钱干多少活,价格是你的可替代性决定的,无论技术,管理其实都是有 level 的。
现在测试其实是有溢价的,自己要有清醒的认识,知道很多理论没实践,鸟用没有,哎。

#58 楼 @woshizh 面试官的水平也是参差不齐的

#59 楼 @yangchengtest 是的,有理论不实践,有技术不懂测试都是不全面的。唯理论、唯技术论都是极端的。

@quqing 楼主你最牛,楼主测试大法,一统江湖,威震武林。佛挡杀佛,人乱说删帖,是吧?

#62 楼 @harsayer 请你删了吧,这种话看了不舒服,谢谢 😁

需要 登录 后方可回复, 如果你还没有账号请点击这里 注册