TDD

TDD基于测试优先的概念。它的好处在于让人先去思考需求,再去思考实现。

如何推行TDD:1)自上而下的灌输‘TDD好’的理念;2)定期开展TDD培训,尤其在结对编程实践不在线的情况下。此时通过培训来提高TDD技能的需求就更加迫切;3)总结出一个行之有效,符合项目实际情况的TDD实践标准。4)洗脑客户。

说单元测试好和TDD好是两件事情。TDD本身的优势, 比如不会产生难以测试的代码, 比如会避免写代码到一半发现有业务上的问题不清晰导致代码要大改甚至重写, 再比如可以让测试尽量和业务要求贴合而不去和工程结构过度耦合.

测试金字塔

测试四象限



在“国内短期交付项目”上,对dev来说有着很多实际的困境:

1)工作量超级大,虽然可能本身的技术难度并不高,但有时候也会涉及到比较复杂的业务流程,姑且不论质量,光是把这些工作做完就不是一件轻松的事情。而由此产生的其他问题可能更严重了:因为没有时间,一些保证质量的环节被选择性的忽略掉,比如code review,重构,测试之类的,大家也会习惯性的认为没有时间做这些事情。

2)相比于其他的项目,技术方面的限制可能更多:客户对技术框架和选型的控制会更封闭(通常坑也更多,并增加了沟通成本)

3)时间紧张,根本没有时间来让团队上的成员有自我提升的机会, 卡都做不完,更别说花时间去学习和提升了。

于是大致会出现这样一个结果:为了项目能够如期交付,以牺牲代码质量为代价来赶进度。对于自动化测试来说,没时间写测试,很大程度上需要依靠QA来把控质量了。

这里涉及到一些很有意思的命题:如果不写测试,是不是可以提升开发进度或者说开发效率?由此带来的质量牺牲是否划算?   

我们先来看第一个命题,我相信大多数人会支持不写测试(或者说不用TDD)开发速度肯定会更快,理由很简单,因为写测试本身也是在写代码,是需要成本的。而要衡量这个成本有多大,需要从两方面考虑:一个就是测试框架的能效比,简而言之就是写测试是否容易,是否运行迅速,如果写起来很麻烦,或者说写了之后每次跑测试需要很久,那么很显然能效比不大高。理想的状态应该是,我们能够很容易的编写测试,而且测试的速度应该比较快,不至于跑测试的时候需要去喝杯咖啡。另一个方面就是开发人员对测试框架的熟悉程度,越是熟悉那么写起来也越得心应手。

而通常认为写测试会降低开发速度,其实建立在一个前提上,就是使用其他方式的验证(比如说把系统跑起来人工去试)会比通过测试去验证更高效。但是往往我们做的卡多多少少都会有很多的场景需要测试,尤其是比较复杂的业务卡,对应的代码也有很多内容,而我们通过人工的方式去验证,实际上不会去考虑太多的场景。那么,如果dev自己没有去验证这些,这部分工作就要单纯依靠QA来完成了。

姑且不考虑代码修改所需要的回归测试的成本,单纯只说开发一个功能的时候,我认为很多时候其实通过自动化测试的方式更加迅速。因为这些自动化测试可以更早,不需要等到所有功能都完成之后才能进行,而且很容易进行隔离,不必要等待一些环境或者其他功能的完成。

所以从这个角度来说,我倾向于认为通过自动化测试的方式来开发反而违背常理的更加迅速。

对于大多数人来说一定是反反复复修改,反反复复测试;当然我相信有人可以很快写完可以work的代码,但如果你对代码对自己有更高的要求,一定会不满足单纯work而已吧?重构是必然的,而重构的前提是得有测试撒。

从另一个层面来说,我们抛开质量的一个前提忽略测试,主要是因为工期紧张。但实际上,上线结束之后通常项目并不会结束,可能会有下一期,也可能会给到其他人维护。所以从这个角度而言,所谓“短期国内交付”并不十分准确,这些技术债,最终可能都是自己来还。

软件交付不是短跑,跑完之后留下一地鸡毛。你写下的每一行代码后续都可能是需要他人维护的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342