mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-10 03:47:03 +02:00
3c4e797150
* feat: upgrade to go 1.18 * chore: go mod tidy Signed-off-by: Carlos A Becker <caarlos0@gmail.com> * test: fix * fix: more updates * test: fix test
109 lines
2.3 KiB
Go
109 lines
2.3 KiB
Go
package before
|
|
|
|
import (
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/apex/log"
|
|
"github.com/goreleaser/goreleaser/pkg/config"
|
|
"github.com/goreleaser/goreleaser/pkg/context"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestMain(m *testing.M) {
|
|
log.SetLevel(log.DebugLevel)
|
|
defer log.SetLevel(log.InfoLevel)
|
|
os.Exit(m.Run())
|
|
}
|
|
|
|
func TestDescription(t *testing.T) {
|
|
require.NotEmpty(t, Pipe{}.String())
|
|
}
|
|
|
|
func TestRunPipe(t *testing.T) {
|
|
for _, tc := range [][]string{
|
|
nil,
|
|
{},
|
|
{"go version"},
|
|
{"go version", "go list"},
|
|
{`bash -c "go version; echo \"lala spaces and such\""`},
|
|
} {
|
|
ctx := context.New(
|
|
config.Project{
|
|
Before: config.Before{
|
|
Hooks: tc,
|
|
},
|
|
},
|
|
)
|
|
require.NoError(t, Pipe{}.Run(ctx))
|
|
}
|
|
}
|
|
|
|
func TestRunPipeInvalidCommand(t *testing.T) {
|
|
ctx := context.New(
|
|
config.Project{
|
|
Before: config.Before{
|
|
Hooks: []string{`bash -c "echo \"unterminated command\"`},
|
|
},
|
|
},
|
|
)
|
|
require.EqualError(t, Pipe{}.Run(ctx), "invalid command line string")
|
|
}
|
|
|
|
func TestRunPipeFail(t *testing.T) {
|
|
for err, tc := range map[string][]string{
|
|
"hook failed: go tool foobar: exit status 2; output: go: no such tool \"foobar\"\n": {"go tool foobar"},
|
|
"hook failed: sh ./testdata/foo.sh: exit status 1; output: lalala\n": {"sh ./testdata/foo.sh"},
|
|
} {
|
|
ctx := context.New(
|
|
config.Project{
|
|
Before: config.Before{
|
|
Hooks: tc,
|
|
},
|
|
},
|
|
)
|
|
require.EqualError(t, Pipe{}.Run(ctx), err)
|
|
}
|
|
}
|
|
|
|
func TestRunWithEnv(t *testing.T) {
|
|
f := filepath.Join(t.TempDir(), "testfile")
|
|
require.NoError(t, Pipe{}.Run(context.New(
|
|
config.Project{
|
|
Env: []string{
|
|
"TEST_FILE=" + f,
|
|
},
|
|
Before: config.Before{
|
|
Hooks: []string{"touch {{ .Env.TEST_FILE }}"},
|
|
},
|
|
},
|
|
)))
|
|
require.FileExists(t, f)
|
|
}
|
|
|
|
func TestInvalidTemplate(t *testing.T) {
|
|
require.EqualError(t, Pipe{}.Run(context.New(
|
|
config.Project{
|
|
Before: config.Before{
|
|
Hooks: []string{"touch {{ .fasdsd }"},
|
|
},
|
|
},
|
|
)), `template: tmpl:1: unexpected "}" in operand`)
|
|
}
|
|
|
|
func TestSkip(t *testing.T) {
|
|
t.Run("skip", func(t *testing.T) {
|
|
require.True(t, Pipe{}.Skip(context.New(config.Project{})))
|
|
})
|
|
|
|
t.Run("dont skip", func(t *testing.T) {
|
|
ctx := context.New(config.Project{
|
|
Before: config.Before{
|
|
Hooks: []string{""},
|
|
},
|
|
})
|
|
require.False(t, Pipe{}.Skip(ctx))
|
|
})
|
|
}
|