`
hzbook
  • 浏览: 260921 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

只懂执行其他人测试想法的人,不能算是一个真正意义上的测试人员

阅读更多

测试人员到底是什么样的人?

节选自《测试之美》 (原书名:Beautiful Testing ,作者:Tim Riley & Adam Goucher,译者:张 等)


 

 

<!-- [if !supportEmptyParas]--><!-- [endif]-->

IT 世界里,测试人员的工作是极为特殊的。在商业世界里有多少份工作是付钱让你直言不讳的呢? 当唯一的“桃子”显然有些坏掉的时候,测试人员不应该是拿着工资却告诉你一切正常。可以想象,你的项目组或 IT 部门的其他成员可能会有些不合时宜的乐观情绪或自相矛盾的评论意见。不过,测试人员拿了工资就是要告诉你他们所了解的一切事实,甚至有时候他们会直白地说你的小宝宝很丑,还给出一系列论据。

管理一群测试人员或者与他们共事,理解他们的思维是很有帮助的,这包括你得明白工作上什么事情才能让他们情绪高涨、兴奋异常。

那么测试人员到底是什么样的人呢?如果只列举少量的关键特质,那么首要的一点是测试人员有好奇心。 他们想弄清楚事物是怎么运行的;其次,他们喜欢动手实验 ,他们想知道尝试使用功能演示时不同的用户场景和实验会发生什么;再次,好的测试人员胆子比较大, 他们不害怕会破坏什么东西,不管你有多位高权重,他们也不害怕把发现的事实告诉你,他们更不害怕站出来据理力争,一定要把他们相信可能影响到产品成功的问题解决掉。测试人员聪明,善于分析,善于学习。事实上,他们总是在学习,他们的工作性质要求如此。技术总是在变化,他们接到的每个项目或多或少跟上一个项目不太一样。有时候他们有很好的文档,有时候没有很好的文档,有时候甚至没有成文的文档。他们必须问出正确的问题,研究正确的问题,把谜题的各个碎片联系在一起,然后得出正确的结论。测试人员一般不关心办公室政治,如果你发现一个测试人员特别精通此道,很有可能他的本职工作做得不是非常出色。 当你的工作是发现和报告问题,要想玩好政治游戏是很困难的。经常有人责备测试人员过于直接、粗鲁、团队合作精神不佳等。其实不然,很有可能责备他们的人不了解或者没能意识到项目组中测试人员的角色,他们的工作不允许他们隐瞒任何“不方便说”的信息。

上述这些是测试人员好的特质,还有其他一些不那么好的特质 ,但也是大部分测试人员整体个性中不可分割的一部分,尤其对那些测试经验丰富的人来说。测试人员容易不信任人 ,这是从实践经历中学来的,别人总是告诉他们模块 X 不需要测试,或代码 Y “没动过”,这种信息错的次数多到数也数不清了。所以就算你告诉测试人员草是绿的他们也要亲自过目才敢相信。测试人员是挑剔的,这个习惯也贯穿在他们生活的其他方面。他们的任务就是要发现和报告问题,这就是说如果你发给他们的电子邮件里有一个拼写错误,他们整个团队都会跳出来好心指出,甚至还有你(或者其他人)的其他错误。测试人员质疑一切,包括权威。一般来说想要用搞定其他部门的办公室政治手腕来欺骗或者算计测试部门可不容易,倒是告诉他们严酷的真相要来得好得多,这是唯一赢得他们尊重和信任的方法。

你可能认识一些并不具备前述特质的测试人员。不是测试团队里的每个人都算得上是测试人员,也不是每个具有测试人员头衔的人都算得上是个测试人员。 有的人满足于运行已有的测试,他们没有擅长分析、好奇和喜欢动手实验的天性,他们的胆子不太大,很容易被强势性格的人、位高权重的人或要去做新鲜事情的想法所动摇。他们可能因为害怕人们之后的反应而不报告缺陷;他们主要的顾虑是不要坏了大局,有的人过于“热衷”办公室政治和关注个人的计划和成功,以致失去了让他们在测试团队中与众不同的那些很有价值的特质。总的来说,根据你的部门大小不同,不同性格的人都可以对项目的成功贡献力量,但是花力气去识别和培养你部门里“真正的”测试人才是值得的。只懂执行其他人测试想法的人,不能算是一个真正意义上的测试人员。 当一个测试人员需要运行一大堆已有的测试用例时,容易心生厌烦,可能会尽快运行这些测试,只是想让它们从眼前消失。这意味着他们可能不会非常关注这些测试,当然也就不能像认真彻底的执行者一样找出某些问题。从好的另一方面来看,一个“真正的”测试人员一定会把这些已有测试看作自己的职责范围,重新考虑其中的想法,提出问题,充实和改变测试,探究原来的分析没有考虑到的地方。 如果原来的分析实在很棒,那可能他们也找不出来太多可以更新充实的内容,进而增加了无聊指数。你会发现,如果每天的工作就是按部就班,如运行一大堆已有的手工测试用例,日复一日,那些真正富有创造力、勤勉的、聪明的测试人员的精气神儿、自主性和创造力都会消磨殆尽。为了你的测试人员士气着想,无疑需要让他们把手头工作交给愿意每天按部就班做事的人,或把手工测试自动化,或者不要让他们再做这些事情。他们想做点新的事情,想发现和报告缺陷,想贡献其他人无法贡献的力量。

很多测试人员觉得单调乏味而不屑运行回归测试用例,你会发现他们其实大部分都理解甚至同意回归测试的必要性,但这就像是面对一道人家已经解决的谜题,一点探索和寻宝的乐趣都没有了。大多数测试人员知道回归测试只能找到代码里的一小部分问题,他们更愿意去寻找新代码里潜伏的一大堆问题,这完全就是探索和寻宝的乐趣之旅。

那么在态度方面,难道不应该团队协作吗?千真万确,你的测试人员也愿意扮演好团队成员角色,他们是想帮忙作贡献的,他们很希望自己得到欣赏,但是他们关注的东西让项目组其他成员难以接受和欣赏他们的贡献。他们的幽默甚至增加了让他们融入团队的难度。更糟的是,如果你在一个不关注质量的公司工作,并不认同或不解决测试人员辛辛苦苦发现的问题,测试团队会认为这是对他们以及他们的工作缺乏尊重。如果你不给予测试人员他们应得的尊重,很快就会让他们士气低落,然后你就很难留住具有本土市场上热门技能的人才。

总的来说,现在整个测试业界已经相对成熟、文明有礼了,测试人员变得更能与人“和睦共事”。最有经验的测试人员会同情地拍拍你的肩膀说:地球人都知道事情不仅仅是发现问题那么简单。他们也会充分理解、全力支持你的决定:问题 A B C 可以不解决了,不会有人就此激动万分大发雷霆的。实际上,拥有多年工作经验的测试人员会说出你所喜闻乐见的意见,因为他们从这家公司的项目经验中学乖了,知道这样会给他们(当然也就是给你的部门)带来最好的质量结果。但是需要记住,他们之所以肯牺牲问题 A B C ,很可能是为了说服你解决更严重的问题 D E 大多数测试人员私底下希望你解决他们找到的所有问题,测试人员很明显会偏向于把问题都解决掉,他们看见出错的东西,就想改进它们。 想想吧,你真的希望测试人员不这么想吗?

一般来说,经验丰富的测试团队能用漂亮的包装纸(词汇)和丝带(对于问题的理解)来呈现一个缺陷,过了好一阵你才会意识到自己收到的是一大堆恶心的牛粪。他们也不过是转赠而已,是你先给了他们这样的东西,不知何故你给他们的时候没有发现这玩意儿真的是相当臭。他们用礼貌的政客语言跟你讲话,这跟在你耳朵听不到的场合(如在牧场跟其他牛仔侃起大山时)说的话可是完全不同的。他们在痛苦的经历中学到,与其共事的其他领域的“家伙”是不能真正欣赏他们这种幽默和乐趣的:在地里系统全面地搜寻牛粪,然后用系着大红蝴蝶结的漂亮彩盒子装起来送给项目组……

搜寻软件毛病(缺陷)很像寻宝之旅。缺陷通常是藏起来的,要找到它们需要同时具有逻辑、技术和直觉(或者说运气)。很多测试人员都很喜欢谜题,这并非偶然。他们就喜欢搜寻和发现东西。寻宝令人兴奋,发现一个错误(或者说答案)是终极动力。当测试人员发现缺陷之日,就是他们赚取酬劳之时。在他们看来,那意味着最终用户不会发现的问题多了一个,开发团队改进产品的机会多了一个,公司的风险因素少了一个。找到一个缺陷就是一个值得欢呼雀跃的意外收获。 开发团队或管理层认为是令人不爽、厌恶、沮丧的没解决的问题,对测试人员来说却是美妙的事物,是埋藏的宝藏,是达布隆金币。

不同的测试人员为搜寻缺陷做着不同方面的准备。他们的准备工作取决于你的环境和研发方法,一些准备工作源自个人偏好,他们可能提前开始写测试用例,也可能从一个笔记列表入手。但是不管技术方面怎么样,有些事情是各种技术都共通的。

他们要阅读一切帮助了解测试目标的资料,要问问题——很多很多的问题,一直问到他们满意觉得足够了解该应用程序为止,然后他们要决定如何最好地进行测试并制定一个计划。这个计划也许很正规,也许只在他们的脑子里,但大多数测试人员在开始测试之前就知道他们想要检查什么,在开始实验的时候也大致知道系统应该是什么样以及如何工作。

这就是技术、培训、经验发挥作用的时候了。一个受过培训、经验丰富的测试人员总是比缺乏培训、经验不足的人找到更多的错误。这与智力无关,只是缺乏指导和学习。 这也不是说新人就会一无所获,他们也能发现一些东西,但是经验丰富的测试人员知道哪里容易发现缺陷,什么容易出问题,他们还从经验中学到在类似的情况下哪种技术曾成功地帮他们发现缺陷。一个测试人员是否受过“正规的”培训(边界分析等),或敏捷技术培训(启发式、游历式等),或者两者都学过,并不那么要紧。一旦测试人员学会阅读字里行间暗藏的玄机,观察显而易见之外的事物,询问一针见血的问题,以及眼界的扩展,你就成为了一名真正的测试强人,通过继续学习和掌握新的工具,你的力量将随着职业生涯不断增强。

 

分享到:
评论

相关推荐

    敏捷软件测试:测试人员与敏捷团队的实践指南

    敏捷测试象限是书中介绍的一个重要工具,它帮助测试人员识别在敏捷开发过程中需要进行哪些类型的测试,以及由谁来执行这些测试。敏捷测试象限分为四个象限:技术专家质量关注、团队质量关注、支持开发过程的质量关注...

    测试人员绩效评价标准

    2. 考核方法:包括提交BUG的数量和执行测试用例的数量、测试人员发现的问题的本身价值、测试文档的质量、测试技能水平和测试技能以外的综合能力等多方面的考核标准。 3. 考核标准:包括测试人员的责任心、积极的...

    优秀的测试人员必备的素质

    这包括理解黑盒测试、白盒测试等基础测试技术,熟悉单元测试、功能测试、集成测试、系统测试、性能测试等不同层次的测试方法,以及掌握测试流程管理、缺陷管理和自动化测试技术。这些知识构成了测试工程师日常工作的...

    软件测试人员的发展方向都有哪些

    - 高级测试工程师/程序分析员:这一级别的测试人员不仅要精通各种测试技术和工具,还要参与制定测试策略和标准,对测试流程提出改进意见,同时可能需要指导初级测试工程师的工作。 - 专家级测试工程师:如自动化...

    让程序进行真正意义的思考 C#测试代码

    循环中通过扫描记忆中的单元,判断记忆中的内容,如果内容是一个想法,那么将实现想法中的方法,想法可以创造另一个想法,并且加入短期记忆,等下一次扫描来临,执行这个想法,想法同样可以修改另一个想法,并且有...

    16任务十六、unittest框架批量执行测试用例(一).docx

    TestSuite是一个容器,可以用来组合多个测试用例或者其他的TestSuite,方便批量执行。 在`test_suite.py`文件中,首先导入了unittest模块和`test_select.py`中的TestSelect测试类。接着,创建了一个TestSuite的实例...

    软件测试计划模板,各种测试阶段任务、人员分配和时间安排、工作规范

    在软件开发过程中,软件测试是不可或缺的一环,它确保产品的质量与稳定性,为用户提供可靠的服务。一份详尽的“软件测试计划”是测试过程的蓝图,涵盖了从测试目标设定到执行,再到结果评估的全部流程。下面将详细...

    什么是白盒测试以及学习白盒测试的意义是什么

    白盒测试作为软件测试领域的一种重要方法,其价值不仅仅体现在它可以有效地发现和预防软件错误上,更重要的是它能够帮助开发者深入理解软件的工作机制,提高自身的开发技能,并最终提升个人在职场上的竞争力。...

    性能测试 负载测试 压力测试 性能测试工作原理及应用角度,模型。测试脚本开发与测试执行,测试分析技巧

    测试管理流程,测试人员安排,测试工作产品,性能测试的过程,周期,系统需求应用配置需求用户手册需求,测试计划,加案例说明。 测试脚本开发与测试执行,测试分析技巧,UML软件工程组织和使命等等

    黑盒测试,白盒测试,系统测试三份实验报告.pdf

    最后,系统测试通常是在一个更接近于实际使用环境的环境中进行,这需要构建一个与生产环境尽可能相似的测试环境,以便验证软件系统在正常及异常条件下都能达到预期的性能和可靠性要求。 综上所述,这三份实验报告...

    软件测试人员量化考核办法.docx

    例如,一个测试人员可能在测试执行环节表现出较高的执行效率,但缺陷发现率却很低,这说明该测试人员在速度和深度之间未能找到良好的平衡,可能需要在测试策略和方法上做出调整。量化指标的分析还能为测试流程的持续...

    软件测试计划测试人员必看.pdf

    《软件测试计划测试人员必看》是一份详细指导软件测试人员进行系统测试的文档,主要涵盖了测试计划的各个方面,旨在确保网上购书系统的功能性和性能得到有效验证。 首先,文档的编写目的是为了对网上购书系统进行...

    JIRA测试用例创建以及关联Strory故事操作指南.pdf

    JIRA是一个广泛使用的项目与缺陷跟踪工具,它也提供了测试用例管理功能,有助于测试团队编写、执行和跟踪测试用例。 二、测试用例创建方法 1. 从Story创建测试用例 用户故事(Story)是敏捷开发中的一种需求描述...

    移动应用众包测试人员信誉度复合计算模型研究.docx

    该模型的核心思想是通过建立一个综合性的评价体系,对参与众包测试的人员进行信誉度评估,以此来保证测试质量。信誉度计算模型不仅关注测试人员的主观表现,比如他们对问题的感知和报告的准确性,也关注客观的测试...

    软件测试人员面试题.docx

    软件测试是IT行业中至关重要的一个环节,主要目的是确保软件产品的质量,找出并修复程序中的错误,使其能够满足用户的需求。面试题中涉及了多个关于软件测试的重要知识点。 首先,选择软件测试行业的原因在于其广阔...

Global site tag (gtag.js) - Google Analytics