mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-10 23:52:16 +01:00
Merge pull request 'Fixes git references wrongly transmitted to the action run' (#4272) from Mai-Lapyst/forgejo:fix-workflow_dispatch-gitrefs into forgejo
Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/4272 Reviewed-by: Earl Warren <earl-warren@noreply.codeberg.org>
This commit is contained in:
commit
7b80ac476f
3 changed files with 25 additions and 1 deletions
|
@ -5,6 +5,7 @@ package git
|
|||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"strings"
|
||||
|
||||
"code.gitea.io/gitea/modules/util"
|
||||
|
@ -61,3 +62,19 @@ func parseTags(refs []string) []string {
|
|||
}
|
||||
return results
|
||||
}
|
||||
|
||||
// ExpandRef expands any partial reference to its full form
|
||||
func (repo *Repository) ExpandRef(ref string) (string, error) {
|
||||
if strings.HasPrefix(ref, "refs/") {
|
||||
return ref, nil
|
||||
} else if strings.HasPrefix(ref, "tags/") || strings.HasPrefix(ref, "heads/") {
|
||||
return "refs/" + ref, nil
|
||||
} else if repo.IsTagExist(ref) {
|
||||
return TagPrefix + ref, nil
|
||||
} else if repo.IsBranchExist(ref) {
|
||||
return BranchPrefix + ref, nil
|
||||
} else if repo.IsCommitExist(ref) {
|
||||
return ref, nil
|
||||
}
|
||||
return "", fmt.Errorf("could not expand reference '%s'", ref)
|
||||
}
|
||||
|
|
|
@ -141,6 +141,11 @@ func (entry *Workflow) Dispatch(ctx context.Context, inputGetter InputValueGette
|
|||
}
|
||||
|
||||
func GetWorkflowFromCommit(gitRepo *git.Repository, ref, workflowID string) (*Workflow, error) {
|
||||
ref, err := gitRepo.ExpandRef(ref)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
commit, err := gitRepo.GetCommit(ref)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
|
|
|
@ -426,8 +426,10 @@ func TestWorkflowDispatchEvent(t *testing.T) {
|
|||
assert.NoError(t, err)
|
||||
defer gitRepo.Close()
|
||||
|
||||
workflow, err := actions_service.GetWorkflowFromCommit(gitRepo, sha, "dispatch.yml")
|
||||
workflow, err := actions_service.GetWorkflowFromCommit(gitRepo, "main", "dispatch.yml")
|
||||
assert.NoError(t, err)
|
||||
assert.Equal(t, "refs/heads/main", workflow.Ref)
|
||||
assert.Equal(t, sha, workflow.Commit.ID.String())
|
||||
|
||||
inputGetter := func(key string) string {
|
||||
return ""
|
||||
|
|
Loading…
Reference in a new issue