fix default initial branch ignoring the project default branch and always be set to master

This commit is contained in:
Massaki Archambault 2021-01-18 00:24:26 -05:00
parent 4d504d9f5a
commit ab4d1d6a7e
3 changed files with 15 additions and 7 deletions

View File

@ -29,7 +29,7 @@ func newRepositoryNode(project *gitlab.Project, param *FSParam) (*RepositoryNode
func (n *RepositoryNode) Readlink(ctx context.Context) ([]byte, syscall.Errno) { func (n *RepositoryNode) Readlink(ctx context.Context) ([]byte, syscall.Errno) {
// Create the local copy of the repo // Create the local copy of the repo
localRepoLoc, _ := n.param.Git.CloneOrPull(n.project.CloneURL, n.project.ID, "master") localRepoLoc, _ := n.param.Git.CloneOrPull(n.project.CloneURL, n.project.ID, n.project.DefaultBranch)
return []byte(localRepoLoc), 0 return []byte(localRepoLoc), 0
} }

View File

@ -82,9 +82,12 @@ func (c *gitClient) clone(gcp *gitCloneParam) error {
if err != nil { if err != nil {
return fmt.Errorf("failed to retrieve worktree of git repo %v: %v", gcp.dst, err) return fmt.Errorf("failed to retrieve worktree of git repo %v: %v", gcp.dst, err)
} }
w.Checkout(&git.CheckoutOptions{ err = w.Checkout(&git.CheckoutOptions{
Branch: branchRef, Branch: branchRef,
}) })
if err != nil {
return fmt.Errorf("failed to checkout %v of git repo %v: %v", branchRef, gcp.dst, err)
}
} }
if c.PullAfterClone { if c.PullAfterClone {
// Dispatch to pull worker // Dispatch to pull worker

View File

@ -8,6 +8,7 @@ type Project struct {
ID int ID int
Name string Name string
CloneURL string CloneURL string
DefaultBranch string
} }
func (c *gitlabClient) newProjectFromGitlabProject(project *gitlab.Project) Project { func (c *gitlabClient) newProjectFromGitlabProject(project *gitlab.Project) Project {
@ -15,6 +16,10 @@ func (c *gitlabClient) newProjectFromGitlabProject(project *gitlab.Project) Proj
p := Project{ p := Project{
ID: project.ID, ID: project.ID,
Name: project.Path, Name: project.Path,
DefaultBranch: project.DefaultBranch,
}
if p.DefaultBranch == "" {
p.DefaultBranch = "master"
} }
if c.PullMethod == PullMethodSSH { if c.PullMethod == PullMethodSSH {
p.CloneURL = project.SSHURLToRepo p.CloneURL = project.SSHURLToRepo