2020-04-27 21:42:44 -03:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
2021-06-04 23:09:12 -03:00
|
|
|
"path/filepath"
|
2020-04-27 21:42:44 -03:00
|
|
|
"testing"
|
|
|
|
|
2023-09-16 17:01:20 -03:00
|
|
|
"github.com/goreleaser/goreleaser/internal/skips"
|
2023-03-02 00:01:11 -03:00
|
|
|
"github.com/goreleaser/goreleaser/internal/testctx"
|
2020-04-27 21:42:44 -03:00
|
|
|
"github.com/goreleaser/goreleaser/pkg/context"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestRelease(t *testing.T) {
|
2020-12-12 13:27:35 -03:00
|
|
|
setup(t)
|
2021-04-25 14:20:49 -03:00
|
|
|
cmd := newReleaseCmd()
|
2020-04-27 21:42:44 -03:00
|
|
|
cmd.cmd.SetArgs([]string{"--snapshot", "--timeout=1m", "--parallelism=2", "--deprecated"})
|
|
|
|
require.NoError(t, cmd.cmd.Execute())
|
|
|
|
}
|
|
|
|
|
2021-06-04 23:09:12 -03:00
|
|
|
func TestReleaseAutoSnapshot(t *testing.T) {
|
|
|
|
t.Run("clean", func(t *testing.T) {
|
|
|
|
setup(t)
|
|
|
|
cmd := newReleaseCmd()
|
|
|
|
cmd.cmd.SetArgs([]string{"--auto-snapshot", "--skip-publish"})
|
|
|
|
require.NoError(t, cmd.cmd.Execute())
|
|
|
|
require.FileExists(t, "dist/fake_0.0.2_checksums.txt", "should not have run with --snapshot")
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("dirty", func(t *testing.T) {
|
|
|
|
setup(t)
|
|
|
|
createFile(t, "foo", "force dirty tree")
|
|
|
|
cmd := newReleaseCmd()
|
|
|
|
cmd.cmd.SetArgs([]string{"--auto-snapshot", "--skip-publish"})
|
|
|
|
require.NoError(t, cmd.cmd.Execute())
|
2021-08-21 11:18:54 -03:00
|
|
|
matches, err := filepath.Glob("./dist/fake_0.0.2-SNAPSHOT-*_checksums.txt")
|
2021-06-04 23:09:12 -03:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Len(t, matches, 1, "should have implied --snapshot")
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2020-04-27 21:42:44 -03:00
|
|
|
func TestReleaseInvalidConfig(t *testing.T) {
|
2020-12-12 13:27:35 -03:00
|
|
|
setup(t)
|
2020-04-27 21:42:44 -03:00
|
|
|
createFile(t, "goreleaser.yml", "foo: bar")
|
2021-04-25 14:20:49 -03:00
|
|
|
cmd := newReleaseCmd()
|
2020-04-27 21:42:44 -03:00
|
|
|
cmd.cmd.SetArgs([]string{"--snapshot", "--timeout=1m", "--parallelism=2", "--deprecated"})
|
|
|
|
require.EqualError(t, cmd.cmd.Execute(), "yaml: unmarshal errors:\n line 1: field foo not found in type config.Project")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestReleaseBrokenProject(t *testing.T) {
|
2020-12-12 13:27:35 -03:00
|
|
|
setup(t)
|
2020-04-27 21:42:44 -03:00
|
|
|
createFile(t, "main.go", "not a valid go file")
|
2021-04-25 14:20:49 -03:00
|
|
|
cmd := newReleaseCmd()
|
2020-04-27 21:42:44 -03:00
|
|
|
cmd.cmd.SetArgs([]string{"--snapshot", "--timeout=1m", "--parallelism=2"})
|
|
|
|
require.EqualError(t, cmd.cmd.Execute(), "failed to parse dir: .: main.go:1:1: expected 'package', found not")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestReleaseFlags(t *testing.T) {
|
2022-09-25 18:19:53 -03:00
|
|
|
setup := func(tb testing.TB, opts releaseOpts) *context.Context {
|
|
|
|
tb.Helper()
|
2023-03-02 00:01:11 -03:00
|
|
|
ctx := testctx.New()
|
2023-11-29 23:12:16 -03:00
|
|
|
require.NoError(t, setupReleaseContext(ctx, opts))
|
2022-09-25 18:19:53 -03:00
|
|
|
return ctx
|
2020-04-27 21:42:44 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
t.Run("snapshot", func(t *testing.T) {
|
2022-09-25 18:19:53 -03:00
|
|
|
ctx := setup(t, releaseOpts{
|
2020-04-27 21:42:44 -03:00
|
|
|
snapshot: true,
|
|
|
|
})
|
|
|
|
require.True(t, ctx.Snapshot)
|
2023-09-16 17:01:20 -03:00
|
|
|
requireAll(t, ctx, skips.Publish, skips.Validate, skips.Announce)
|
2020-04-27 21:42:44 -03:00
|
|
|
})
|
|
|
|
|
2023-09-16 17:01:20 -03:00
|
|
|
t.Run("skips (old)", func(t *testing.T) {
|
2022-09-25 18:19:53 -03:00
|
|
|
ctx := setup(t, releaseOpts{
|
2020-04-27 21:42:44 -03:00
|
|
|
skipPublish: true,
|
|
|
|
skipSign: true,
|
|
|
|
skipValidate: true,
|
|
|
|
})
|
2023-09-16 17:01:20 -03:00
|
|
|
|
|
|
|
requireAll(t, ctx, skips.Sign, skips.Publish, skips.Validate, skips.Announce)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("skips", func(t *testing.T) {
|
|
|
|
ctx := setup(t, releaseOpts{
|
|
|
|
skips: []string{
|
|
|
|
string(skips.Publish),
|
|
|
|
string(skips.Sign),
|
|
|
|
string(skips.Validate),
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
requireAll(t, ctx, skips.Sign, skips.Publish, skips.Validate, skips.Announce)
|
2020-04-27 21:42:44 -03:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("parallelism", func(t *testing.T) {
|
2022-09-25 18:19:53 -03:00
|
|
|
require.Equal(t, 1, setup(t, releaseOpts{
|
2020-04-27 21:42:44 -03:00
|
|
|
parallelism: 1,
|
|
|
|
}).Parallelism)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("notes", func(t *testing.T) {
|
2021-04-25 14:20:49 -03:00
|
|
|
notes := "foo.md"
|
|
|
|
header := "header.md"
|
|
|
|
footer := "footer.md"
|
2022-09-25 18:19:53 -03:00
|
|
|
ctx := setup(t, releaseOpts{
|
2021-05-21 21:07:47 -03:00
|
|
|
releaseNotesFile: notes,
|
|
|
|
releaseHeaderFile: header,
|
|
|
|
releaseFooterFile: footer,
|
2020-04-27 21:42:44 -03:00
|
|
|
})
|
2021-05-21 21:07:47 -03:00
|
|
|
require.Equal(t, notes, ctx.ReleaseNotesFile)
|
|
|
|
require.Equal(t, header, ctx.ReleaseHeaderFile)
|
|
|
|
require.Equal(t, footer, ctx.ReleaseFooterFile)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("templated notes", func(t *testing.T) {
|
|
|
|
notes := "foo.md"
|
|
|
|
header := "header.md"
|
|
|
|
footer := "footer.md"
|
2022-09-25 18:19:53 -03:00
|
|
|
ctx := setup(t, releaseOpts{
|
2021-05-21 21:07:47 -03:00
|
|
|
releaseNotesTmpl: notes,
|
|
|
|
releaseHeaderTmpl: header,
|
|
|
|
releaseFooterTmpl: footer,
|
|
|
|
})
|
|
|
|
require.Equal(t, notes, ctx.ReleaseNotesTmpl)
|
|
|
|
require.Equal(t, header, ctx.ReleaseHeaderTmpl)
|
|
|
|
require.Equal(t, footer, ctx.ReleaseFooterTmpl)
|
2020-04-27 21:42:44 -03:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("rm dist", func(t *testing.T) {
|
2022-09-25 18:19:53 -03:00
|
|
|
require.True(t, setup(t, releaseOpts{
|
2023-01-20 23:47:08 -03:00
|
|
|
clean: true,
|
2023-01-29 00:24:11 -03:00
|
|
|
}).Clean)
|
2020-04-27 21:42:44 -03:00
|
|
|
})
|
|
|
|
}
|