背景
接之前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
封装个主动获取远程堆栈默认分支名的代码出来
- 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
- }
复制代码 目标分支名调用该接口,取消分叉项目掩护的分支为目标分支名
- // 获取当前分支
- 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
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |