mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-08 03:31:59 +02:00
ecb800aef7
* feat: store artifact list into dist/artifacts.json Signed-off-by: Carlos A Becker <caarlos0@gmail.com> * chore: fmt Signed-off-by: Carlos A Becker <caarlos0@gmail.com>
393 lines
7.6 KiB
Go
393 lines
7.6 KiB
Go
package artifact
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
"golang.org/x/sync/errgroup"
|
|
)
|
|
|
|
// ensure Type implements the stringer interface...
|
|
var _ fmt.Stringer = Type(0)
|
|
|
|
func TestAdd(t *testing.T) {
|
|
var g errgroup.Group
|
|
artifacts := New()
|
|
for _, a := range []*Artifact{
|
|
{
|
|
Name: "foo",
|
|
Type: UploadableArchive,
|
|
},
|
|
{
|
|
Name: "bar",
|
|
Type: Binary,
|
|
},
|
|
{
|
|
Name: "foobar",
|
|
Type: DockerImage,
|
|
},
|
|
{
|
|
Name: "check",
|
|
Type: Checksum,
|
|
},
|
|
} {
|
|
a := a
|
|
g.Go(func() error {
|
|
artifacts.Add(a)
|
|
return nil
|
|
})
|
|
}
|
|
require.NoError(t, g.Wait())
|
|
require.Len(t, artifacts.List(), 4)
|
|
}
|
|
|
|
func TestFilter(t *testing.T) {
|
|
data := []*Artifact{
|
|
{
|
|
Name: "foo",
|
|
Goos: "linux",
|
|
Goarch: "arm",
|
|
},
|
|
{
|
|
Name: "bar",
|
|
Goarch: "amd64",
|
|
},
|
|
{
|
|
Name: "foobar",
|
|
Goarm: "6",
|
|
},
|
|
{
|
|
Name: "check",
|
|
Type: Checksum,
|
|
},
|
|
{
|
|
Name: "checkzumm",
|
|
Type: Checksum,
|
|
},
|
|
}
|
|
artifacts := New()
|
|
for _, a := range data {
|
|
artifacts.Add(a)
|
|
}
|
|
|
|
require.Len(t, artifacts.Filter(ByGoos("linux")).items, 1)
|
|
require.Len(t, artifacts.Filter(ByGoos("darwin")).items, 0)
|
|
|
|
require.Len(t, artifacts.Filter(ByGoarch("amd64")).items, 1)
|
|
require.Len(t, artifacts.Filter(ByGoarch("386")).items, 0)
|
|
|
|
require.Len(t, artifacts.Filter(ByGoarm("6")).items, 1)
|
|
require.Len(t, artifacts.Filter(ByGoarm("7")).items, 0)
|
|
|
|
require.Len(t, artifacts.Filter(ByType(Checksum)).items, 2)
|
|
require.Len(t, artifacts.Filter(ByType(Binary)).items, 0)
|
|
|
|
require.Len(t, artifacts.Filter(nil).items, 5)
|
|
|
|
require.Len(t, artifacts.Filter(
|
|
And(
|
|
ByType(Checksum),
|
|
func(a *Artifact) bool {
|
|
return a.Name == "checkzumm"
|
|
},
|
|
),
|
|
).List(), 1)
|
|
|
|
require.Len(t, artifacts.Filter(
|
|
Or(
|
|
ByType(Checksum),
|
|
And(
|
|
ByGoos("linux"),
|
|
ByGoarm("arm"),
|
|
),
|
|
),
|
|
).List(), 2)
|
|
}
|
|
|
|
func TestRemove(t *testing.T) {
|
|
data := []*Artifact{
|
|
{
|
|
Name: "foo",
|
|
Goos: "linux",
|
|
Goarch: "arm",
|
|
Type: Binary,
|
|
},
|
|
{
|
|
Name: "universal",
|
|
Goos: "darwin",
|
|
Goarch: "all",
|
|
Type: UniversalBinary,
|
|
},
|
|
{
|
|
Name: "bar",
|
|
Goarch: "amd64",
|
|
},
|
|
{
|
|
Name: "checks",
|
|
Type: Checksum,
|
|
},
|
|
}
|
|
|
|
t.Run("null filter", func(t *testing.T) {
|
|
artifacts := New()
|
|
for _, a := range data {
|
|
artifacts.Add(a)
|
|
}
|
|
require.NoError(t, artifacts.Remove(nil))
|
|
require.Len(t, artifacts.List(), len(data))
|
|
})
|
|
|
|
t.Run("removing", func(t *testing.T) {
|
|
artifacts := New()
|
|
for _, a := range data {
|
|
artifacts.Add(a)
|
|
}
|
|
require.NoError(t, artifacts.Remove(
|
|
Or(
|
|
ByType(Checksum),
|
|
ByType(UniversalBinary),
|
|
And(
|
|
ByGoos("linux"),
|
|
ByGoarch("arm"),
|
|
),
|
|
),
|
|
))
|
|
|
|
require.Len(t, artifacts.List(), 1)
|
|
})
|
|
}
|
|
|
|
func TestGroupByPlatform(t *testing.T) {
|
|
data := []*Artifact{
|
|
{
|
|
Name: "foo",
|
|
Goos: "linux",
|
|
Goarch: "amd64",
|
|
},
|
|
{
|
|
Name: "bar",
|
|
Goos: "linux",
|
|
Goarch: "amd64",
|
|
},
|
|
{
|
|
Name: "foobar",
|
|
Goos: "linux",
|
|
Goarch: "arm",
|
|
Goarm: "6",
|
|
},
|
|
{
|
|
Name: "foobar",
|
|
Goos: "linux",
|
|
Goarch: "mips",
|
|
Goarm: "softfloat",
|
|
},
|
|
{
|
|
Name: "foobar",
|
|
Goos: "linux",
|
|
Goarch: "mips",
|
|
Goarm: "hardfloat",
|
|
},
|
|
{
|
|
Name: "check",
|
|
Type: Checksum,
|
|
},
|
|
}
|
|
artifacts := New()
|
|
for _, a := range data {
|
|
artifacts.Add(a)
|
|
}
|
|
|
|
groups := artifacts.GroupByPlatform()
|
|
require.Len(t, groups["linuxamd64"], 2)
|
|
require.Len(t, groups["linuxarm6"], 1)
|
|
require.Len(t, groups["linuxmipssoftfloat"], 1)
|
|
require.Len(t, groups["linuxmipshardfloat"], 1)
|
|
}
|
|
|
|
func TestChecksum(t *testing.T) {
|
|
folder := t.TempDir()
|
|
file := filepath.Join(folder, "subject")
|
|
require.NoError(t, os.WriteFile(file, []byte("lorem ipsum"), 0o644))
|
|
|
|
artifact := Artifact{
|
|
Path: file,
|
|
}
|
|
|
|
for algo, result := range map[string]string{
|
|
"sha256": "5e2bf57d3f40c4b6df69daf1936cb766f832374b4fc0259a7cbff06e2f70f269",
|
|
"sha512": "f80eebd9aabb1a15fb869ed568d858a5c0dca3d5da07a410e1bd988763918d973e344814625f7c844695b2de36ffd27af290d0e34362c51dee5947d58d40527a",
|
|
"sha1": "bfb7759a67daeb65410490b4d98bb9da7d1ea2ce",
|
|
"crc32": "72d7748e",
|
|
"md5": "80a751fde577028640c419000e33eba6",
|
|
"sha224": "e191edf06005712583518ced92cc2ac2fac8d6e4623b021a50736a91",
|
|
"sha384": "597493a6cf1289757524e54dfd6f68b332c7214a716a3358911ef5c09907adc8a654a18c1d721e183b0025f996f6e246",
|
|
} {
|
|
t.Run(algo, func(t *testing.T) {
|
|
sum, err := artifact.Checksum(algo)
|
|
require.NoError(t, err)
|
|
require.Equal(t, result, sum)
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestChecksumFileDoesntExist(t *testing.T) {
|
|
file := filepath.Join(t.TempDir(), "nope")
|
|
artifact := Artifact{
|
|
Path: file,
|
|
}
|
|
sum, err := artifact.Checksum("sha1")
|
|
require.EqualError(t, err, fmt.Sprintf(`failed to checksum: open %s: no such file or directory`, file))
|
|
require.Empty(t, sum)
|
|
}
|
|
|
|
func TestInvalidAlgorithm(t *testing.T) {
|
|
f, err := os.CreateTemp(t.TempDir(), "")
|
|
require.NoError(t, err)
|
|
require.NoError(t, f.Close())
|
|
artifact := Artifact{
|
|
Path: f.Name(),
|
|
}
|
|
sum, err := artifact.Checksum("sha1ssss")
|
|
require.EqualError(t, err, `invalid algorithm: sha1ssss`)
|
|
require.Empty(t, sum)
|
|
}
|
|
|
|
func TestExtraOr(t *testing.T) {
|
|
a := &Artifact{
|
|
Extra: map[string]interface{}{
|
|
"Foo": "foo",
|
|
},
|
|
}
|
|
require.Equal(t, "foo", a.ExtraOr("Foo", "bar"))
|
|
require.Equal(t, "bar", a.ExtraOr("Foobar", "bar"))
|
|
}
|
|
|
|
func TestByIDs(t *testing.T) {
|
|
data := []*Artifact{
|
|
{
|
|
Name: "foo",
|
|
Extra: map[string]interface{}{
|
|
ExtraID: "foo",
|
|
},
|
|
},
|
|
{
|
|
Name: "bar",
|
|
Extra: map[string]interface{}{
|
|
ExtraID: "bar",
|
|
},
|
|
},
|
|
{
|
|
Name: "foobar",
|
|
Extra: map[string]interface{}{
|
|
ExtraID: "foo",
|
|
},
|
|
},
|
|
{
|
|
Name: "check",
|
|
Extra: map[string]interface{}{
|
|
ExtraID: "check",
|
|
},
|
|
},
|
|
{
|
|
Name: "checksum",
|
|
Type: Checksum,
|
|
},
|
|
}
|
|
artifacts := New()
|
|
for _, a := range data {
|
|
artifacts.Add(a)
|
|
}
|
|
|
|
require.Len(t, artifacts.Filter(ByIDs("check")).items, 2)
|
|
require.Len(t, artifacts.Filter(ByIDs("foo")).items, 3)
|
|
require.Len(t, artifacts.Filter(ByIDs("foo", "bar")).items, 4)
|
|
}
|
|
|
|
func TestByFormats(t *testing.T) {
|
|
data := []*Artifact{
|
|
{
|
|
Name: "foo",
|
|
Extra: map[string]interface{}{
|
|
ExtraFormat: "zip",
|
|
},
|
|
},
|
|
{
|
|
Name: "bar",
|
|
Extra: map[string]interface{}{
|
|
ExtraFormat: "tar.gz",
|
|
},
|
|
},
|
|
{
|
|
Name: "foobar",
|
|
Extra: map[string]interface{}{
|
|
ExtraFormat: "zip",
|
|
},
|
|
},
|
|
{
|
|
Name: "bin",
|
|
Extra: map[string]interface{}{
|
|
ExtraFormat: "binary",
|
|
},
|
|
},
|
|
}
|
|
artifacts := New()
|
|
for _, a := range data {
|
|
artifacts.Add(a)
|
|
}
|
|
|
|
require.Len(t, artifacts.Filter(ByFormats("binary")).items, 1)
|
|
require.Len(t, artifacts.Filter(ByFormats("zip")).items, 2)
|
|
require.Len(t, artifacts.Filter(ByFormats("zip", "tar.gz")).items, 3)
|
|
}
|
|
|
|
func TestTypeToString(t *testing.T) {
|
|
for _, a := range []Type{
|
|
UploadableArchive,
|
|
UploadableBinary,
|
|
UploadableFile,
|
|
Binary,
|
|
UniversalBinary,
|
|
LinuxPackage,
|
|
PublishableSnapcraft,
|
|
Snapcraft,
|
|
PublishableDockerImage,
|
|
DockerImage,
|
|
DockerManifest,
|
|
Checksum,
|
|
Signature,
|
|
Certificate,
|
|
UploadableSourceArchive,
|
|
BrewTap,
|
|
GoFishRig,
|
|
KrewPluginManifest,
|
|
ScoopManifest,
|
|
} {
|
|
t.Run(a.String(), func(t *testing.T) {
|
|
require.NotEqual(t, "unknown", a.String())
|
|
bts, err := a.MarshalJSON()
|
|
require.NoError(t, err)
|
|
require.Equal(t, []byte(`"`+a.String()+`"`), bts)
|
|
})
|
|
}
|
|
t.Run("unknown", func(t *testing.T) {
|
|
require.Equal(t, "unknown", Type(9999).String())
|
|
bts, err := Type(9999).MarshalJSON()
|
|
require.NoError(t, err)
|
|
require.Equal(t, []byte(`"unknown"`), bts)
|
|
})
|
|
}
|
|
|
|
func TestPaths(t *testing.T) {
|
|
paths := []string{"a/b", "b/c", "d/e", "f/g"}
|
|
artifacts := New()
|
|
for _, a := range paths {
|
|
artifacts.Add(&Artifact{
|
|
Path: a,
|
|
})
|
|
}
|
|
require.ElementsMatch(t, paths, artifacts.Paths())
|
|
}
|