敏捷开发流程:

1、我们首先需要确定一个Product Backlog(按优先顺序排列的一个产品需求列表),这个是由Product Owner 负责的;

2、Scrum Team根据Product Backlog列表,做工作量的预估和安排;

3、有了Product Backlog列表,我们需要通过 Sprint Planning Meeting(Sprint计划会议) 来从中挑选出一个Story作为本次迭代完成的目标,这个目标的时间周期是1~4个星期,然后把这个Story进行细化,形成一个Sprint Backlog;

4、Sprint Backlog是由Scrum Team去完成的,每个成员根据Sprint Backlog再细化成更小的任务(细到每个任务的工作量在2天内能完成);

5、在Scrum Team完成计划会议上选出的Sprint Backlog过程中,需要进行 Daily Scrum Meeting(每日站立会议),每次会议控制在15分钟左右,每个人都必须发言,并且要向所有成员当面汇报你昨天完成了什么,并且向所有成员承诺你今天要完成什么,同时遇到不能解决的问题也可以提出,每个人回答完成后,要走到黑板前更新自己的 Sprint burn down(Sprint燃尽图);

6、做到每日集成,也就是每天都要有一个可以成功编译、并且可以演示的版本;很多人可能还没有用过自动化的每日集成,其实TFS就有这个功能,它可以支持每次有成员进行签入操作的时候,在服务器上自动获取最新版本,然后在服务器中编译,如果通过则马上再执行单元测试代码,如果也全部通过,则将该版本发布,这时一次正式的签入操作才保存到TFS中,中间有任何失败,都会用邮件通知项目管理人员;

7、当一个Story完成,也就是Sprint Backlog被完成,也就表示一次Sprint完成,这时,我们要进行 Srpint Review Meeting(演示会议),也称为评审会议,产品负责人和客户都要参加(最好本公司老板也参加),每一个Scrum Team的成员都要向他们演示自己完成的软件产品(这个会议非常重要,一定不能取消);

8、最后就是 Sprint Retrospective Meeting(回顾会议),也称为总结会议,以轮流发言方式进行,每个人都要发言,总结并讨论改进的地方,放入下一轮Sprint的产品需求中;

user story 定义:

Story就是一个可测试的小功能点(Story:功能点=1:1)、或者是多个继承性的小功能点组成的一个Story(Story:功能点=1:N)、或者是一个无法再分割的功能点(再分割这个功能点就无法进行测试了)包含多个Story(Story:功能点=N:1)。

1、Story

Story最原始的目的是指导开发工作量的划分,Story是将一个大的特性划分成小颗粒度的功能块,方便分配工作量,以便获得快速反馈;

2、特性:

敏捷中的特性类似于在双V模型或者其他模型中的子系统、子模块或者说是较大的功能模块,是由很多的功能块组成的,一个特性是耦合度很高的子模块;

3、功能块:

敏捷中的功能块类似于双V模型或者其他模型中的较小的模块,从子模块里划分出来的较小的功能模块,是由很多的功能点组成的;

4、功能点:是不可再分割的可测试的小功能模块;

5、特性团队

特性团队是指由设计人员、开发人员、测试人员、资料人员、特性团队组长等人一起组成的一个完整的团队(7人左右),特性团队是按特性进行划分的团队,团队成员对该特性的交付全权负责

6、头脑风暴

由特性团队中所有成员一起就一个Story的方案、设计、用例设计验收标准等内容而进行的团队中的讨论会,以澄清Story的设计,用例,测试验收标准等;

7、Story验收标准

每一个Story都需要在进行头脑风暴时,由团队里的人一起制定该Story的验收标准;

Story划分时以测试功能点作为依据,实现Story与功能点的融合,测试时基于功能点进行设计测试用例,开发基于Story进行开发。

最新文章

  1. java.net.ConnectException: Connection timed out
  2. activity通过onActivityResult间数据交互
  3. 创建Struct2的web应用(一)
  4. Uiautomator ——API详解
  5. Inside The C++ Object Model - 01
  6. 安全攻城狮研发技能栈V1.0,附详细点评~
  7. qt 焦点设置策略
  8. 重读《Struts In Action》
  9. Linux 进行反编译 或者 汇编
  10. C#中调用WIN32的API
  11. 解决方案-Microsoft Visual Studio 2012 已停止工作
  12. lnux内核的malloc实现(Oracle的cache buffer影子)
  13. Instance of 的用法
  14. RabbitMQ之消费者Demo(队列参数详细说明)
  15. 个人整理方幂和公式(∑i^k 公式)
  16. MapReduce实现PageRank算法(邻接矩阵法)
  17. ios NSTimer的强引用问题
  18. CentOS 7安装新版RabbitMQ解决Erlang 19.3版本依赖
  19. Isomorphism 同构
  20. 20165202 Mypwd

热门文章

  1. python之xml模块
  2. Python中的sys.path.append()
  3. Flask实战-留言板-使用Faker生成虚拟数据
  4. java static关键字和代码块
  5. 【vue】清理代码
  6. Swagger结合mustache模板生成后台接口代码、以及前后台建模代码
  7. leetcode 最后一个单词的长度 python
  8. jQuery实现input框输入值动态搜索
  9. 关于微信unionid理解
  10. 2019/4/18 wen 线程