From f844a9b470caab2ff99016bcd6da115e1ebd2f19 Mon Sep 17 00:00:00 2001 From: mitchell Date: Thu, 30 Nov 2023 11:15:33 -0500 Subject: [PATCH] For checkout/activate, when given a commitID, fetch the branch it belongs to. --- internal/runbits/checkout/checkout.go | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/internal/runbits/checkout/checkout.go b/internal/runbits/checkout/checkout.go index 5692e31ef3..4d5d303ccb 100644 --- a/internal/runbits/checkout/checkout.go +++ b/internal/runbits/checkout/checkout.go @@ -85,6 +85,19 @@ func (r *Checkout) Run(ns *project.Namespaced, branchName, cachePath, targetPath return "", locale.WrapError(err, "err_fetch_branch", "", branchName) } commitID = branch.CommitID + } else { + // It's possible the given commitID does not belong to the default project branch. + // If so, find the correct branch. + for _, branch := range pj.Branches { + belongs, err := model.CommitBelongsToBranch(ns.Owner, ns.Project, branch.Label, *commitID) + if err != nil { + return "", errs.Wrap(err, "Could not determine if the given commitID belongs to a project branch") + } + if belongs { + branchName = branch.Label + break + } + } } if commitID == nil {