mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-10 03:47:03 +02:00
f544c5ce69
alternative to #3806 the idea is that both `context.New` and `context.Context{}` are never used in tests. not sure yet how much I like it, so far code does look a bit more readable though. --------- Signed-off-by: Carlos A Becker <caarlos0@users.noreply.github.com>
73 lines
1.5 KiB
Go
73 lines
1.5 KiB
Go
package commitauthor
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/goreleaser/goreleaser/internal/testctx"
|
|
"github.com/goreleaser/goreleaser/pkg/config"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestGet(t *testing.T) {
|
|
t.Run("valid", func(t *testing.T) {
|
|
author, err := Get(testctx.NewWithCfg(config.Project{
|
|
Env: []string{"NAME=foo", "MAIL=foo@bar"},
|
|
}), config.CommitAuthor{
|
|
Name: "{{.Env.NAME}}",
|
|
Email: "{{.Env.MAIL}}",
|
|
})
|
|
require.NoError(t, err)
|
|
require.Equal(t, config.CommitAuthor{
|
|
Name: "foo",
|
|
Email: "foo@bar",
|
|
}, author)
|
|
})
|
|
|
|
t.Run("invalid name tmpl", func(t *testing.T) {
|
|
_, err := Get(
|
|
testctx.New(),
|
|
config.CommitAuthor{
|
|
Name: "{{.Env.NOPE}}",
|
|
Email: "a",
|
|
})
|
|
require.Error(t, err)
|
|
})
|
|
|
|
t.Run("invalid email tmpl", func(t *testing.T) {
|
|
_, err := Get(
|
|
testctx.New(),
|
|
config.CommitAuthor{
|
|
Name: "a",
|
|
Email: "{{.Env.NOPE}}",
|
|
})
|
|
require.Error(t, err)
|
|
})
|
|
}
|
|
|
|
func TestDefault(t *testing.T) {
|
|
t.Run("empty", func(t *testing.T) {
|
|
require.Equal(t, Default(config.CommitAuthor{}), config.CommitAuthor{
|
|
Name: defaultName,
|
|
Email: defaultEmail,
|
|
})
|
|
})
|
|
|
|
t.Run("no name", func(t *testing.T) {
|
|
require.Equal(t, Default(config.CommitAuthor{
|
|
Email: "a",
|
|
}), config.CommitAuthor{
|
|
Name: defaultName,
|
|
Email: "a",
|
|
})
|
|
})
|
|
|
|
t.Run("no email", func(t *testing.T) {
|
|
require.Equal(t, Default(config.CommitAuthor{
|
|
Name: "a",
|
|
}), config.CommitAuthor{
|
|
Name: "a",
|
|
Email: defaultEmail,
|
|
})
|
|
})
|
|
}
|