1
1
Fork 0
mirror of https://github.com/goreleaser/nfpm synced 2024-05-04 23:26:09 +02:00
nfpm/acceptance_test.go
Carlos A Becker fb0a007440
chore: fmt
Signed-off-by: Carlos A Becker <caarlos0@gmail.com>
2021-10-12 14:42:00 -03:00

328 lines
8.8 KiB
Go

//go:build acceptance
// +build acceptance
package nfpm_test
import (
"fmt"
"os"
"os/exec"
"path/filepath"
"testing"
"github.com/goreleaser/nfpm/v2"
_ "github.com/goreleaser/nfpm/v2/apk"
_ "github.com/goreleaser/nfpm/v2/deb"
_ "github.com/goreleaser/nfpm/v2/rpm"
"github.com/stretchr/testify/require"
)
// nolint: gochecknoglobals
var formatArchs = map[string][]string{
"apk": {"amd64", "arm64", "386", "ppc64le"},
"deb": {"amd64", "arm64", "ppc64le"},
"rpm": {"amd64", "arm64", "ppc64le"},
}
func TestCore(t *testing.T) {
t.Parallel()
testNames := []string{
"min",
"simple",
"no-glob",
"complex",
"env-var-version",
"overrides",
"meta",
"withchangelog",
"symlink",
"signed",
}
for _, name := range testNames {
for format, architecture := range formatArchs {
for _, arch := range architecture {
func(tt *testing.T, testName, testFormat, testArch string) {
tt.Run(fmt.Sprintf("%s/%s/%s", testFormat, testArch, testName), func(ttt *testing.T) {
ttt.Parallel()
if testArch == "ppc64le" && os.Getenv("NO_TEST_PPC64LE") == "true" {
ttt.Skip("ppc64le arch not supported in pipeline")
}
accept(ttt, acceptParms{
Name: fmt.Sprintf("%s_%s", testName, testArch),
Conf: fmt.Sprintf("core.%s.yaml", testName),
Format: testFormat,
Docker: dockerParams{
File: fmt.Sprintf("%s.dockerfile", testFormat),
Target: testName,
Arch: testArch,
},
})
})
}(t, name, format, arch)
}
}
}
}
func TestUpgrade(t *testing.T) {
t.Parallel()
testNames := []string{
"upgrade",
}
for _, name := range testNames {
for format, architecture := range formatArchs {
for _, arch := range architecture {
func(tt *testing.T, testName, testFormat, testArch string) {
tt.Run(fmt.Sprintf("%s/%s/%s", testFormat, testArch, testName), func(ttt *testing.T) {
ttt.Parallel()
if testArch == "ppc64le" && os.Getenv("NO_TEST_PPC64LE") == "true" {
ttt.Skip("ppc64le arch not supported in pipeline")
}
oldpkg := fmt.Sprintf("tmp/%s_%s.v1.%s", testName, testArch, testFormat)
target := fmt.Sprintf("./testdata/acceptance/%s", oldpkg)
require.NoError(t, os.MkdirAll("./testdata/acceptance/tmp", 0o700))
config, err := nfpm.ParseFileWithEnvMapping(fmt.Sprintf("./testdata/acceptance/%s.v1.yaml", testName),
func(s string) string {
switch s {
case "BUILD_ARCH":
return testArch
case "SEMVER":
return "v1.0.0-0.1.b1+git.abcdefgh"
default:
return os.Getenv(s)
}
},
)
require.NoError(t, err)
info, err := config.Get(testFormat)
require.NoError(t, err)
require.NoError(t, nfpm.Validate(info))
pkg, err := nfpm.Get(testFormat)
require.NoError(t, err)
f, err := os.Create(target)
require.NoError(t, err)
defer f.Close()
info.Target = target
require.NoError(t, pkg.Package(nfpm.WithDefaults(info), f))
accept(ttt, acceptParms{
Name: fmt.Sprintf("%s_%s.v2", testName, testArch),
Conf: fmt.Sprintf("%s.v2.yaml", testName),
Format: testFormat,
Docker: dockerParams{
File: fmt.Sprintf("%s.dockerfile", testFormat),
Target: testName,
Arch: testArch,
BuildArgs: []string{fmt.Sprintf("oldpackage=%s", oldpkg)},
},
})
})
}(t, name, format, arch)
}
}
}
}
func TestRPMCompression(t *testing.T) {
t.Parallel()
format := "rpm"
compressFormats := []string{"gzip", "xz", "lzma"}
for _, arch := range formatArchs[format] {
for _, compFormat := range compressFormats {
func(tt *testing.T, testCompFormat, testArch string) {
tt.Run(fmt.Sprintf("%s/%s/%s", format, testArch, testCompFormat), func(ttt *testing.T) {
ttt.Parallel()
if testArch == "ppc64le" && os.Getenv("NO_TEST_PPC64LE") == "true" {
ttt.Skip("ppc64le arch not supported in pipeline")
}
accept(ttt, acceptParms{
Name: fmt.Sprintf("%s_compression_%s", testCompFormat, testArch),
Conf: fmt.Sprintf("rpm.%s.compression.yaml", testCompFormat),
Format: format,
Docker: dockerParams{
File: fmt.Sprintf("%s.dockerfile", format),
Target: "compression",
Arch: testArch,
BuildArgs: []string{fmt.Sprintf("compression=%s", testCompFormat)},
},
})
})
}(t, compFormat, arch)
}
}
}
func TestDebCompression(t *testing.T) {
t.Parallel()
format := "deb"
compressFormats := []string{"gzip", "xz", "none"}
for _, arch := range formatArchs[format] {
for _, compFormat := range compressFormats {
func(tt *testing.T, testCompFormat, testArch string) {
tt.Run(fmt.Sprintf("%s/%s/%s", format, testArch, testCompFormat), func(ttt *testing.T) {
ttt.Parallel()
if testArch == "ppc64le" && os.Getenv("NO_TEST_PPC64LE") == "true" {
ttt.Skip("ppc64le arch not supported in pipeline")
}
accept(ttt, acceptParms{
Name: fmt.Sprintf("%s_compression_%s", testCompFormat, testArch),
Conf: fmt.Sprintf("deb.%s.compression.yaml", testCompFormat),
Format: format,
Docker: dockerParams{
File: fmt.Sprintf("%s.dockerfile", format),
Target: "compression",
Arch: testArch,
},
})
})
}(t, compFormat, arch)
}
}
}
func TestRPMSpecific(t *testing.T) {
t.Parallel()
format := "rpm"
testNames := []string{
"release",
}
for _, name := range testNames {
for _, arch := range formatArchs[format] {
func(tt *testing.T, testName, testArch string) {
tt.Run(fmt.Sprintf("%s/%s/%s", format, testArch, testName), func(ttt *testing.T) {
ttt.Parallel()
if testArch == "ppc64le" && os.Getenv("NO_TEST_PPC64LE") == "true" {
ttt.Skip("ppc64le arch not supported in pipeline")
}
accept(ttt, acceptParms{
Name: fmt.Sprintf("%s_%s", testName, testArch),
Conf: fmt.Sprintf("%s.%s.yaml", format, testName),
Format: format,
Docker: dockerParams{
File: fmt.Sprintf("%s.dockerfile", format),
Target: testName,
Arch: testArch,
},
})
})
}(t, name, arch)
}
}
}
func TestDebSpecific(t *testing.T) {
t.Parallel()
format := "deb"
testNames := []string{
"rules",
"triggers",
"breaks",
}
for _, name := range testNames {
for _, arch := range formatArchs[format] {
func(tt *testing.T, testName, testArch string) {
tt.Run(fmt.Sprintf("%s/%s/%s", format, testArch, testName), func(ttt *testing.T) {
ttt.Parallel()
if testArch == "ppc64le" && os.Getenv("NO_TEST_PPC64LE") == "true" {
ttt.Skip("ppc64le arch not supported in pipeline")
}
accept(ttt, acceptParms{
Name: fmt.Sprintf("%s_%s", testName, testArch),
Conf: fmt.Sprintf("%s.%s.yaml", format, testName),
Format: format,
Docker: dockerParams{
File: fmt.Sprintf("%s.dockerfile", format),
Target: testName,
Arch: testArch,
},
})
})
}(t, name, arch)
}
}
}
type acceptParms struct {
Name string
Conf string
Format string
Docker dockerParams
}
type dockerParams struct {
File string
Target string
Arch string
BuildArgs []string
}
type testWriter struct {
*testing.T
}
func (t testWriter) Write(p []byte) (n int, err error) {
t.Log(string(p))
return len(p), nil
}
func accept(t *testing.T, params acceptParms) {
t.Helper()
configFile := filepath.Join("./testdata/acceptance/", params.Conf)
tmp, err := filepath.Abs("./testdata/acceptance/tmp")
require.NoError(t, err)
packageName := params.Name + "." + params.Format
target := filepath.Join(tmp, packageName)
t.Log("package: " + target)
require.NoError(t, os.MkdirAll(tmp, 0o700))
envFunc := func(s string) string {
switch s {
case "BUILD_ARCH":
return params.Docker.Arch
case "SEMVER":
return "v1.0.0-0.1.b1+git.abcdefgh"
default:
return os.Getenv(s)
}
}
config, err := nfpm.ParseFileWithEnvMapping(configFile, envFunc)
require.NoError(t, err)
info, err := config.Get(params.Format)
require.NoError(t, err)
require.NoError(t, nfpm.Validate(info))
pkg, err := nfpm.Get(params.Format)
require.NoError(t, err)
cmdArgs := []string{
"build", "--rm", "--force-rm",
"--platform", fmt.Sprintf("linux/%s", params.Docker.Arch),
"-f", params.Docker.File,
"--target", params.Docker.Target,
"--build-arg", "package=" + filepath.Join("tmp", packageName),
}
for _, arg := range params.Docker.BuildArgs {
cmdArgs = append(cmdArgs, "--build-arg", arg)
}
cmdArgs = append(cmdArgs, ".")
f, err := os.Create(target)
require.NoError(t, err)
info.Target = target
require.NoError(t, pkg.Package(nfpm.WithDefaults(info), f))
//nolint:gosec
cmd := exec.Command("docker", cmdArgs...)
cmd.Dir = "./testdata/acceptance"
cmd.Stderr = testWriter{t}
cmd.Stdout = cmd.Stderr
t.Log("will exec:", cmd.Args, "with env BUILD_ARCH:", envFunc("BUILD_ARCH"))
require.NoError(t, cmd.Run())
}