mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-06 03:13:48 +02:00
fix: custom targets if missing goamd64, goarm, gomips (#3056)
* fix: custom targets if missing goamd64, goarm, gomips if the user provide custom targets without the goamd64, goarm or gomips bit, things may go awry at some point. this prevents issues by suffixing them with the default when its missing. closes https://github.com/goreleaser/goreleaser/issues/3055 Signed-off-by: Carlos A Becker <caarlos0@gmail.com> * test: fix build tests Signed-off-by: Carlos A Becker <caarlos0@gmail.com>
This commit is contained in:
parent
922992ce76
commit
63436392db
@ -69,6 +69,21 @@ func (*Builder) WithDefaults(build config.Build) (config.Build, error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return build, err
|
return build, err
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
for i, target := range build.Targets {
|
||||||
|
if strings.HasSuffix(target, "_amd64") {
|
||||||
|
build.Targets[i] = target + "_v1"
|
||||||
|
}
|
||||||
|
if strings.HasSuffix(target, "_arm") {
|
||||||
|
build.Targets[i] = target + "_6"
|
||||||
|
}
|
||||||
|
if strings.HasSuffix(target, "_mips") ||
|
||||||
|
strings.HasSuffix(target, "_mips64") ||
|
||||||
|
strings.HasSuffix(target, "_mipsle") ||
|
||||||
|
strings.HasSuffix(target, "_mips64le") {
|
||||||
|
build.Targets[i] = target + "_hardfloat"
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return build, nil
|
return build, nil
|
||||||
}
|
}
|
||||||
|
@ -95,6 +95,66 @@ func TestWithDefaults(t *testing.T) {
|
|||||||
},
|
},
|
||||||
goBinary: "go",
|
goBinary: "go",
|
||||||
},
|
},
|
||||||
|
"custom targets no amd64": {
|
||||||
|
build: config.Build{
|
||||||
|
ID: "foo3",
|
||||||
|
Binary: "foo",
|
||||||
|
Targets: []string{
|
||||||
|
"linux_386",
|
||||||
|
"darwin_amd64",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
targets: []string{
|
||||||
|
"linux_386",
|
||||||
|
"darwin_amd64_v1",
|
||||||
|
},
|
||||||
|
goBinary: "go",
|
||||||
|
},
|
||||||
|
"custom targets no arm": {
|
||||||
|
build: config.Build{
|
||||||
|
ID: "foo3",
|
||||||
|
Binary: "foo",
|
||||||
|
Targets: []string{"linux_arm"},
|
||||||
|
},
|
||||||
|
targets: []string{"linux_arm_6"},
|
||||||
|
goBinary: "go",
|
||||||
|
},
|
||||||
|
"custom targets no mips": {
|
||||||
|
build: config.Build{
|
||||||
|
ID: "foo3",
|
||||||
|
Binary: "foo",
|
||||||
|
Targets: []string{"linux_mips"},
|
||||||
|
},
|
||||||
|
targets: []string{"linux_mips_hardfloat"},
|
||||||
|
goBinary: "go",
|
||||||
|
},
|
||||||
|
"custom targets no mipsle": {
|
||||||
|
build: config.Build{
|
||||||
|
ID: "foo3",
|
||||||
|
Binary: "foo",
|
||||||
|
Targets: []string{"linux_mipsle"},
|
||||||
|
},
|
||||||
|
targets: []string{"linux_mipsle_hardfloat"},
|
||||||
|
goBinary: "go",
|
||||||
|
},
|
||||||
|
"custom targets no mips64": {
|
||||||
|
build: config.Build{
|
||||||
|
ID: "foo3",
|
||||||
|
Binary: "foo",
|
||||||
|
Targets: []string{"linux_mips64"},
|
||||||
|
},
|
||||||
|
targets: []string{"linux_mips64_hardfloat"},
|
||||||
|
goBinary: "go",
|
||||||
|
},
|
||||||
|
"custom targets no mips64le": {
|
||||||
|
build: config.Build{
|
||||||
|
ID: "foo3",
|
||||||
|
Binary: "foo",
|
||||||
|
Targets: []string{"linux_mips64le"},
|
||||||
|
},
|
||||||
|
targets: []string{"linux_mips64le_hardfloat"},
|
||||||
|
goBinary: "go",
|
||||||
|
},
|
||||||
"empty with custom dir": {
|
"empty with custom dir": {
|
||||||
build: config.Build{
|
build: config.Build{
|
||||||
ID: "foo2",
|
ID: "foo2",
|
||||||
|
@ -562,11 +562,12 @@ func TestBuildOptionsForTarget(t *testing.T) {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
expectedOpts: &api.Options{
|
expectedOpts: &api.Options{
|
||||||
Name: "testbinary",
|
Name: "testbinary",
|
||||||
Path: filepath.Join(tmpDir, "testid_linux_amd64", "testbinary"),
|
Path: filepath.Join(tmpDir, "testid_linux_amd64_v1", "testbinary"),
|
||||||
Target: "linux_amd64",
|
Target: "linux_amd64_v1",
|
||||||
Goos: "linux",
|
Goos: "linux",
|
||||||
Goarch: "amd64",
|
Goarch: "amd64",
|
||||||
|
Goamd64: "v1",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -579,11 +580,12 @@ func TestBuildOptionsForTarget(t *testing.T) {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
expectedOpts: &api.Options{
|
expectedOpts: &api.Options{
|
||||||
Name: "testbinary_linux_amd64",
|
Name: "testbinary_linux_amd64",
|
||||||
Path: filepath.Join(tmpDir, "testid_linux_amd64", "testbinary_linux_amd64"),
|
Path: filepath.Join(tmpDir, "testid_linux_amd64_v1", "testbinary_linux_amd64"),
|
||||||
Target: "linux_amd64",
|
Target: "linux_amd64_v1",
|
||||||
Goos: "linux",
|
Goos: "linux",
|
||||||
Goarch: "amd64",
|
Goarch: "amd64",
|
||||||
|
Goamd64: "v1",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -597,11 +599,12 @@ func TestBuildOptionsForTarget(t *testing.T) {
|
|||||||
NoUniqueDistDir: true,
|
NoUniqueDistDir: true,
|
||||||
},
|
},
|
||||||
expectedOpts: &api.Options{
|
expectedOpts: &api.Options{
|
||||||
Name: "distpath/linux/amd64/testbinary_linux_amd64",
|
Name: "distpath/linux/amd64/testbinary_linux_amd64",
|
||||||
Path: filepath.Join(tmpDir, "distpath", "linux", "amd64", "testbinary_linux_amd64"),
|
Path: filepath.Join(tmpDir, "distpath", "linux", "amd64", "testbinary_linux_amd64"),
|
||||||
Target: "linux_amd64",
|
Target: "linux_amd64_v1",
|
||||||
Goos: "linux",
|
Goos: "linux",
|
||||||
Goarch: "amd64",
|
Goarch: "amd64",
|
||||||
|
Goamd64: "v1",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user