当敏捷开发遇上了千年老怪的老系统....

敏捷开发中,当必需和没文档,没单元测试的老系统共舞时,就宛如是一场陷入泥沼的恶战、恶梦...... 

在敏捷开发中,当必需和老系统奋战时,光只是 “看” 老系统的源代码,不仅耗时,耗尽体力,更是完全无效的;完全无法梳理清楚老系统中的业务、代码逻辑与相互间的依赖。

这世上永远是极复杂的问题,却只需极简单的解决方案……

① 将在老系统上所需做的事;如:搬迁老系统的业务到新系统上,在老系统上加新特性、新功能……;均划分成 User Stories。

② 依照每个 User Story的目的,“直接” 修改老系统上的源代码。

③ 编译、执行老系统;此时应该会出现许多 “执行错误”。

这些编译、执行上错误的信息,将会是最珍贵的线索; 能让我们知道,要在老系统上完成所需的 User Story 开发, 则所需的 “前置条件”、“依赖”、“业务流程 (逻辑)" 是什么 ?。

“要搞懂老系统,便必需要与老系统的源代码做第一类的接触;直接修改老系统的源代码;别只是“看” 源代码。”

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏张善友的专栏

Miguel de Icaza 细说 Mix 07大会上的Silverlight和DLR

Mono之父Miguel de Icaza 详细报道微软Mix 07大会上的Silverlight和DLR ,上面还谈到了Mono and Silverligh...

3037
来自专栏Ceph对象存储方案

Luminous版本PG 分布调优

Luminous版本开始新增的balancer模块在PG分布优化方面效果非常明显,操作也非常简便,强烈推荐各位在集群上线之前进行这一操作,能够极大的提升整个集群...

3725
来自专栏pangguoming

Spring Boot集成JasperReports生成PDF文档

由于工作需要,要实现后端根据模板动态填充数据生成PDF文档,通过技术选型,使用Ireport5.6来设计模板,结合JasperReports5.6工具库来调用渲...

1.5K7
来自专栏我和未来有约会

Kit 3D 更新

Kit3D is a 3D graphics engine written for Microsoft Silverlight. Kit3D was inita...

2956
来自专栏一个会写诗的程序员的博客

Spring Reactor 项目核心库Reactor Core

Non-Blocking Reactive Streams Foundation for the JVM both implementing a Reactiv...

2902
来自专栏我和未来有约会

Silverlight第三方控件专题

这里我收集整理了目前网上silverlight第三方控件的专题,若果有所遗漏请告知我一下。 名称 简介 截图 telerik 商 RadC...

4435
来自专栏杨龙飞前端

scrollto 到指定位置

2994
来自专栏陈仁松博客

ASP.NET Core 'Microsoft.Win32.Registry' 错误修复

今天在发布Asp.net Core应用到Azure的时候出现错误InvalidOperationException: Cannot find compilati...

5318
来自专栏魂祭心

原 canvas绘制clock

5214
来自专栏张善友的专栏

LINQ via C# 系列文章

LINQ via C# Recently I am giving a series of talk on LINQ. the name “LINQ via C...

3045

扫码关注云+社区