1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-24 04:16:27 +02:00
goreleaser/cmd/build_test.go
Carlos Alexandro Becker f544c5ce69
test: testctx pkg (#3807)
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>
2023-03-02 00:01:11 -03:00

328 lines
7.3 KiB
Go

package cmd
import (
"os"
"runtime"
"testing"
"github.com/goreleaser/goreleaser/internal/pipeline"
"github.com/goreleaser/goreleaser/internal/testctx"
"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(testctx.New(), buildOpts{}),
)
})
t.Run("single-target", func(t *testing.T) {
require.Equal(
t,
pipeline.BuildCmdPipeline,
setupPipeline(testctx.New(), buildOpts{
singleTarget: true,
}),
)
})
t.Run("single-target and id", func(t *testing.T) {
require.Equal(
t,
pipeline.BuildCmdPipeline,
setupPipeline(testctx.New(), 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(testctx.New(), 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(
testctx.NewWithCfg(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(
testctx.New(),
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(
testctx.NewWithCfg(config.Project{
Builds: []config.Build{{}},
}),
buildOpts{
singleTarget: true,
output: "zaz",
},
),
)
})
}
func TestBuildFlags(t *testing.T) {
setup := func(opts buildOpts) *context.Context {
ctx := testctx.New()
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{
clean: true,
}).Clean)
})
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 := testctx.NewWithCfg(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 := testctx.NewWithCfg(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 := testctx.NewWithCfg(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 := testctx.NewWithCfg(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 := testctx.New()
require.NoError(t, setupBuildContext(ctx, buildOpts{
ids: []string{"aaa"},
}))
})
t.Run("single build config", func(t *testing.T) {
ctx := testctx.NewWithCfg(config.Project{
Builds: []config.Build{
{
ID: "foo",
},
},
})
require.NoError(t, setupBuildContext(ctx, buildOpts{
ids: []string{"not foo but doesnt matter"},
}))
})
})
}
func TestBuildSingleTargetWithSpecificTargets(t *testing.T) {
ctx := testctx.NewWithCfg(config.Project{
ProjectName: "test",
Builds: []config.Build{
{
Targets: []string{
"linux_amd64_v1",
"darwin_arm64",
"darwin_amd64_v1",
},
},
},
})
t.Setenv("GOOS", "linux")
t.Setenv("GOARCH", "amd64")
setupBuildSingleTarget(ctx)
require.Equal(t, config.Build{
Goos: []string{"linux"},
Goarch: []string{"amd64"},
}, ctx.Config.Builds[0])
}
func TestBuildSingleTargetRemoveOtherOptions(t *testing.T) {
ctx := testctx.NewWithCfg(config.Project{
ProjectName: "test",
Builds: []config.Build{
{
Goos: []string{"linux", "darwin"},
Goarch: []string{"amd64", "arm64"},
Goamd64: []string{"v1", "v2"},
Goarm: []string{"6"},
Gomips: []string{"anything"},
},
},
})
t.Setenv("GOOS", "linux")
t.Setenv("GOARCH", "amd64")
setupBuildSingleTarget(ctx)
require.Equal(t, config.Build{
Goos: []string{"linux"},
Goarch: []string{"amd64"},
}, ctx.Config.Builds[0])
}