写点什么

开发人员与测试人员的划分

  • 2012-05-02
  • 本文字数:2908 字

    阅读完需:约 10 分钟

从此以后他们幸福地生活在一起

关于开发人员和测试人员的关系,人们阐述了很多,讨论了很多,争论了很多。而貌似一旦这两者坐在一起,对峙便开始了,两者间的争论多于相互认同。显然,这不利于实现两者合作的目标——向用户提供价值。

让我们来分析事情的来龙去脉和现状,思考如何做得更好。

史前时期

在最开始,不存在测试人员,只有开发人员。软件开发人员和软件项目的其他人员比起来并没有特别大的不同,除了如下事实:他们是软件项目的主要成本。准确地 说这里的成本并不完全是指开发人员自身 (虽然那时优秀的开发人员并不好找),而是开发时间以及运行软件所需的资源(比如巨型计算机)。从经济角度考虑,专 门成立测试人员是行不通的:开发软件的时间如此昂贵,为测试人员分配时间显得很浪费。

没有专门人员检查工作,软件开发人员只好自己做测试。因为开发软件的时间如此昂贵,他们通过检查日志、打印信息以及离线“调试”来确保软件正常运行。那时 还没有可用于调试的 IDE,开发时间如此昂贵,可不能在查看成百上千页的打印数据上花费太多的时间。因此检查数据的人都是开发人员,这样大家使用彼此熟悉 的术语,对问题心知肚明。这样,尽管速度还不够快,但整个团队能够和谐地前进,。

开始分裂

随着软件行业的高速发展以及计算机成本的降低,软件公司在考虑成本的同时也开始关注软件质量。软件使用者开始变得挑剔,他们经常在初次使用时就不满意,要求软件公司修复或改善他们所购买的软件。

保证软件质量的方案之一就是验收测试:客户在软件系统上执行应用场景。这些场景就像是软件公司和客户之间的契约:软件系统只有通过这些场景测试才能够被客户接受。

最初,开发人员会自己执行验收测试,或者由客户执行验收测试,然后将问题反馈给开发人员。但软件公司很快就意识到开发人员不擅长于处理和客户的关系,于是隔离客户和开发团队的想法开始萌芽。

存在的问题不仅仅是客户和开发人员之间的沟通。因为验收测试有时无法达到预期效果,人们越来越意识到应该对开发团队进行更加严格的质量监控。若由其他团队 的开发人员进行质量监控,则会导致软件成本增加;而进行质量监控不需要理解错综复杂的软件是如何工作的,因此软件测试人员这个职业便产生了。

当然,这种组织结构的变化并不是自然而然产生的,组织结构变化需要管理上的支撑和协调。所以经过几年的发展,软件项目中开发人员和测试人员两种角色的界限还是不清晰,

随着软件测试领域的发展,越来越多的测试人员需要提升自身的技能,于是开始产生了相关的方法论和培训需求。培训和认证机构看到了这个市场机会,开始提供测 试人员以及开发人员培训服务。随着方法论的逐渐成熟,测试专家开始涌现。之后开发和测试领域都有各自的专家,开发人员和测试人员的界限清晰起来了。

双城记

开发人员和工作人员在思维和工作方式上截然不同。开发人员认为自己是创新家,他们从无到有创建出软件,却常常招测试人员指手画脚。另一方面,测试人员苦苦 忍耐开发进度,而当终于从开发人员手里接过软件时却发现软件是个废物。质量始终难以过关,测试人员重复测试出主要应用场景的错误,花费了不少时间。由于时 间有限,很多应用程序没能完全通过测试。

开发人员认为测试人员就是敌人,因此可能会把软件发布抛在脑后,使出浑身解术避开测试人员。测试人员认为开发人员不够专业,产生了很多本可以避免的 bug。软件团队中弥漫者诸多不信任。

软件公司中的这两个党派之间还存在另一个问题:软件需求以及测试场景的沟通问题。因为思维方式的差异和语言的歧义性,软件需求经过再次表述,接着再次被理解,结果和实际会有很大出入。而这些理解上的出入直到测试阶段才被发现,相互指责随之爆发。

最后一个会引发两党冲突的问题是时间鸿沟。开发人员说可以测了,测试人员便开始测试,开发人员接着进行新功能的开发以保持生产率。然而,当测试人员报告 bug 时开发人员的开发工作被扰乱了,开发人员开始抱怨测试人员见缝插针,指手画脚。

开发派和测试派之间的紧张局势显然不利于减少浪费和产生有价值的产品。两派之间的冲突导致了重复工作,相互指责,而软件产品难以有见光的一天。

敏捷之桥

敏捷实践一开始就以开发出能良好运转的软件作为目标。这是很重要的一步:敏捷宣言的倡导者来自软件行业的各个领域(开发人员、测试人员和管理人员),他们把业务价值放在第一位,任何事情都应以它为依托。

“完整团队”是其解决方案,这是试图将客户和开发团队捆绑在一起的极限编程实践。敏捷组织也有测试人员的概念。

因为开发人员与测试人员有了共同点并需要紧密协作,他们恢复了之前抗拒的行为:交流。

他们开始使用相同的术语交流需求是什么。语言障碍消除了,双方在应该怎样做和哪些事情还未解决上达成一致。

最重要的是,在一个 sprint 中,功能特性被开发和测试,所有发现的 bug 都被修正。这样,开发人员和测试人员之间的时间鸿沟消失了,因为他们始终在相同的迭代周期中协作。

