千家信息网

软件集成策略故事连载----构建错误是怎么来的

发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,3.构建错误是怎么来的晓川在回到工位的路上,回想着跟老刘的谈话,心中感慨万千。老刘并不是去指责我,甚至不是命令或要求我,而是请我帮忙。对于我不成熟的想法,他没有贬低,甚至没有告诉我应该怎样做,而是让我
千家信息网最后更新 2025年02月01日软件集成策略故事连载----构建错误是怎么来的

3构建错误是怎么来的


晓川在回到工位的路上,回想着跟老刘的谈话,心中感慨万千。老刘并不是去指责我,甚至不是命令或要求我,而是请我帮忙。对于我不成熟的想法,他没有贬低,甚至没有告诉我应该怎样做,而是让我继续想,提示我要多调查。

回到工位,晓川跟师父聊起这些。师父说:"老刘当然没法命令你了。他只是项目经理,不是你部门经理。他要是敢指责你,你就跟咱们领导说,有人给你撑腰。至于他不告诉你该怎么做,那要么是他也不知道,要么是他不愿意从他嘴里说出来。这人一看就是个老油条,你小心点儿。 "

"谢谢师父提醒。 "

都说公司里面有办公室政治,看来确实是这样啊,晓川心想。师父年长我很多,这方面我要多听听他怎么说。不过,到底为什么构建总是出错呢?老刘说得也对,我得调查分析一下才能知道。

晓川着手调查。就以上个星期刚做完的集成为例吧。每次构建出错,我是定位到出错的源文件,然后通过源代码版本控制工具查一下这个文件昀近是谁动过,然后就找相应的程序员去改正,然后把改正直接检入到集成分支。嗯,那我去看一下在集成期间,是谁把改正检入到集成分支上的,就能知道是谁的提交造成了问题。

晓川去查看源代码版本控制工具的版本库中集成分支上昀近所做的改动。咦,都是晓川改的……哦,是因为程序员都是跑到我的计算机上改的,所以都是以我的名义检入的。唉,这么查,查不出来了。

晓川只好根据每次改动所改的具体文件去查。因为修改这个文件,让编译能通过,那意味着这个文件的前一次改动是有问题的。这样,再去查这个文件当初是谁在哪个任务分支上改的,就能知道是谁在哪儿惹的祸了。

就这样,晓川用了大半天的时间,到快下班的时候,整理出了一张表,表明这次集成遇到的每个构建错误,各是由谁,在哪个提交中带进来的。下班啦!

下了班,晓川在外面随便买了点东西吃。吃着吃着,觉得不对劲儿。倒不是吃的东西不对劲儿,而是想起了自己下班前的工作成果,觉得不对劲儿。

每个构建错误,确实是某个提交带来的,确实是因为某个提交的存在而存在的。如果没有那个提交,就没有相应的构建错误。但是,这并不能说,这个提交本身是有问题的,是有构建错误的。因为程序员在提交前构建的内容,并不是我构建的内容。我构建的内容,是多个提×××并到一起之后的内容。

事实上,这正是老刘质疑我的地方。"如果程序员的提交都没问题,你确定你构建的时候就肯定没问题么?"我那时也觉得有点不对劲儿,自己的思路不严谨。怎么今天下午调查的时候又给忘了!不成,我得继续研究清楚。不然一周后,新的一轮构建又要开始了,就顾不上了。

星期二上班,晓川来到工位,解锁计算机,开始复现程序员在提交前的环境。这个比较简单,因为程序员工作在任务分支上,在提交前把所有要提交的内容都保存在任务分支上,所以,只要把任务分支末端的源代码取出来,放到本地工作区里,就得到程序员在提交前的环境了。

在这样的工作区里,晓川开始编译构建。构建要一个多小时的时间,因为没法做增量构建,只能全量构建。一个多小时后,构建结果出来了,构建是成功的!

晓川又做了几个试验。结果不尽相同。有的是成功的,有的报错。虽然不能完全确定,但是凭记忆,应该就是在集成分支上构建时报的错。这么说,集成分支上构建报错,有两种可能,一种是提交本身的问题,一种是几个提交相互合并带来的问题。在数量上,大概是一半儿一半儿。

得到了分析结果,晓川觉得挺有成就感。高兴的时候想想,嗯,集成这工作呢,其实也挺轻松的,因为大部分时间都在等。等着程序员解决代码合并冲突,等着构建。构建失败了,等着相关的程序员修复。而有时候是大家一起陪着等。等着把提交的代码都合并到集成分支,相关的程序员们才能回家。等出了基线,依赖于基线中内容的新的任务才能开始。等着等着,时间就等过去了。青春就等过去了。

本文节选自《软件集成策略》一书

董越 .
电子工业出版社出版。


分支 程序 程序员 问题 内容 错误 任务 文件 老刘 工作 不对 劲儿 师父 时候 时间 调查 工位 源代码 版本 结果 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 非正式沟通网络技术式 深圳市往悦互联网科技有限公司 双城软件开发项目管理 对信息网络安全的认识 宝山区会计软件开发收费标准 宁波软件开发公司 如何删除两列重复的数据库 婚礼桁架软件开发 云服务器安全卫士能对布丁升级 如何开发数据库服务器程序 计算机科学涉及网络安全吗 信息基础设施网络安全应急演练 网络安全专网规范 福建多功能软件开发联系方式 互联网是否属于科技股 重庆七星网络技术有限公司 业内较好的定制软件开发 科大讯飞软件开发工程师收入 笔记本做服务器配置 大华云数据库账户密码 服务器上网英文 软件开发知识产权的 约定 h1z1北美服务器ip emp 数据库是什么意思 读软件开发哪所大学好 河北it软件开发哪家好 国际服无法连接过期的服务器 有线电视的服务器 软件开发项目管理表 大专学计算机网络技术可以吗
0