一种新的代码组织办法 feature flow

当前大部分团队都使用git flow流程管理代码(不了解gitflow的朋友可以自行搜索),以我们团队的状况来看,一个产品的开发初期是比较适合用git flow的,因为初期都是在做功能添加,而且人比较少,每个迭代只更新一个或几个完整的功能。到了后期的功能调整阶段,git flow就不太适用了,人员多了就可以做更多的事,可能有多个模块需要调整,多个版本同时在开发。

我们的前端组遇到过这样的情况,在同一个仓库中,三个人同时进行开发,做不同的功能,一个人配合客户端修改JSBridge,一个人给运营做活动页面,还有一个人在开发新功能。其中配合客户端的修改要和客户端一起上线,活动页面要按运营的时间表上线,新功能要等服务端部署上线,这就有三个上线时间点。按照gitflow的流程管理,开发完毕的feature都合并到develop,发布的时候我们遇到了困难,客户端准备上线了,需要将此仓库发布,但是活动页面还没到活动的日期,不能让用户提前看到。为了解决这个问题,我们只好在几个修改的地方都加上了版本号判断,类似的问题也在服务端和客户端的发布中出现过。

为了规避这种问题,我们制定了一种新的代码管理流程,我们称之为feature flow

主要分支

  • master
  • develop

master分支用于发布版本,在发布之前将已经测试完毕的feature和bugfix合并到master分支,不允许从develop分支直接合并到master

develop分支是众多feature和bugfix的合集,代码杂乱不可直接合并到master分支,而且不允许在develop分支上commit代码

feature

代码管理以feature为核心,例如开发一个feature A,则从master拉一个分支featureA出来,在featureA上开发完成后合并到develop分支,发测试包测试,如有问题则继续在featureA上修复,然后合并develop分支再发包测试,测试完毕后featureA放在那里等待发布。

当决定发布一个新版本时,会挑选多个feature,这些feature分支都是开发并测试完毕的,将它们合并到master之后删除,在master上发布。

这样做的原因是现在一般都是多个版本的开发同时进行,不能确定某个版本发布时会包含哪些feature,若像之前一样git flow管理的话,合并到develop的feature想摘出来会十分困难

bugfix

bug修复分两种情况进行管理

  • 简单bug,指修复后容易测试,可确认修复不会造成其它问题
  • 复杂bug,修复后不容易测试,有隐患带来其它问题,需长时间测试或认真考虑在哪个版本发布的问题

简单bug修复不必遵循feature管理的原则,在develop分支测试完成后直接合并到master分支
复杂bug修复和feature管理做相同处理

feature分支过多

如果feature本身小而数量多,可以将确定会一起发布的feature合并到一个存储分支,比如一个版本号分支2.0.6

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,524评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,869评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,813评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,210评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,085评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,117评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,533评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,219评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,487评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,582评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,362评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,218评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,589评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,899评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,176评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,503评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,707评论 2 335

推荐阅读更多精彩内容

  • 1 Git Flow介绍 我们都知道, 在 git 的分支功能相对 svn 确实方便许多,而且也非常推荐使用分支来...
    七寸知架构阅读 7,804评论 20 68
  • 多种多样的工作流使得在项目中实施Git时变得难以选择。这份教程提供了一个出发点,调查企业团队最常见的Git工作流。...
    JSErik阅读 4,348评论 2 8
  • 人天生对跌宕起伏的剧情感兴趣,总有人会为了看到故事的结局而彻夜未眠。《一千零一夜》的出现,也是因为一个爱听故事的国...
    静心观情阅读 149评论 2 2
  • 桌子上面有一把枪 枪的主人是匹野狼 野狼请我喝酒吃肉 他的眼里泛着光 光的背后是绝望 我问野狼要那把枪 野狼问我要...
    邵廪生阅读 324评论 0 0
  • 青春·单车 岁月碾过青春的雨季, 含笑花投下淡淡的笑影, 幽然的花香吟出最初的梦语, 飘然而逝的单车铃声, 响在耳...
    秦时明月_阅读 667评论 0 2