当开发人员和测试人员在同一迭代周期中协作时,他们发现了更好的情况:测试人员在流程早期捕获错误和决定怎么处理,这样对开发工作产生正面的推动,开发人 员也从迭代中受益:在 sprint 中捕获和修正的 bug 都不算是真正的“bug”,只有逃脱出迭代周期的 bug 才会被当作真正的 bug 记录下来——开发人 员可不愿意成天被别人说自己开发的软件是有 bug 的。

改造

敏捷团队实践也产生了奇特的社会学副作用:开发人员和测试人员之间的界限不再清晰。敏捷团队中开发人员做着各种各样的事情,他们介于开发人员和测试人员之 间。开发人员开始参与测试,而测试人员则学会了怎样开发以及怎样编写代码做自动化测试。没有人能够做所有事情,但每个人都学会了额外的技能。

另一个边际效应是软件质量的提升。敏捷实践认为每个人都应该关注质量。开发人员肩负起本来的职责:保证他们的代码能够正常运行。软件质量提高了,测试人员则可以在一般性测试之后开始探索式测试,使软件质量更上一层楼。

美好结局?

试图获得成功的敏捷团队还一直处于发展变化之中。敏捷软件公司正在尝试创建功能特性团队,这样的团队不仅仅由开发人员和测试人员组成,还包括了其他角色。

但这样的公司还是少数。大多数公司还没有涉及真正的协同敏捷软件开发。开发人员和测试人员仍然被相互隔离,他们认为从业务角度考量这两种角色就应该被分开。

敏捷实践已经证实,通过流程以及协作可以打破开发人员和测试人员之间的隔阂。成功的敏捷实践必然包括开发团队和测试团队的融合。没有重新组织以使两者融合,是不可能获得成功的,或者用敏捷的术语:不可能获得良好运转的软件。

关于作者

Gil Zilberfeld Typemock 公司的产品经理。在 15 年的软件开发之旅中,Gil 经历了软件开发的各个方面,从编码到团队管理,再到流程实现。Gil 在演讲和博客中谈论单元测试,鼓励初级和高级开发人员在他们的项目把单元测试作为核心实践。你可以通过电子邮件 gilz@typemock.com 他的博客联系他。

查看英文原文: The Developer-Tester Divide


感谢侯伯薇对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ )或者腾讯微博( @InfoQ )关注我们,并与我们的编辑和其他读者朋友交流。

2012-05-02 00:006042

评论

发布
暂无评论
发现更多内容

我对2021的期待,从合上这份2020日历开始

脑极体

腾讯T2手把手教你!字节跳动历年校招Android面试真题解析,含BATJM大厂

欢喜学安卓

android 程序员 面试 移动开发

Serverless 在 SaaS 领域的最佳实践

阿里巴巴中间件

阿里巴巴 中间件

侵犯著作权、判刑两年半的 CTO |法庭上的CTO(22)

赵新龙

CTO 法庭上的CTO

网络模拟器:Cisco Packet Tracer 设备登陆实验

生产环境全链路压测建设历程 23:FAQ 3、4 适配改造,目标压力

数列科技杨德华

全链路压测 七日更

10次面试,2份offer —— 大龄程序员 2020 求职记录

escray

面试 架构师训练营第 1 期

2020盘点之手机失窃事件复盘分析

石君

信息安全 资金安全 手机失窃

十大经典排序算法最强总结(含Java、Python码实现)

Java 面试 算法

史上最全面‘java监听器’解读,读完就能用进项目

Java架构师迁哥

小说内容理解

DataFunTalk

AI 推荐系统

天下武功,唯”拆“不破之架构篇二 | 技术人应知的创新思维模型 (9)

Alan

架构 技术 技术人应知的创新思维模型 七日更 28天写作

C语言编程:入门指南(一周内学懂)

计算机与AI

c

百分点智能对话技术探索实践

DataFunTalk

AI

“让专业的人做专业的事”,畅捷通与阿里云的云原生故事

阿里巴巴中间件

云计算 云原生

被砍伤的技术VP | 法庭上的CTO(24)

赵新龙

CTO 法庭上的CTO

架构师训练营第一周作业

Mark

鸟枪换炮,利用python3对球员做大数据降维(因子分析得分),为C罗找到合格僚机

刘悦的技术博客

Python 数据分析 特征选择 降维

甲方日常 77

句子

工作 随笔杂谈 日常

工具词典:中立观点

lidaobing

维基百科 28天写作

阿里P8大牛亲自讲解!Android高级工程师面试实战,Android岗

欢喜学安卓

android 程序员 面试 移动开发

时空大数据与智能技术的时代共舞,百度地图给2020的答案

脑极体

犯”集资诈骗罪“、二审判6年的CTO | 法庭上的CTO(21)

赵新龙

CTO 法庭上的CTO

云原生架构-静态代码扫描SonarQube超时

云原生实验室

DevOps 云原生 jenkins SonarQube Pipeli

58同城风控平台演进

DataFunTalk

架构 中台

互联网大厂有哪些分库分表的思路和技巧?

冰河

分布式数据库 分库分表 分布式存储 数据一致性 数据同步

开设赌场的CTO | 法庭上的CTO(23)

赵新龙

CTO 法庭上的CTO

散布消极言论被开除的总监 | 法庭上的CTO(25)

赵新龙

CTO 法庭上的CTO

阿里P8大牛亲自讲解!6年菜鸟开发面试字节跳动安卓研发岗,成功收获美团,小米安卓offer

欢喜学安卓

android 程序员 面试 移动开发

全面 Severless 化只需要 7天!看南瓜电影的云上升级

阿里巴巴中间件

阿里巴巴 中间件

总结2020:5个月出版两本书,日更公众号是一种怎样的体验?

冰河

程序员 程序人生 年终总结

开发人员与测试人员的划分_软件工程_Gil Zilberfeld_InfoQ精选文章