4391a10d5a
* feat: use logger from context wherever possible Co-authored-by: Markus Wolf <markus.wolf@new-work.se> * feat: add step/job id and results to json logs Co-authored-by: Markus Wolf <markus.wolf@new-work.se> * test: value to be masked should not be hard-coded in the action Co-authored-by: Markus Wolf <markus.wolf@new-work.se> * fix: replace values following ::add-mask:: in evaluated strings Co-authored-by: Markus Wolf <markus.wolf@new-work.se> * feat: [DEBUG] identifier for debug logs to distinguish them Co-authored-by: Markus Wolf <markus.wolf@new-work.se> * feat: replace logger with step logger The container gets injected a job logger, but during the time that steps are run, we want to use the step logger. This commit wraps pre/main/post steps in an executor that replaces the job logger with a step logger. Co-authored-by: Markus Wolf <markus.wolf@new-work.se> * feat: add pre/post stage identifier fields to json log output Co-authored-by: Markus Wolf <markus.wolf@new-work.se> * feat: add job/step result status to skipped steps/jobs Co-authored-by: Markus Wolf <markus.wolf@new-work.se> Co-authored-by: Markus Wolf <markus.wolf@new-work.se> Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
133 lines
2.8 KiB
Go
133 lines
2.8 KiB
Go
package model
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"testing"
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestSetRefAndSha(t *testing.T) {
|
|
log.SetLevel(log.DebugLevel)
|
|
|
|
oldFindGitRef := findGitRef
|
|
oldFindGitRevision := findGitRevision
|
|
defer func() { findGitRef = oldFindGitRef }()
|
|
defer func() { findGitRevision = oldFindGitRevision }()
|
|
|
|
findGitRef = func(ctx context.Context, file string) (string, error) {
|
|
return "refs/heads/master", nil
|
|
}
|
|
|
|
findGitRevision = func(ctx context.Context, file string) (string, string, error) {
|
|
return "", "1234fakesha", nil
|
|
}
|
|
|
|
tables := []struct {
|
|
eventName string
|
|
event map[string]interface{}
|
|
ref string
|
|
sha string
|
|
}{
|
|
{
|
|
eventName: "pull_request_target",
|
|
event: map[string]interface{}{
|
|
"pull_request": map[string]interface{}{
|
|
"base": map[string]interface{}{
|
|
"sha": "pr-base-sha",
|
|
},
|
|
},
|
|
},
|
|
ref: "master",
|
|
sha: "pr-base-sha",
|
|
},
|
|
{
|
|
eventName: "pull_request",
|
|
event: map[string]interface{}{
|
|
"number": "1234",
|
|
},
|
|
ref: "refs/pull/1234/merge",
|
|
sha: "1234fakesha",
|
|
},
|
|
{
|
|
eventName: "deployment",
|
|
event: map[string]interface{}{
|
|
"deployment": map[string]interface{}{
|
|
"ref": "refs/heads/somebranch",
|
|
"sha": "deployment-sha",
|
|
},
|
|
},
|
|
ref: "refs/heads/somebranch",
|
|
sha: "deployment-sha",
|
|
},
|
|
{
|
|
eventName: "release",
|
|
event: map[string]interface{}{
|
|
"release": map[string]interface{}{
|
|
"tag_name": "v1.0.0",
|
|
},
|
|
},
|
|
ref: "v1.0.0",
|
|
sha: "1234fakesha",
|
|
},
|
|
{
|
|
eventName: "push",
|
|
event: map[string]interface{}{
|
|
"ref": "refs/heads/somebranch",
|
|
"after": "push-sha",
|
|
"deleted": false,
|
|
},
|
|
ref: "refs/heads/somebranch",
|
|
sha: "push-sha",
|
|
},
|
|
{
|
|
eventName: "unknown",
|
|
event: map[string]interface{}{
|
|
"repository": map[string]interface{}{
|
|
"default_branch": "main",
|
|
},
|
|
},
|
|
ref: "main",
|
|
sha: "1234fakesha",
|
|
},
|
|
{
|
|
eventName: "no-event",
|
|
event: map[string]interface{}{},
|
|
ref: "refs/heads/master",
|
|
sha: "1234fakesha",
|
|
},
|
|
}
|
|
|
|
for _, table := range tables {
|
|
t.Run(table.eventName, func(t *testing.T) {
|
|
ghc := &GithubContext{
|
|
EventName: table.eventName,
|
|
BaseRef: "master",
|
|
Event: table.event,
|
|
}
|
|
|
|
ghc.SetRefAndSha(context.Background(), "main", "/some/dir")
|
|
|
|
assert.Equal(t, table.ref, ghc.Ref)
|
|
assert.Equal(t, table.sha, ghc.Sha)
|
|
})
|
|
}
|
|
|
|
t.Run("no-default-branch", func(t *testing.T) {
|
|
findGitRef = func(ctx context.Context, file string) (string, error) {
|
|
return "", fmt.Errorf("no default branch")
|
|
}
|
|
|
|
ghc := &GithubContext{
|
|
EventName: "no-default-branch",
|
|
Event: map[string]interface{}{},
|
|
}
|
|
|
|
ghc.SetRefAndSha(context.Background(), "", "/some/dir")
|
|
|
|
assert.Equal(t, "master", ghc.Ref)
|
|
assert.Equal(t, "1234fakesha", ghc.Sha)
|
|
})
|
|
}
|