17、【ubuntu】【gitlab】【nuttx】自动识别远程仓库默认分支名

背景

接之前wiki 15、【OS】【Nuttx】OS裁剪,运行指定程序,周期打印当前任务

准备合并MR的时候,发现合并请求创建不了

原因为该项目没有main分支,nuttx-apps的主分支名为master,而gitlab创建的项目中,主分支名为main,开源项目有不少主分支名为master,而非main

目标

重新更新go封装,自动识别远程仓库默认分支名

解决方案

回顾之前go代码
7、【ubuntu】【git】【go】优化merge request,用go对git mr进行配置
10、【ubuntu】【go】【git】优化merge request:使用分叉方法对项目进行隔离

发现target branch进行了硬编码,默认写成了main

封装个自动获取远程仓库默认分支名的代码出来

go 复制代码
func getDefaultBranch(client *gitlab.Client, projectPath string) string {
	// 使用 GetProject 方法获取项目默认分支名
	project, _, err := client.Projects.GetProject(projectPath, nil)
	if err != nil {
		log.Fatalf("Failed to get project information: %v", err)
	}
	return project.DefaultBranch
}

目标分支名调用该接口,取消分叉项目保护的分支为目标分支名

go 复制代码
	// 获取当前分支
	mrInfo.sourceBranch = execCommand("git br --show-current")
	// Merge Request的相关信息
	mrInfo.targetBranch = getDefaultBranch(client, projectPath)
	fmt.Printf("merge request from %s to %s\n", mrInfo.sourceBranch, mrInfo.targetBranch)
	// 获取当前认证的用户
	user := getCurrentUser(client)
	fmt.Printf("current user is %s\n", user)
	// 为项目创建新Group
	group := getGroup(client, user)
	// 分叉项目
	fmt.Printf("project id is %d\n", mrInfo.projectID)
	forkedProject := getForkProject(mrInfo.projectID, group, client)
	mrInfo.forkedProjectID = forkedProject.ID
	fmt.Printf("forkedProject id is %d, url is %s\n", forkedProject.ID, forkedProject.SSHURLToRepo)
	// 取消分叉项目分支保护
	unprotectedBranch(forkedProject.ID, mrInfo.targetBranch, client)
	// 配置fork远程仓库
	forkRemoteConfig(forkedProject)

按wiki 5、【ubuntu】【git】【go】用go对git做层wrapper

构建,对git进行替换

最终效果

MR创建成功,目标分支也改成了远程仓库名master

相关推荐
chlk1231 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑1 天前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件1 天前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
深紫色的三北六号2 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash2 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI2 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行3 天前
Linux和window共享文件夹
linux
木心月转码ing3 天前
WSL+Cpp开发环境配置
linux
崔小汤呀4 天前
最全的docker安装笔记,包含CentOS和Ubuntu
linux·后端
何中应4 天前
vi编辑器使用
linux·后端·操作系统