开发自测模式实践

开发自测模式实践

 背景:

  长期以来业务线测试有这种困扰:淘宝业务线传统的项目流程把开发、测试两个阶段分得比较明显,导致开发赶时间写代码,提测阶段测出一些低级bug;重新返工不仅测试时间延长,也导致开发、测试同学都累。

   在天彤的支持下,本人今年3月份来到C2B市场团队轮岗开发,实践了开发自测的项目模式。这是一个新产品团队,新模式比较容易落地。迄今经历了5个项目 (C2B公益概念版、C2B标准版、C2B公益版2期、C2B合买版和合买版双12活动),摸索了近1年,有过困难和困惑,总体看来实践效果还是挺不错 的,分享一下。

  分享分为实践案例、模式小结和展望3部分

  一、实践案例

  以时间为维度,实践中经历了以下3个阶段。每个阶段都是在前一阶段模式的基础上根据实际情况优化的

  阶段1:人人都是开发,没有专职测试

  有两个项目

  1、C2B团购概念版(3.20-4.15,开发测试比3:0),第1次实践成功

  这是第一次轻量级尝试,加上我有3个开发,功能全部自测,最后我主导验收了一下功能。项目流程如下

开发自测模式实践_第1张图片

  说明:

  1)由于前端资源紧缺问题,所以后期才开始前端编码

  2)TC也要开发自己写。给开发培训了一下从UC到TC的转化方法

  3)整体验收包括代码review、PD验收和我再覆盖一下主流程

  效果:

  1)单测和接口测试覆盖很好地保证了质量

  在单测和接口测试阶段都发现了bug,避免遗留到功能测试阶段;后端编码的稳定性,能让开发在后期专注在前端功能的开发和联调上,不用担忧底层的质量

  2)功能测试时间大大缩短

  因为资源问题前端介入较晚,全部联调好后离计划发布日还剩2天,这两天的功能测试时间里我们找出了大部分问题并解决了,完成了验收和发布。项目总共花了19个工作日,开发时间稍微延长,测试时间大大缩短,总的项目时间是缩短的。

  3)项目质量稳定

  发布后,后端遗留一个因线上、daily环境不一致导致的bug;前台遗留1个bug。在时间很有限的情况下,总体质量不错

  问题:

  UC、TC有一定的重复工作量,初次编写TC的开发工程师写得不太好且消耗时间略多

 2、C2B标准版(5.15-7.13,开发测试比4:0)。暴露一个问题

  因为第一个项目比较成功,所以第二个项目继续沿用上一次的自测模式,项目流程基本不变。

  效果:

  关键词还是前端资源紧张,全部联调好后只剩下1天的daily测试时间。因为前期各自自测做得比较充分,所以依旧是后端稳定,前端小问题比较多。花了1天修复完大部分前端问题后,按时发布。

  问题:

  此次需求点很多,时间又紧,人员配置全部都是开发的情况下,没有一个人能够关注到整体业务,对所有的业务逻辑能比较清晰。导致

  1)系统方面:后面新需求过来评估时,要花费更多的时间,潜在bug发生的可能性增加

  2)业务方面:用户体验,对PD新需求的控制力什么的,照顾不太到

  3)流程方面:UC略不规范,导致转化成TC不太方便,也不方便别人看,不方便验收和测试

  阶段2:开发自测,测试关注整体业务

  1、公益版2期(7.13-8.3,开发测试比4:1)

  2、合买版(10.19-11.3,开发测试比4:1)

  这两个项目又新增了开发资源,吸取了前两次的经验教训后,继续优化一下项目模式。

  优化点:

  1)项目里我不再担任开发人员,全职做测试;因为前面两个项目自测效果不错,所以依旧坚持开发自测的思路

  2)强化UC,弱化TC。开发不再编写TC,但要详细写好UC。由我负责写一些主流程TC和容易出错环节的TC

  弱化TC的原因:

  i.和UC有重复工作量

  ii.黑盒功能用例写得再多也不能保证全部覆盖

  iii.TC也是给开发自测参考用的。开发自测习惯是根据代码逻辑做功能测试,流程性的一般根据自己的UC进行自测,然后再覆盖一下TC上容易遗漏的点,基本能满足自测期望达到的目标

  3)增强代码review

  测试从前期就介入代码review中,避免项目后面大家一起review的工作量太大。项目代码略稳定后,我每天花在代码review上的时间至少占工作量的三分之一

  4)完善回归系统

  效果:

  1)测试能对整体业务点都很了解,并且能在前期就review出一些bug

  2)从时间上可以看出,项目时间都在一个月内。这里测试时间压缩了很多,两个项目提测到发布都只花了4天

 阶段3:开发自测,优化流程,释放测试资源

  合买版双12活动(11.23-12.6,开发测试比4:1)

  阶段2进行得比较顺利,于是接下来的项目继续在此模式基础上优化

  优化点:

  1)测试全程介入技术方案评审和代码review

  从技术方案开始介入,review sql、业务层代码、vm层代码

  2)更加关注系统性能方面的东西

  测试同学能有时间学习性能测试,并为系统进行了性能调优,为双12做好准备

  问题:

  前端代码尚无能力review。

  二、模式小结

  有些人疑惑,开发自测后,测试干什么?

  这就回到了开头提到的困扰。开发自测模式,能把开发和测试从低级bug中解放出来,开发可以提高代码质量,测试可以关注更深层次的系统质量(比如性能和代码优化等),整个团队能提升效率,进入良性循环。

  那么写了那么多,经历了半年多的探索,目前我们项目组到达了什么程度呢?从项目模式、效果和测试同学的角色3方面来描述一下。

  1、产出了一个被现实考验过的项目模式(当然还在继续优化中)

