V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
FrankFang128
V2EX  ›  程序员

GitFlow 中如何将已经 finish 的 feature 分享给另一个开发者?

  •  
  •   FrankFang128 · 2014-02-18 17:15:39 +08:00 · 3277 次点击
    这是一个创建于 3721 天前的主题,其中的信息可能已经有所发展或是发生改变。
    例如后台开发者A完成了一个新的API
    git flow feature start new_api
    git flow feature finish new_api
    现在需要把心得API分享给前端开发者B测试,要怎么做呢?

    我想到的办法:
    1. 将 develop 合并到 master,然后 push master
    这样做的问题是破坏了GitFlow的开发模型, new_api 这个 feature 未经测试就被发布到了master。
    2. 先 release,
    git flow release start new_api
    git flow release publish new_api
    git flow release finish new_api
    这样 new_api 就被发布到 master 上了。开发者B可以 pull master,并且合并到自己的 develop 分支上。
    这个方案也很蛋疼。总不能没新增一个api就要release一次吧?


    这个问题的本质应该是两个开发者的 develop 分支应该如何交互。
    12 条回复    1970-01-01 08:00:00 +08:00
    FrankFang128
        1
    FrankFang128  
    OP
       2014-02-18 17:18:41 +08:00
    难道说 GitFlow 认为所有程序员都是各自测试各自发布的?
    humiaozuzu
        2
    humiaozuzu  
       2014-02-18 17:36:33 +08:00 via iPhone
    我们是前后端都commmit到 feature/new-api 的branch中,毕竟是基于feature的开发,和这个feature相关的人都会进入这个branch
    wtracyliu
        3
    wtracyliu  
       2014-02-18 17:39:15 +08:00
    如果前端开发者B自己目前有一个feature分支 那直接merge develop不就可以拿到最新的new_api了么, 如果new_api是A,B要完成的feature的一部分,那么A,B应该可以公共用一个feature分支,我们目前是这么做的。不知道大家都是怎么处理这个的
    FrankFang128
        4
    FrankFang128  
    OP
       2014-02-18 18:25:10 +08:00
    @humiaozuzu 我现在也是这么认为,那么就是说后端开发者一定要记得把 feature 发布到 remote 才行。
    万一忘了,是不是可以重开这个 feature 然后在 publish 啊? 因为我实在找不到什么办法把 dev 上的代码分享出去,前提是遵循 GitFlow 的约定。
    FrankFang128
        5
    FrankFang128  
    OP
       2014-02-18 18:26:20 +08:00
    @wtracyliu 嗯,道理是这样没错。见楼上
    FrankFang128
        6
    FrankFang128  
    OP
       2014-02-18 18:28:24 +08:00
    @wtracyliu 安装 GitFlow 的说法, develop 是不能发布到 remote 上的吧,只能放在自己本地。
    不过我倾向于把 develop 给发布到 remote 上啊。

    GitFlow 相对与 Git 的最大变化应该就是“基于feature开发”吧,我一时还没适应过来。
    humiaozuzu
        7
    humiaozuzu  
       2014-02-18 18:37:13 +08:00 via iPhone
    @FrankFang128 master和dev在remote是必须有的,发布很简单啊,git push origin feature/new-api
    FrankFang128
        8
    FrankFang128  
    OP
       2014-02-18 18:58:32 +08:00 via Android
    @humiaozuzu remote 不能有 dev 分支。。。
    humiaozuzu
        9
    humiaozuzu  
       2014-02-18 19:18:23 +08:00
    @FrankFang128 从来没有听说过这种说法,你看各种git flow的教程都有讲如何push dev 和 feature branch的
    flypiggy
        10
    flypiggy  
       2014-02-18 19:31:48 +08:00   ❤️ 1
    感觉楼主对git和git-flow理解都有点偏差..
    git-flow只是一个开发流程..不管你放在哪里的...即使是feature也可以push到remote
    另外即使merge了feature以后feature中每个状态也可以追踪的.

    gitflow核心是(摘自ihower博客)
    主要分支
    master: 永遠處在 production-ready 狀態
    develop: 最新的下次發佈開發狀態
    支援性分支
    Feature branches: 開發新功能都從 develop 分支出來,完成後 merge 回 develop
    Release branches: 準備要 release 的版本,只修 bugs。從 develop 分支出來,完成後 merge 回 master 和 develop
    Hotfix branches: 等不及 release 版本就必須馬上修 master 趕上線的情況。會從 master 分支出來,完成後 merge 回 master 和 develop
    FrankFang128
        11
    FrankFang128  
    OP
       2014-02-18 22:29:59 +08:00
    @humiaozuzu Thanks,我又看了一下介绍 git flow 的模型的那篇文章,确实没有说 dev 只能在本地。
    doskoi
        12
    doskoi  
       2014-02-19 10:29:24 +08:00
    finish的feature不是会merge到develop分支里吗?
    如果是开发中的你可以git flow feature publish MYFEATURE
    对方可以git flow feature pull MYFEATURE
    参见http://danielkummer.github.io/git-flow-cheatsheet/index.zh_CN.html
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1012 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 18:50 · PVG 02:50 · LAX 11:50 · JFK 14:50
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.