前言:在 上一篇 TFS2015敏捷开发实践 中,我们给大家介绍了TFS2015中看板的基本使用和功能,这一篇中我们来看一个具体的场景,如何使用看板来运行一个sprint。Sprint是Scrum对迭代的称谓,也是Scrum中团队协作的一个迭代单元,包含了Scrum中最主要的活动,我们来看看如何使用看板来支持这些活动。
TFS 2015中对看板功能进行了大量改进。我们可以通过对列,泳道,展示样式及卡片内容进行定制,使TFS看板具有更强的展示效果与可操作性。本篇博文中我就对TFS 看板进行了一些深度定制,以实现敏捷团队在TFS 2015看板上完成一个Scrum的Sprint。
团队介绍
团队组成:
- 产品负责人: 1名
- Scrum Master: 1名(团队成员轮流兼任)
- 开发团队成员: 8名(5开发,3测试)
迭代周期:2周,10个工作日
团队平均速率:100(每个迭代完成100工作量的积压工作)
注:在敏捷团队创建之初,确定一个迭代的周期对于敏捷团队是最重要的。 迭代周期不是越短越好,迭代周期的选定包含很多要素:
- 团队能交付一定量的产品增量
- 产品负责人能承诺的不改变已经进行计划的积压工作的最长时间
- 测试资源
- 其他因素
Scrum事件发生时间:
迭代计划会议:迭代第一个工作日上午召开(星期二 9:30 )
每日站立会议:每日早上9:45到10点
迭代评审会议:迭代最后一个工作日下午召开 (星期一),选在周一下午召开是因为我们有一个周末的时间可以处理紧急问题
迭代回顾会议:迭代最后一个工作日下午评审会议完成后召开(星期一)
看板样式如下:
这里对我所使用的看板进行一下简单说明:
- 采用6列:新建,当前迭代(会在迭代计划会议中将本迭代需要完成的PBI和Bug放入此列),开发,测试,发布(此列可选),完成。 其中当前迭代对应状态New, 开发对应状态Approved,测试与发布对应状态Committed。
- 关于WIP,当前迭代列为每个迭代的平均完成积压工作数量;开发、测试列的WIP采用资源数*2-1的方法来计算,比如:开发WIP为 5(开发人员)*2-1 = 9。
- 采用Bug与PBI双泳道,并且Bug泳道在PBI泳道之上。我这样设计是为了说明Bug的处理优先级应该高于PBI,处于当前迭代下游的开发人员,应该优先解决当前迭代列中的Bug。在显示效果上也更醒目。
- 启动在开发、测试与发布列中的缓冲区,就是每个列下面的Doing和Done。因为大家都知道在看板中是采用拉动式生产方式,团队成员应该从自己所处列的上游拉取卡片到自己的工作列中。因此我们在TFS配置中启动列的缓冲区,这样可以明确的告知我们的下游团队成员哪些卡片使能够被拉取。比如:如果开发列中的卡片处于Done中,那么表示开发工作已经完成,测试人员可以对这些PBI或者Bug进行测试。
启动一个迭代
在迭代计划会议开始之前我们的产品负责人一定要提前整理好团队积压工作列表,包括录入积压工作及按照商业价值/紧迫程度为积压工作排序。这部份工作一定要在开始迭代计划会议之前完成,不然会大大的降低会议效率。
迭代计划会议
最左侧是由产品负责人整理的挤压工作列表,优先级由上到下。那下面我们要确定这个Sprint我们要完成哪些工作:
- 先由产品负责人将最顶的积压工作拖拽到 当前迭代中,并设置字段 迭代路径
- 开发团队对工作量进行预估,同时让团队成员认领积压工作。关于工作量也多说两句:工作量与工时是量化完成工作的两个维度。工时很好理解就是完成积压工作需要耗费的单位时间,工作量是一个没有单位的数值,预估的方式为:在积压工作列表中选取一个最简单的积压工作,然后将工作量预估为1,其他的积压工作的工作量与这个相比较。 工作量数值一般采用近似于斐波那契数组的值:1,3,5,8,13,20,40,60,100。在TFS中工作项的工作量在积压工作项中设置,而所需工时需要在由积压工作项分解出的任务中设置。
- 与产品负责人一同确定验收标准
- 按照优先级依次将新建的积压工作项拖拽到当前迭代列,直到积压工作项的工作量达到饱和。
关于开发团队每个迭代的工作量总和可以通过TFS的Sprint 速率报表(Velocity)查看以往迭代的完成速率来确定。
- 确定如何完成这些积压工作。细化需求,将积压工作项分解为任务。如果一个积压工作不能在一天内完成,我们又想知道每天的工作进度,可以将积压工作分解为任务,通过任务来跟踪团队成员每日的工作情况
每日站立会议
按照先开发人员再测试人员的顺序,每个团队成员只需要回答3个问题:
- 昨天做了什么? 完成了哪个积压工作或者任务。 如果积压工作完成,将积压工作从开发拖入到测试正在进行中
- 如果该团队成员完成了工作,将卡片从当前列的Doing移动到Done,表示此工作在当前阶段已经完成。
- 如果团队成员未完成整个PBI只是PBI分解出的任务,可以通过勾选卡片中任务前的勾选框来标记,任务已经完成,系统会自动将任务状态改为Done。这样我们可以通过任务来跟踪团队成员每天的工作及PBI的工作进度。
- 今天要做什么?该团队成员只需要从自身角色所在流程的上游获取新的卡片即可,比如开发人员在当前迭代中拉取新的PBI或者Bug到开发列的Doing中;测试人员将开发列Done中的PBI拖拽到测试的Doing进行测试
- 遇到了哪些问题?千万不要在站立会议上寻求问题的解决方案,这会占用团队的大量时间,只需要告诉大家你有什么问题就可以了。
如果我们每个列的卡片过多,每个团队成员在站立会议过程中只想展示自己的卡片怎么办?可以使用看板中的快速搜索功能
迭代评审会议 & 迭代回顾会议
- 向产品经理交付在测试完成列中的积压工作,不在新建与发布列Done列中的其他工作项当前Sprint未完成积压工作。
- 根据接受标准向产品负责人展示交付物,如果产品负责人接受交付,将积压工作项拖入完成列。
- 如果产品负责人不接受,开发团队同意下个迭代进行修改,可以添加标签注明是哪个迭代的积压工作,并在下个迭代计划会议中将积压工作项拖拽到当前迭代中
对于迭代评审会议的其他事件与迭代回顾会议,由于不涉及看板就不在这里赘述了。在本文中大家可以看到如何使用TFS看板来完整的运行一个Scrum迭代,下个帖子我将向大家讲述怎样在TFS平台上提高我们的源代码开发效率。
请关注微信公众号 【devopshub】,获取更多关于DevOps研发运维一体化的信息
TFS 2015 敏捷开发实践 – 在Kanban上运行一个Sprint的更多相关文章
-
TFS 2015 敏捷开发实践 – 看板的使用
看板在现代应用开发过程中使用非常广泛,不管是使用传统的瀑布式开发还是敏捷开发,都可以使用看板管理.因为看板拥有简单的管理方法,直观的显示方式,所以很多软件开发团队选择使用看板进行软件开发管理.本文不在 ...
-
微服务与敏捷开发(Scrum/Kanban)的核心思想之我见
微服务与敏捷开发(Scrum/Kanban)的核心思想之我见 关于"微服务"和"敏捷开发"的文章网络上有很多,所以这里不再重复叙述这些概念的解释和特点,而是 ...
-
[敏捷开发实践](2) 用于开发和维持复杂产品的敏捷开发框架Scrum
[敏捷开发实践](2) 用于开发和维持复杂产品的敏捷开发框架Scrum 1,Scrum概述 上篇中提到敏捷开发有两种主流的方法,一个是XP,另一个是Scrum,本篇简要介绍Scrum方法.Scrum是 ...
-
环信联合创始人: Saas敏捷开发实践!
马晓宇 --环信联合创始人/执行总裁 我们是一个做云服务的创业公司,所以我就云服务创业公司的角度,来谈谈我们是怎么去实践敏捷开发的.确切地说,就是讲讲我们这几年的这些教训... 1-创业公司敏捷开发流 ...
-
《HP大规模敏捷开发实践》读书笔记
读这本书的心得,敏捷是实践出来的,哪怕不懂srcum**等方法,只要坚持心中的价值观,朝一个方向改进,哪怕不能“任何时候都拥有符合发布要求的代码”,今天比昨天好,也是成功. 通过业务分析确定开 ...
-
WePY - 小程序敏捷开发实践丨掘金开发者大会
声明:内容转载他处,如有侵权,可协商下架 本主题虽然在其它地方讲了很多次,但还是有非常多新内容.因为很多东西正在做或者想要做.本次分享主要分为以下几个部分: WePY 的介绍 WePY 的用户 上面展 ...
-
92.vue---新手从本地项目开发到服务器线上运行爬坑。
因为我做的是后台,所以不用做SEO 参考 本项目的定位是后台集成方案,不太适合当基础模板来进行二次开发.因为本项目集成了很多你可能用不到的功能,会造成不少的代码冗余.如果你的项目不关注这方面的问题,也 ...
-
在 Docker 上运行一个 RESTful 风格的微服务
tags: Microservice Restful Docker Author: Andy Ai Weibo:NinetyH GitHub: https://github.com/aiyanbo/d ...
-
现在k8s新版里,如何在每个node上运行一个带privileged的daemonset
以前,我们会在kubelet上加--allow-prividged启动参数来实现. 而现在,更推荐的是用pod secureity policy来实现.前面的那种方式以后会被废弃. https://k ...
随机推荐
-
Javascript里的那些距离们
1.有滚动条的控件的距离: scrollTop和scrollLeft:分别指有滚动条的容器控件的滚动条的top和left:页面滚动条的通用取法:document.body.scrollTop(FF\C ...
-
Codecademy For Python学习笔记
一.Python Lists and Dictionaries: 1. 2.
-
MySQL基础操作命令
MySQL基础操作命令 1. 查看MySQL进程 ps -ef|grep mysql |grep -v grep 2. 查看MySQL端口 ss -lnt | grep 3306 3. MySQL的启 ...
-
利用CentOS系统IPtables防火墙添加网站IP白名单
参考博文: 利用CentOS系统IPtables防火墙添加360网站卫士节点IP白名单 centos6.5添加白名单如下: 在防火墙 配置文件中加入白名单 ip -A INPUT -s 183.13 ...
-
python 性能- and-or 学习技能
C语言类似表情: bool ? a : b ,当表达式值为真的话,值为a.否则为b. 看一个样例: >>> a = "first" >>> b ...
-
centOS7 mini配置linux服务器(一)安装centOs7
1. 准备centos-7 (minni镜像) 官网地址http://isoredirect.centos.org/centos/7/isos/x86_64/CentOS-7-x86_64-Minim ...
-
bzoj 1188 [HNOI2007]分裂游戏 SG函数 SG定理
[HNOI2007]分裂游戏 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1394 Solved: 847[Submit][Status][Dis ...
-
深入理解JVM(四)——垃圾回收算法
我们都知道java语言与C语言最大的区别就是内存自动回收,那么JVM是怎么控制内存回收的,这篇文章将介绍JVM垃圾回收的几种算法,从而了解内存回收的基本原理. stop the world 在介绍垃圾 ...
-
Cookie的存活时间
1. 默认情况下,cookie数据保存到内存里,当浏览器关闭后,Cookie数据被销毁 2. 持久化存储: setMaxAge(int seconds) 1. 正数:将Cookie数据写到硬盘的文件中 ...
-
BZOJ.4919.[Lydsy1706月赛]大根堆(线段树合并/启发式合并)
题目链接 考虑树退化为链的情况,就是求一个最长(严格)上升子序列. 对于树,不同子树间是互不影响的.仿照序列上的LIS,对每个点x维护一个状态集合,即合并其子节点后的集合,然后用val[x]替换掉第一 ...