mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-06 03:13:48 +02:00
cf3c758356
* Allow multiple ids to be passed to build goreleaser build --id build 1 --id build2 * addressing cr * addressing cr * fix: rename to ids Signed-off-by: Carlos A Becker <caarlos0@users.noreply.github.com> * fix: improve output Signed-off-by: Carlos A Becker <caarlos0@users.noreply.github.com> Co-authored-by: JD <jdpcbs@gmail.com>
281 lines
6.3 KiB
Go
281 lines
6.3 KiB
Go
package cmd
|
|
|
|
import (
|
|
"os"
|
|
"runtime"
|
|
"testing"
|
|
|
|
"github.com/goreleaser/goreleaser/internal/pipeline"
|
|
"github.com/goreleaser/goreleaser/pkg/config"
|
|
"github.com/goreleaser/goreleaser/pkg/context"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestBuild(t *testing.T) {
|
|
setup(t)
|
|
cmd := newBuildCmd()
|
|
cmd.cmd.SetArgs([]string{"--snapshot", "--timeout=1m", "--parallelism=2", "--deprecated"})
|
|
require.NoError(t, cmd.cmd.Execute())
|
|
}
|
|
|
|
func TestBuildSingleTarget(t *testing.T) {
|
|
setup(t)
|
|
cmd := newBuildCmd()
|
|
cmd.cmd.SetArgs([]string{"--snapshot", "--timeout=1m", "--parallelism=2", "--deprecated", "--single-target"})
|
|
require.NoError(t, cmd.cmd.Execute())
|
|
}
|
|
|
|
func TestBuildInvalidConfig(t *testing.T) {
|
|
setup(t)
|
|
createFile(t, "goreleaser.yml", "foo: bar")
|
|
cmd := newBuildCmd()
|
|
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 TestBuildBrokenProject(t *testing.T) {
|
|
setup(t)
|
|
createFile(t, "main.go", "not a valid go file")
|
|
cmd := newBuildCmd()
|
|
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 TestSetupPipeline(t *testing.T) {
|
|
t.Run("regular", func(t *testing.T) {
|
|
require.Equal(
|
|
t,
|
|
pipeline.BuildCmdPipeline,
|
|
setupPipeline(context.New(config.Project{}), buildOpts{}),
|
|
)
|
|
})
|
|
|
|
t.Run("single-target", func(t *testing.T) {
|
|
require.Equal(
|
|
t,
|
|
pipeline.BuildCmdPipeline,
|
|
setupPipeline(context.New(config.Project{}), buildOpts{
|
|
singleTarget: true,
|
|
}),
|
|
)
|
|
})
|
|
|
|
t.Run("single-target and id", func(t *testing.T) {
|
|
require.Equal(
|
|
t,
|
|
pipeline.BuildCmdPipeline,
|
|
setupPipeline(context.New(config.Project{}), buildOpts{
|
|
singleTarget: true,
|
|
ids: []string{"foo"},
|
|
}),
|
|
)
|
|
})
|
|
|
|
t.Run("single-target and id, given output", func(t *testing.T) {
|
|
require.Equal(
|
|
t,
|
|
append(pipeline.BuildCmdPipeline, withOutputPipe{"foobar"}),
|
|
setupPipeline(context.New(config.Project{}), buildOpts{
|
|
singleTarget: true,
|
|
ids: []string{"foo"},
|
|
output: ".",
|
|
}),
|
|
)
|
|
})
|
|
|
|
t.Run("single-target and single build on config", func(t *testing.T) {
|
|
require.Equal(
|
|
t,
|
|
pipeline.BuildCmdPipeline,
|
|
setupPipeline(
|
|
context.New(config.Project{
|
|
Builds: []config.Build{{}},
|
|
}),
|
|
buildOpts{
|
|
singleTarget: true,
|
|
},
|
|
),
|
|
)
|
|
})
|
|
|
|
t.Run("single-target, id and output", func(t *testing.T) {
|
|
require.Equal(
|
|
t,
|
|
append(pipeline.BuildCmdPipeline, withOutputPipe{"foobar"}),
|
|
setupPipeline(
|
|
context.New(config.Project{}),
|
|
buildOpts{
|
|
singleTarget: true,
|
|
ids: []string{"foo"},
|
|
output: "foobar",
|
|
},
|
|
),
|
|
)
|
|
})
|
|
|
|
t.Run("single-target, single build on config and output", func(t *testing.T) {
|
|
require.Equal(
|
|
t,
|
|
append(pipeline.BuildCmdPipeline, withOutputPipe{"zaz"}),
|
|
setupPipeline(
|
|
context.New(config.Project{
|
|
Builds: []config.Build{{}},
|
|
}),
|
|
buildOpts{
|
|
singleTarget: true,
|
|
output: "zaz",
|
|
},
|
|
),
|
|
)
|
|
})
|
|
}
|
|
|
|
func TestBuildFlags(t *testing.T) {
|
|
setup := func(opts buildOpts) *context.Context {
|
|
ctx := context.New(config.Project{})
|
|
require.NoError(t, setupBuildContext(ctx, opts))
|
|
return ctx
|
|
}
|
|
|
|
t.Run("snapshot", func(t *testing.T) {
|
|
ctx := setup(buildOpts{
|
|
snapshot: true,
|
|
})
|
|
require.True(t, ctx.Snapshot)
|
|
require.True(t, ctx.SkipValidate)
|
|
require.True(t, ctx.SkipTokenCheck)
|
|
})
|
|
|
|
t.Run("skips", func(t *testing.T) {
|
|
ctx := setup(buildOpts{
|
|
skipValidate: true,
|
|
skipPostHooks: true,
|
|
})
|
|
require.True(t, ctx.SkipValidate)
|
|
require.True(t, ctx.SkipPostBuildHooks)
|
|
require.True(t, ctx.SkipTokenCheck)
|
|
})
|
|
|
|
t.Run("parallelism", func(t *testing.T) {
|
|
require.Equal(t, 1, setup(buildOpts{
|
|
parallelism: 1,
|
|
}).Parallelism)
|
|
})
|
|
|
|
t.Run("rm dist", func(t *testing.T) {
|
|
require.True(t, setup(buildOpts{
|
|
rmDist: true,
|
|
}).RmDist)
|
|
})
|
|
|
|
t.Run("single-target", func(t *testing.T) {
|
|
opts := buildOpts{
|
|
singleTarget: true,
|
|
}
|
|
|
|
t.Run("runtime", func(t *testing.T) {
|
|
result := setup(opts)
|
|
require.Equal(t, []string{runtime.GOOS}, result.Config.Builds[0].Goos)
|
|
require.Equal(t, []string{runtime.GOARCH}, result.Config.Builds[0].Goarch)
|
|
})
|
|
|
|
t.Run("from env", func(t *testing.T) {
|
|
os.Setenv("GOOS", "linux")
|
|
os.Setenv("GOARCH", "arm64")
|
|
t.Cleanup(func() {
|
|
os.Unsetenv("GOOS")
|
|
os.Unsetenv("GOARCH")
|
|
})
|
|
result := setup(opts)
|
|
require.Equal(t, []string{"linux"}, result.Config.Builds[0].Goos)
|
|
require.Equal(t, []string{"arm64"}, result.Config.Builds[0].Goarch)
|
|
})
|
|
})
|
|
|
|
t.Run("id", func(t *testing.T) {
|
|
t.Run("match", func(t *testing.T) {
|
|
ctx := context.New(config.Project{
|
|
Builds: []config.Build{
|
|
{
|
|
ID: "default",
|
|
},
|
|
{
|
|
ID: "foo",
|
|
},
|
|
},
|
|
})
|
|
require.NoError(t, setupBuildContext(ctx, buildOpts{
|
|
ids: []string{"foo"},
|
|
}))
|
|
})
|
|
|
|
t.Run("match-multiple", func(t *testing.T) {
|
|
ctx := context.New(config.Project{
|
|
Builds: []config.Build{
|
|
{
|
|
ID: "default",
|
|
},
|
|
{
|
|
ID: "foo",
|
|
},
|
|
},
|
|
})
|
|
require.NoError(t, setupBuildContext(ctx, buildOpts{
|
|
ids: []string{"foo", "default"},
|
|
}))
|
|
})
|
|
|
|
t.Run("match-partial", func(t *testing.T) {
|
|
ctx := context.New(config.Project{
|
|
Builds: []config.Build{
|
|
{
|
|
ID: "default",
|
|
},
|
|
{
|
|
ID: "foo",
|
|
},
|
|
},
|
|
})
|
|
require.NoError(t, setupBuildContext(ctx, buildOpts{
|
|
ids: []string{"foo", "notdefault"},
|
|
}))
|
|
})
|
|
|
|
t.Run("dont match", func(t *testing.T) {
|
|
ctx := context.New(config.Project{
|
|
Builds: []config.Build{
|
|
{
|
|
ID: "foo",
|
|
},
|
|
{
|
|
ID: "bazz",
|
|
},
|
|
},
|
|
})
|
|
require.EqualError(t, setupBuildContext(ctx, buildOpts{
|
|
ids: []string{"bar", "fooz"},
|
|
}), "no builds with ids bar, fooz")
|
|
})
|
|
|
|
t.Run("default config", func(t *testing.T) {
|
|
ctx := context.New(config.Project{})
|
|
require.NoError(t, setupBuildContext(ctx, buildOpts{
|
|
ids: []string{"aaa"},
|
|
}))
|
|
})
|
|
|
|
t.Run("single build config", func(t *testing.T) {
|
|
ctx := context.New(config.Project{
|
|
Builds: []config.Build{
|
|
{
|
|
ID: "foo",
|
|
},
|
|
},
|
|
})
|
|
require.NoError(t, setupBuildContext(ctx, buildOpts{
|
|
ids: []string{"not foo but doesnt matter"},
|
|
}))
|
|
})
|
|
})
|
|
}
|