脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Golang - 利用go语言实现Git 重命名远程分支

利用go语言实现Git 重命名远程分支

2022-10-14 11:41王中阳Go Golang

这篇文章主要介绍了go语言实现Git 重命名远程分支,文章基于go语言的基础展开Git 重命名远程分支的实现过程,需要的小伙伴可以参考一下,希望对你的学习有所帮助

问题描述

小A和我并行开发,他在优化之前的代码逻辑,我在开发新功能。

小A在我之前把代码提交到了测试分支,我想提交我的新功能代码到测试分支时发现巨多冲突。

首先解决冲突浪费时间,我的新功能代码每次提测都需要解决冲突。

再者我再测试分支解决冲突,只能按照小A优化后的代码逻辑的去解决,和我自己的分支逻辑并不一致。

交付给测试同学测的代码,和我自己分支的代码不一致,这种测试是没有意义的。

反思出问题的原因

  • 工厂模式使用的不合理
  • 任务分配的不合理

代码层面

因为是工厂设计模式,我负责的实现类A和他的实现类B虽然没有直接关系。但是因为他修改了工厂类中的方法定义。

比如之前工厂类中的接口是这么定义的

?
1
2
3
4
5
package factory
 
type xxx interface {
   GetXxxx(ctx context.Context, req aaa.aa) (res bbb.bb, err error
}

但是小A修改了工厂类中的接口定义:

?
1
2
3
4
5
package factory
 
type xxx interface {
   GetXxxx(ctx context.Context, req ccc.cc) (res ddd.dd, err error
}

这样就导致了一个问题:

我想合并我的代码到测试分支也必须将我的实现类A修改传参类型和返回类型。

但是我们都在不同的分支上开发,我是没有他定义的类型ccc.cc,ddd.dd的。

我又不能直接把他定义的ccc.cc,ddd.dd要过来,在我自己的分支上开发,一是因为需求不一致,小A的上线周期会比我长,二是这种操作本身就不规范。

解决问题

从代码设计上优化

我们想到的方案是合理使用interface

把工厂类中要实现的接口方法的入参和出参设置为interface{}类型

?
1
2
3
4
5
package factory
 
type xxx interface {
   GetXxxx(ctx context.Context, req interface{}) (res interface{}, err error
}

这样就比较容易进行扩展了。

从git操作上优化

但是入参和出参设置为interface{}类型的办法并没有从根本上解决我们的问题。

原因是这样的:

小A的需求是整体优化工厂类和各个实现类的入参、出参,优化内部逻辑,抽取方法。小A的修改导致和我的实现逻辑有比较大的冲突。

但是他的git提交又在我之前提交到了测试环境,导致我无法提交我的代码,如果要提交就要解决各种冲突。解决冲突就要按照小A的优化逻辑去改,给到测试同学测的有和我自己分支的不一致。难顶啊。考虑到小A的修改暂时不需要提测,上线周期也比较长。

最终的办法是这样的

从远程的测试分支拉取了一个备份分支,删除远程的测试分支

把我本地需要测试的分支提交到测试分支,交付测试。

git 重命名远程分支

1.先重命名本地分支

?
1
git branch -m 旧分支名称  新分支名称

2.删除远程分支

?
1
git push --delete origin 旧分支名称

3.上传新修改名称的本地分支

?
1
git push origin 新分支名称

4.修改后的本地分支关联远程分支

?
1
git branch --set-upstream-to origin/新分支名称

到此这篇关于go语言实现Git 重命名远程分支  的文章就介绍到这了,更多相关go Git 重命名 内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://juejin.cn/post/7104258964732575775

延伸 · 阅读

精彩推荐
  • GolangGo语言中普通函数与方法的区别分析

    Go语言中普通函数与方法的区别分析

    这篇文章主要介绍了Go语言中普通函数与方法的区别,以实例形式对比分析了普通函数与方法使用时的区别与相关技巧,需要的朋友可以参考下 ...

    脚本之家3022020-04-13
  • Golanggoland 恢复已更改文件的操作

    goland 恢复已更改文件的操作

    这篇文章主要介绍了goland 恢复已更改文件的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    疯狂学者10902021-06-05
  • Golang一文搞懂Go语言中条件语句的使用

    一文搞懂Go语言中条件语句的使用

    这篇文章主要介绍了Go语言中五个常用条件语句的使用,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考...

    隐姓埋名48694892022-09-27
  • Golang一些关于Go程序错误处理的相关建议

    一些关于Go程序错误处理的相关建议

    错误处理在每个语言中都是一项重要内容,众所周知,通常写程序时遇到的分为异常与错误两种,Golang中也不例外,这篇文章主要给大家介绍了一些关于Go程序错...

    网管10162021-11-16
  • GolangGo语言利用Unmarshal解析json字符串的实现

    Go语言利用Unmarshal解析json字符串的实现

    本文主要介绍了Go语言利用Unmarshal解析json字符串的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友...

    hp_cpp4692022-10-08
  • Golanggolang 实现json类型不确定时的转换

    golang 实现json类型不确定时的转换

    这篇文章主要介绍了golang 实现json类型不确定时的转换操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    翔云12345611882021-03-27
  • Golanggo中控制goroutine数量的方法

    go中控制goroutine数量的方法

    这篇文章主要介绍了go中控制goroutine数量的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面...

    liz7482021-06-11
  • Golang解决Golang json序列化字符串时多了\的情况

    解决Golang json序列化字符串时多了\的情况

    这篇文章主要介绍了解决Golang json序列化字符串时多了\的情况,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    Go哥10412021-03-22