上一个帖子“软件工程进阶之每日构建[0]:概述”提到说每日构建是一种很牛X的软件工程手段。本帖子就来说说它到底有多牛X。为了加深大伙儿的印象,我先来说一些陈年往事。
话说上世纪末,我还在一家小公司干活,并参与开发了一个C++的项目。当时公司的流程是:开发人员写好代码,自己编译好,丢给测试人员测试;测试人员如果发现bug,口头通知开发人员改;开发人员改好bug,再丢给测试人员测试<!--program-think-->......
★案例1(开发的混乱)
有一天,开发组的小头目找来程序员甲。
>>小头目:你负责的XX功能完成了没有?
>>程序员甲:早做完啦!
>>小头目:那测试人员甲怎么说一直没看到XX功能?
>>程序员甲:不会吧!我去瞧瞧。
若干分钟后,程序员甲回来。
>>程序员甲:不好意思,编译好的EXE我只发给了测试人员乙,忘记发给测试人员甲了。
>>小头目:!@#$%^&*(此处省略15字)
★案例2(测试的混乱)
另一天刚上班。
>>测试人员甲:今天的XX.EXE怎么一运行就崩溃?
>>测试人员乙:有吗?我这儿好好的呀!
>>测试人员甲:真见鬼!我找开发问一下。
经过若干分钟打听,知道XX.EXE是程序员丙负责,于是找来程序员丙。
>>测试人员甲:为啥你做的XX.EXE一运行就崩溃?
>>程序员丙:有这回事?!让我看看你的环境。
程序员丙在测试人员甲的机器上研究了N刻钟后。
>>程序员丙:你是猪脑啊,你没有更新XXX.DLL,害我浪费这么长时间!
>>测试人员甲:你才是猪脑!我怎么知道XX.EXE会用到XXX.DLL?
然后两人开始对骂......
★案例3(集成的混乱)
临近项目交付了,开发人员都在忙着改bug,测试人员都在忙着复测bug,没有人手准备安装包,于是安装包的制作一直拖到项目交付的前一天才开始搞。制作安装包本身倒是很快,半天就搞定。但是......
>>小头目:做好的安装包应该没什么问题吧?
>>测试人员丙:呃,这个,这个......好像装出来的软件没法运行,直接崩溃了。
>>小头目:偶的神啊!还愣着干嘛,快去查原因!!!今天不搞定大家不许回家!!!
然后开发和测试通力协作,经过艰苦卓绝的努力,到了午夜时分,终于发现:有个DLL是Debug版本......
有同学可能会问:为啥平时测试的时候没发现这个问题捏?因为平时团队里面都使用Debug版本,方便ASSERT断言。到了作安装包那天,照道理应该统
一编译Release版本,但是有个家伙遗漏了,所以混了一个Debug版本的DLL在里面。等安装完运行程序时,该DLL动态加载失败,所以程序就崩溃
鸟。
我上面说的这些情形,到今天为止,还在很多公司内部上演。那为啥每日构建能搞定上面这些问题捏?且听我细细道来:
★针对“开发的混乱”
对于每日构建的流程,开发人员只要负责提交代码到代码库中。不需要挨个给测试人员提供编译后的二进制文件。因此案例1的问题(漏给测试文件)迎刃而解。
★针对“测试的混乱”
在开发阶段,由于测试拿到的程序都是自动编译出来的,因此保证了所有测试人员拿到的是统一的运行程序,并且这个程序和代码库中最新的代码是相对应的。
在测试阶段,每一个开发人员修复了Bug之后,都必须把改过的代码提交到代码库,测试人员才会拿到改过Bug的二进制程序。如果某个开发人员改了Bug但是不提交代码,那么在测试人员看来,相当于他的Bug一直没有改,因此他的Bug就一直不会被关闭。
所以案例2的情况也不会出现。
★针对“集成的混乱”
对于每日构建来说,每天都会产生安装包(或者安装光盘的ISO镜像)。也就是说,从项目开始开发的那天起,每天都在进行集成(这就是传说中的持续集成)。因此,集成的问题,在一开始就会暴露出来,而不用等到项目后期。
其实每日构建的好处除了上述三点(这三点我认为比较重要),还有其它很多,大伙儿可以自己再琢磨一下。后面一个帖子,我把每日构建需要的准备工作介绍一下。
http://program-think.blogspot.com/2009/02/daily-build-1-advantage.html
分享到:
相关推荐
进阶 1:HEAD、master 与 branch 学习时长: 15分41秒 6 进阶 2:push 的本质 学习时长: 4分36秒 试学 7 进阶 3:merge:合并 commits 学习时长: 11分9秒 8 进阶 4:Feature Branching:最流行的工作流 学习时长: 8分...
IIS 6.0入门及进阶系列课程之六:应用程序层协议揭秘——HTTP和FTP
《Netty进阶之路:跟着案例学Netty》中的案例涵盖了Netty的启动和停止、内存、并发多线程、性能、可靠性、安全等方面,囊括了Netty绝大多数常用的功能及容易让人犯错的地方。在案例的分析过程中,还穿插讲解了Netty...
Java进阶技术-netty进阶之路
GEF示例 博文链接:https://xyhsm.iteye.com/blog/67809
进阶 1:HEAD、master 与 branch 学习时长: 15分41秒 6 进阶 2:push 的本质 学习时长: 4分36秒 试学 7 进阶 3:merge:合并 commits 学习时长: 11分9秒 8 进阶 4:Feature Branching:最流行的工作流 学习时长: 8分...
Java工程师进阶之路,罗列学习曲线,一文全懂java进阶
- **软件工程**:理解软件开发生命周期,包括需求分析、设计、编码、测试和维护。 - **架构设计**:掌握模块化、分层架构、微服务等设计模式,以处理复杂性。 - **并发与多线程**:处理多任务并行,理解线程同步...
C/C++实践进阶之道:写给程序员看的编程书 part 1 of 2
《Netty进阶之路-跟着案例学Netty》是由知名技术专家李林峰撰写的一本专为Java开发者深入理解Netty框架而准备的书籍。这本书旨在通过实例教学,帮助读者全面掌握Netty的核心特性和实战技巧,提升网络编程的能力。 ...
职场进阶之如何构建和提高战略规划的十大核心能力.pptx
Netty进阶之路 跟着案例学Netty 整本书无密码,Netty进阶之路 跟着案例学Netty