敏捷开发流程总结

敏捷开发流程总结

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

Agile——敏捷开发,作为CMM神话崩溃后被引入的一套新的软件开发模式,这几年来被广泛引起关注,并被寄予厚望。敏捷开发在其它业界的应用是否理想不得而知,但下面总结了我所在公司的敏捷开发试验,希望能够达到管中窥豹的目的。

敏捷开发宣言——
个体和交互 胜过 过程和工具
能够工作的软件 胜过 面面俱到的文档
客户合作 胜过 合同谈判
响应变化 胜过 遵循计划
尽管右项也有价值,可是我们觉得左项具有更大的价值。

以上的宣言比較抽象,基于该理念,下面是ThoughtsWork咨询公司的推崇的n个敏捷开发实践:
Iteration
迭代开发。能够工作的软件胜过面面俱到的文档。因此,敏捷开发提倡将一个完整的软件版本号划分为多个迭代,每一个迭代实现不同的特性。重大的、优先级高的特性优先实现,风险高的特性优先实现。在项目的早期就将软件的原型开发出来,并基于这个原型在兴许的迭代不断晚上。迭代开发的优点是:尽早编码,尽早暴露项目的技术风险。尽早使客户见到可执行的软件,并提出优化意见。能够分阶段提早向不同的客户交付可用的版本号。
IterationPlanningMeeting
迭代计划会议。每一个迭代启动时,召集整个开发团队,召开迭代计划会议,全部的团队成员畅所欲言,明白迭代的开发任务,解答疑惑。
Story Card/Story Wall/Feature List
在每一个迭代中,架构师负责将全部的特性分解成多个Story Card。每一个Story能够视为一个独立的特性。每一个Story应该能够在最多1个星期内完毕开发,交付提前測试(Pre-Test)。当一个迭代中的全部Story开发完毕以后,測试组再进行完整的測试。在整个測试过程中(pre-test,test),基于Daily build,測试组永远都是每天从配置库上取下最新编译的版本号进行測试,开发者也随时改动測试人员提交的问题单,并合入配置库。
敏捷开发的一个特点是开放式办公,充分沟通,包含測试人员也和开发者一起办公。基于Story Card的开发方式,团队会在开放式办公区域放置一块白板,上面粘贴着全部的Story Card,按当前的开发状态贴在4个区域中,各自是:未开发,开发中,预測试中,測试中。Story Card的开发者和測试人员依据开发进度在Story Wall上移动Story Card,更新Story Card的状态。这样的方式能够对项目开发进度有一个非常直观的了解。
在开发者開始开发一个Story时,ta须要找来相应的測试人员解说Story功能,以便測试人员有一致的理解,同一时候開始自己主动化系统測试脚本的开发。
Standup Meeting
站立会议。每天早上,全部的团队成员围在Story Wall周围,开一个高效率的会议,通常不超过15分钟,汇报开发进展,提出问题,但不浪费全部人的时间立马解决这个问题,而是会后个别沟通解决。
Pair Programming
结对编程是指两个开发者结对编码。结对编程的优点是:经过两个人讨论后编写的代码比一个人独立完毕会更加的完好,一些大的方向不至于出现偏差,一些细节也能够被充分考虑到。一个有经验的开发者和一个新手结对编程,能够促进新手的成长,保证软件开发的质量。
CI/Daily Build
持续集成和每日构建能力是否足够强大是迭代开发是否成功的一个重要基础。基于每日构建。开发者每天将编写/改动的代码及时的更新到配置库中,自己主动化编译程序每天至少一次自己主动从配置库上取下代码,执行自己主动化代码静态检查(如PCLint),单元測试,编译版本号,安装,系统測试,动态检查(如Purify)。以上这些自己主动化任务执行完毕后,会输出报告,自己主动发送邮件给团队成员。假设当中存在着不论什么的问题,相关责任人应该及时的改动。
能够看到,整个开发组频繁的更新代码,出现一些问题不可避免。通过測试部又在不停地基于最新的代码进行測试。新增的问题能否够被及时发现并消灭掉,取决于自己主动化单元測试和系统測试能力是否足够强大,特别是自己主动化系统測试能力。假设自己主动化測试仅仅能验证最简单的操作,则新合入代码的隐患将非常难被发现,并遗留到项目后期,形成大的风险。而实际上,提升自己主动化測试的覆盖率是最困难的。
Retrospect
总结和反思。每一个迭代结束以后,项目组成员召开总结会议,总结好的实践和教训,并落实到兴许的开发中。
ShowCase
演示。每一个Story开发完毕以后,开发者叫上測试人员,演示软件功能,以便測试人员充分理解软件功能。
Refactoring
重构。由于迭代开发模式在项目早期就开发出可执行的软件原型,一開始开发出来的代码和架构不可能是最优的、面面俱到的,因此在兴许的Story开发中,须要对代码和架构进行持续的重构。迭代开发对架构师要求非常高。由于架构师要将一个完整的版本号拆分成多个迭代,每一个跌倒由拆分成非常多Story,从架构的角度看,这些Story必须在是有非常强的继承性,是能够不断叠加的,不至于兴许开发的Story全然推翻了早期开发的代码和架构,同一时候也不可避免的须要对代码进行不断完好,不断重构。
TDD
測试驱动开发。正如上面讲的,迭代开发的特点是频繁合入代码,频繁公布版本号。測试驱动开发是保证合入代码正常执行且不会在后期被破坏的重要手段。这里的測试主要指单元測试。

