Git x SVN rebase事故

在使用GitxSVN过程中,由于错误的rebase操作导致功能版本覆盖及测试遗漏,通过git reflog找回丢失的feature-A分支并重新进行合并及测试,避免了上线前的功能版本错误。

Git x SVN rebase事故 

@author ixenos 2019-01-09 14:21:21

 

 

前言:

  昨天在Git x SVN 中进行git svn dcommit的时候,提示需要再进行11次git rebase。

  而我当时的分支情况是这样的:

    在合并之前,master先git svn rebase获取到远程分支的最新修改,然后,切换到feature-A分支;

    feature-A分支merge master分支,解决冲突后合并;

    然后再切回master分支,将feature-A分支合并到master中;

    最后执行git svn dcommit提交。

  以上的工作流程在纯git环境中很常见,但是就在我dcommit后,提示我需要再进行11次git rebase,当时我也没多想,惯性地认为git rebase已在上一次merge中完成,就一路git rebase --skip下去。。。

  然后测试部分也遗漏了(因为feature-A之前已经经过功能性测试)

  最后在临上线前发现功能版本不对,查看SVN记录,发现commit被覆盖了,而此时只存在本地的feature-A已被git branch -D删除。

 

解决方案:

  1.git reflog 查找最近一条feature-A的记录,获取其commit id

  2.git branch <branch_name> <hash_val> 根据commit id恢复对应分支

  3.重新进行合并操作

  4.11次rebase仔细进行

  5.测试

转载于:https://www.cnblogs.com/ixenos/p/10244275.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值