问题描述
我们有2个功能A
和B
已合并到dev
分支中,分支dev
用于测试环境,并且这两个功能均已测试。现在我们只想发布功能A
,该怎么做?是不是我们的git flow很差?
解决方法
到目前为止,您的git-flow
看起来还不错。根本不打算使用它来部分释放develop
。
任何合并到develop
的内容都将被释放。
以下是您可以使用的一些解决方案:
(1)除非要发布功能,否则不要合并(或者最好不要开始使用它)。
(2)如果要合并未完成的功能,请添加功能开关,以轻松打开和关闭develop
上的所有功能。
注意:并非所有人都认为这是好的软件设计-包括我在内。但是为了完整起见,我想提一下。
(3)也不是一个好的方法,但是在技术上是可行的:恢复不想在release
分支上发布的功能。如果您不想重写提交历史记录(您不应该这样做),那么这可能是您现在唯一的选择。
(4)在合并功能release
和B
功能cherry-pick
到该A
分支之前的提交开始,创建一个新的release
分支