开发自测模式实践_第2张图片

  1)UC

  开发同学要写详细、标准的UC,方便后续测试和维护;测试同学根据UC简单得写一些TC,方便开发自测

  2)DAO层单测

  新增sql必须要写单测用例,修改sql必须要回归单测用例

  3)业务层单测

  已经有比较完善的单测环境,开发可以根据个人喜好,在manager层或ao层进行单测,无硬性要求

  4)代码review贯穿整个流程

  分为两类代码review,目前我们项目组两类并存

  i.测试同学主导的每日review

  项目里每天测试同学都会review开发提交的代码,这不仅仅是发现bug,目前我们的代码review已经能到优化代码或设计方案的阶段。例如:http://kelude.taobao.net/issues/206462?page=1

  ii.传统的项目组review

  在项目后期集中式得进行一两次review,有效果但量较大

  5)功能自测&验收

  功能自测开发根据UC和TC进行;验收是PD介入,页面有新需求可以及时改动

  6)整体测试

  主要由我来执行,进行主流程测试和随机测试,但不会覆盖所有点,其他功能点的质量开发同学自己保证

 2、效果

  1)工期缩短。这是最明显的,目前这几个项目的daily、预发测试时间加起来都没超过1周的

  2)质量提高。

  i.开发同学的代码质量提高了。以前测试同学都基本是保姆式的,现在测试介入得少了,遗漏bug会增加吗?刚开始开发会略感不适应,但长期来看对整个团队肯定是有益的

  ii.整个开发流程中,很多bug发现在前期,后期底层基本很稳定了

  3)释放测试资源

  目前我们团队的开发测试比是4:1,最高时是5:1。在开发大部分时间工作量饱和的情况下,测试资源基本能满足项目组需要

  4)周期快,能够满足一周多次发布的需求

  交易线标准的日常流程:上一周提需求,周五UC评审,下周二提测,周三预发,周四发布。1周发布1次

  目前我们日常主要靠 开发自测+代码review+脚本回归 保证质量,测试同学不用花太多精力进行功能测试。因此团队效率很高,甚至能达到一天一次的发布频率(当然发布多了不是好事)

  3、测试同学的任务

  从初级bug的痛苦中释放出来后,测试关注什么?

  1)业务方面

  了解整体业务和逻辑,review覆盖整个研发流程,包括技术方案、sql、业务代码、vm,做一个熟悉整个系统的角色

  2)持续回归

  这一直是测试同学的强项,维护一个成形的产品需要建立一套完善的回归体系

  3)其他方面

  系统性能?算法测试?单测回归?无线?随便,因为有时间有精力了,都可以去做

  三、展望。我们才刚开始

  明年测试策略需要怎样完善?产品在不断迭代,市场在不断增长,测试压力得到释放后,有更多的事等着我们去做。目前想到的有以下3点

  1)测试数据

  方便开发同学自测

  2)前端代码review

  这一直是痛点,前端没有成形的review机制。明年学习一下前端知识,希望在review上有所突破

  3)完善回归

  方便开发自测,最好开发能根据改动点进行定制的脚本回归

  做到了这些,就做成了一个完整的开发自测生态圈。明年继续努力!

你可能感兴趣的:(开发自测模式实践)