敏捷方法反思:
自己參与的敏捷开发项目总的来说不是非常成功,这可能也是业界遇到的通病:
1、对于全新的软件,在项目早期測试人员就參与并实现自己主动化測试脚本,但实际上软件的界面等非常不稳定,导致測试人员返工的工作量非常大。
2、对于全新的软件,资料人员过早參与,后期返工工作量大,原因同第一点。
3、自己主动化系统測试工作量大,測试人员投入大量的精力在使測试自己主动化起来,而没有足够的精力放在真正的測试软件的功能是否正常。即便是这样,自己主动化系统測试脚本也多流于形式,測不出深层次的问题。
4、代码动态检查工具执行不理想,流于形式。没有人对Purify有深刻的理解和应用经验,报告中查出来非常多告警,但不知怎样消除。
5、由于高速搭建原型,没有在架构上进行严谨的设计,导致后期一直堆砌代码。
6、异地开发模式下无法实现高速构建、高速交付,团队普遍感觉非常疲惫。
7、敏捷开发不提倡加班,但实际上无论是CMM还是Agile哪一种开发模式跟是否加班都没有必定联系。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/118782.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • groupby函数详解

    groupby函数详解pandas中groupby函数用法详解1groupby()核心用法2groupby()语法格式3groupby()参数说明4groupby()典型范例1groupby()核心用法(1)根据DataFrame本身的某一列或多列内容进行分组聚合,(a)若按某一列聚合,则新DataFrame将根据某一列的内容分为不同的维度进行拆解,同时将同一维度的再进行聚合,(b)若按某多列聚合,则新D…

  • bug生命周期流程_bug六大要素

    bug生命周期流程_bug六大要素你们公司是如何管理bug的?考查点:缺陷的生命周期常见的流程就不多说了,CSDN上有很多,今天说一些不一样的点:正常流程:打开–接受–已解决-关闭其它状态:拒绝、重新打开、遗留1、线上的bug优先级最高,会要求测试leader亲自协助运营、开发人员定位,邮件报告相关领导:bug分析、开发人员如何修改,有哪些影响范围,bug修改进度,开发和测试的改进措施;2、测试环境的典型b…

    2022年10月20日
  • 回溯算法 js_回溯算法代码

    回溯算法 js_回溯算法代码回溯算法是算法设计中的一种回溯算法是一种渐进式寻找并构建问题解决方式的策略回溯算法会先从一个可能的动作开始解决问题,如果不行,就回溯并选择另一个动作,直到将问题解决使用场景有很多路在这些路中,有死路和出路通常需要递归来模拟所有的路leetcode46:全排列解题思路要求:1所有排列情况;2没有重复元素有出路有死路使用回溯算法解题步骤用递归模拟出所有情况遇到包含重复元素的情况,就回溯收集所有到达递归终点的情况,并返回code//时间复杂度O.

  • Java 继承(extends)详解

    Java 继承(extends)详解一、继承问题的引出继承性是面向对象的第二大主要特征。下面首先编写两个程序:Person类、Student类。Person类:classPerson{privateStringname;privateintage;publicvoidsetName(Stringname){

  • linux x11vnc,X11vnc (简体中文)[通俗易懂]

    linux x11vnc,X11vnc (简体中文)[通俗易懂]WARNING:这将建立一个没有密码的VNC.意思是任何人都可以通过网络访问你的VNC并且能看到你的X界面.可以非常简单的通过SSH连接来避免这样的事情.设置x11vnc安装pacman-Sx11vnc运行首先你需要运行一个xserver服务器.使用startx或类似的.完成后运行startxx11vnc-display:0-auth~/.Xauthority如果失败,你…

    2022年10月23日
  • springaop面向切面编程_简述面向切面编程思想

    springaop面向切面编程_简述面向切面编程思想Spring理论基础-面向切面编程

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号