2017-12-17 15:14:21 -02:00
|
|
|
package artifact
|
|
|
|
|
|
|
|
import (
|
2021-12-05 22:42:13 -03:00
|
|
|
"encoding/json"
|
2017-12-18 09:49:49 -02:00
|
|
|
"fmt"
|
2021-04-25 13:00:51 -03:00
|
|
|
"os"
|
2018-08-21 15:55:35 -03:00
|
|
|
"path/filepath"
|
2017-12-17 15:14:21 -02:00
|
|
|
"testing"
|
|
|
|
|
2021-12-05 22:42:13 -03:00
|
|
|
"github.com/goreleaser/goreleaser/internal/golden"
|
2022-06-23 23:36:19 -03:00
|
|
|
"github.com/goreleaser/goreleaser/pkg/config"
|
2022-02-25 09:28:09 -05:00
|
|
|
"github.com/stretchr/testify/assert"
|
2018-08-21 15:55:35 -03:00
|
|
|
"github.com/stretchr/testify/require"
|
2017-12-17 15:14:21 -02:00
|
|
|
"golang.org/x/sync/errgroup"
|
|
|
|
)
|
|
|
|
|
2017-12-18 09:49:49 -02:00
|
|
|
// ensure Type implements the stringer interface...
|
|
|
|
var _ fmt.Stringer = Type(0)
|
|
|
|
|
2017-12-17 15:14:21 -02:00
|
|
|
func TestAdd(t *testing.T) {
|
|
|
|
var g errgroup.Group
|
2021-04-25 11:34:40 -03:00
|
|
|
artifacts := New()
|
2019-08-12 17:44:48 -03:00
|
|
|
for _, a := range []*Artifact{
|
2017-12-17 15:14:21 -02:00
|
|
|
{
|
|
|
|
Name: "foo",
|
2017-12-17 16:31:06 -02:00
|
|
|
Type: UploadableArchive,
|
2017-12-17 15:14:21 -02:00
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "bar",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "foobar",
|
|
|
|
Type: DockerImage,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "check",
|
|
|
|
Type: Checksum,
|
|
|
|
},
|
|
|
|
} {
|
|
|
|
a := a
|
|
|
|
g.Go(func() error {
|
|
|
|
artifacts.Add(a)
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
}
|
2020-10-06 09:48:04 -03:00
|
|
|
require.NoError(t, g.Wait())
|
|
|
|
require.Len(t, artifacts.List(), 4)
|
2017-12-17 15:14:21 -02:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestFilter(t *testing.T) {
|
2021-04-25 11:34:40 -03:00
|
|
|
data := []*Artifact{
|
2017-12-17 15:14:21 -02:00
|
|
|
{
|
2017-12-17 16:59:54 -02:00
|
|
|
Name: "foo",
|
|
|
|
Goos: "linux",
|
|
|
|
Goarch: "arm",
|
2017-12-17 15:14:21 -02:00
|
|
|
},
|
2022-04-13 21:29:39 -03:00
|
|
|
{
|
|
|
|
Name: "bar",
|
|
|
|
Goarch: "amd64",
|
|
|
|
Goamd64: "v1",
|
|
|
|
},
|
2017-12-17 15:14:21 -02:00
|
|
|
{
|
2022-04-11 22:43:22 -03:00
|
|
|
Name: "bar",
|
|
|
|
Goarch: "amd64",
|
|
|
|
Goamd64: "v2",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "bar",
|
|
|
|
Goarch: "amd64",
|
|
|
|
Goamd64: "v3",
|
2017-12-17 15:14:21 -02:00
|
|
|
},
|
2022-04-13 21:29:39 -03:00
|
|
|
{
|
|
|
|
Name: "bar",
|
|
|
|
Goarch: "amd64",
|
|
|
|
Goamd64: "v4",
|
|
|
|
},
|
2017-12-17 15:14:21 -02:00
|
|
|
{
|
|
|
|
Name: "foobar",
|
|
|
|
Goarm: "6",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "check",
|
|
|
|
Type: Checksum,
|
|
|
|
},
|
2017-12-17 16:31:06 -02:00
|
|
|
{
|
|
|
|
Name: "checkzumm",
|
|
|
|
Type: Checksum,
|
|
|
|
},
|
2021-12-07 21:53:39 -03:00
|
|
|
{
|
|
|
|
Name: "unibin-replaces",
|
|
|
|
Goos: "darwin",
|
|
|
|
Goarch: "all",
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraReplaces: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "unibin-noreplace",
|
|
|
|
Goos: "darwin",
|
|
|
|
Goarch: "all",
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraReplaces: false,
|
|
|
|
},
|
|
|
|
},
|
2017-12-17 15:14:21 -02:00
|
|
|
}
|
2021-04-25 11:34:40 -03:00
|
|
|
artifacts := New()
|
2017-12-17 15:14:21 -02:00
|
|
|
for _, a := range data {
|
|
|
|
artifacts.Add(a)
|
|
|
|
}
|
2017-12-17 16:31:06 -02:00
|
|
|
|
2020-10-06 09:48:04 -03:00
|
|
|
require.Len(t, artifacts.Filter(ByGoos("linux")).items, 1)
|
2021-12-07 21:53:39 -03:00
|
|
|
require.Len(t, artifacts.Filter(ByGoos("darwin")).items, 2)
|
2017-12-17 15:14:21 -02:00
|
|
|
|
2022-04-13 21:29:39 -03:00
|
|
|
require.Len(t, artifacts.Filter(ByGoarch("amd64")).items, 4)
|
2020-10-06 09:48:04 -03:00
|
|
|
require.Len(t, artifacts.Filter(ByGoarch("386")).items, 0)
|
2017-12-17 15:14:21 -02:00
|
|
|
|
2022-04-13 21:29:39 -03:00
|
|
|
require.Len(t, artifacts.Filter(ByGoamd64("v1")).items, 1)
|
2022-04-11 22:43:22 -03:00
|
|
|
require.Len(t, artifacts.Filter(ByGoamd64("v2")).items, 1)
|
|
|
|
require.Len(t, artifacts.Filter(ByGoamd64("v3")).items, 1)
|
2022-04-13 21:29:39 -03:00
|
|
|
require.Len(t, artifacts.Filter(ByGoamd64("v4")).items, 1)
|
2022-04-11 22:43:22 -03:00
|
|
|
|
2020-10-06 09:48:04 -03:00
|
|
|
require.Len(t, artifacts.Filter(ByGoarm("6")).items, 1)
|
|
|
|
require.Len(t, artifacts.Filter(ByGoarm("7")).items, 0)
|
2017-12-17 15:14:21 -02:00
|
|
|
|
2020-10-06 09:48:04 -03:00
|
|
|
require.Len(t, artifacts.Filter(ByType(Checksum)).items, 2)
|
|
|
|
require.Len(t, artifacts.Filter(ByType(Binary)).items, 0)
|
2017-12-17 16:31:06 -02:00
|
|
|
|
2022-04-13 21:29:39 -03:00
|
|
|
require.Len(t, artifacts.Filter(OnlyReplacingUnibins).items, 9)
|
2021-12-07 21:53:39 -03:00
|
|
|
require.Len(t, artifacts.Filter(And(OnlyReplacingUnibins, ByGoos("darwin"))).items, 1)
|
|
|
|
|
2022-04-13 21:29:39 -03:00
|
|
|
require.Len(t, artifacts.Filter(nil).items, 10)
|
2020-05-10 17:03:49 +01:00
|
|
|
|
2020-10-06 09:48:04 -03:00
|
|
|
require.Len(t, artifacts.Filter(
|
2017-12-17 16:59:54 -02:00
|
|
|
And(
|
|
|
|
ByType(Checksum),
|
2019-08-12 17:44:48 -03:00
|
|
|
func(a *Artifact) bool {
|
2017-12-17 16:59:54 -02:00
|
|
|
return a.Name == "checkzumm"
|
|
|
|
},
|
|
|
|
),
|
|
|
|
).List(), 1)
|
|
|
|
|
2020-10-06 09:48:04 -03:00
|
|
|
require.Len(t, artifacts.Filter(
|
2017-12-17 16:59:54 -02:00
|
|
|
Or(
|
|
|
|
ByType(Checksum),
|
|
|
|
And(
|
|
|
|
ByGoos("linux"),
|
|
|
|
ByGoarm("arm"),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
).List(), 2)
|
2017-12-17 15:14:21 -02:00
|
|
|
}
|
2017-12-17 15:50:09 -02:00
|
|
|
|
2021-10-12 14:55:43 -03:00
|
|
|
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)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-01-23 23:49:40 -03:00
|
|
|
func TestGroupByID(t *testing.T) {
|
|
|
|
data := []*Artifact{
|
|
|
|
{
|
|
|
|
Name: "foo",
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraID: "foo",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "bar",
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraID: "foo",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "foobar",
|
|
|
|
Goos: "linux",
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraID: "foovar",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "foobar",
|
|
|
|
Goos: "linux",
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraID: "foovar",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "foobar",
|
|
|
|
Goos: "linux",
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraID: "foobar",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "check",
|
|
|
|
Type: Checksum,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
artifacts := New()
|
|
|
|
for _, a := range data {
|
|
|
|
artifacts.Add(a)
|
|
|
|
}
|
|
|
|
|
|
|
|
groups := artifacts.GroupByID()
|
|
|
|
require.Len(t, groups["foo"], 2)
|
|
|
|
require.Len(t, groups["foobar"], 1)
|
|
|
|
require.Len(t, groups["foovar"], 2)
|
|
|
|
require.Len(t, groups, 3)
|
|
|
|
}
|
|
|
|
|
2017-12-17 15:50:09 -02:00
|
|
|
func TestGroupByPlatform(t *testing.T) {
|
2021-04-25 11:34:40 -03:00
|
|
|
data := []*Artifact{
|
2017-12-17 15:50:09 -02:00
|
|
|
{
|
2022-04-11 22:43:22 -03:00
|
|
|
Name: "foo",
|
|
|
|
Goos: "linux",
|
|
|
|
Goarch: "amd64",
|
|
|
|
Goamd64: "v2",
|
2017-12-17 15:50:09 -02:00
|
|
|
},
|
|
|
|
{
|
2022-04-11 22:43:22 -03:00
|
|
|
Name: "bar",
|
|
|
|
Goos: "linux",
|
|
|
|
Goarch: "amd64",
|
|
|
|
Goamd64: "v2",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "bar",
|
|
|
|
Goos: "linux",
|
|
|
|
Goarch: "amd64",
|
|
|
|
Goamd64: "v3",
|
2017-12-17 15:50:09 -02:00
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "foobar",
|
|
|
|
Goos: "linux",
|
|
|
|
Goarch: "arm",
|
|
|
|
Goarm: "6",
|
|
|
|
},
|
2020-02-05 22:08:18 -03:00
|
|
|
{
|
|
|
|
Name: "foobar",
|
|
|
|
Goos: "linux",
|
|
|
|
Goarch: "mips",
|
|
|
|
Goarm: "softfloat",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "foobar",
|
|
|
|
Goos: "linux",
|
|
|
|
Goarch: "mips",
|
|
|
|
Goarm: "hardfloat",
|
|
|
|
},
|
2017-12-17 15:50:09 -02:00
|
|
|
{
|
|
|
|
Name: "check",
|
|
|
|
Type: Checksum,
|
|
|
|
},
|
|
|
|
}
|
2021-04-25 11:34:40 -03:00
|
|
|
artifacts := New()
|
2017-12-17 15:50:09 -02:00
|
|
|
for _, a := range data {
|
|
|
|
artifacts.Add(a)
|
|
|
|
}
|
|
|
|
|
2021-04-25 11:34:40 -03:00
|
|
|
groups := artifacts.GroupByPlatform()
|
2022-04-11 22:43:22 -03:00
|
|
|
require.Len(t, groups["linuxamd64v2"], 2)
|
|
|
|
require.Len(t, groups["linuxamd64v3"], 1)
|
2020-10-06 09:48:04 -03:00
|
|
|
require.Len(t, groups["linuxarm6"], 1)
|
|
|
|
require.Len(t, groups["linuxmipssoftfloat"], 1)
|
|
|
|
require.Len(t, groups["linuxmipshardfloat"], 1)
|
2017-12-17 15:50:09 -02:00
|
|
|
}
|
2018-08-21 15:55:35 -03:00
|
|
|
|
|
|
|
func TestChecksum(t *testing.T) {
|
2021-04-25 11:34:40 -03:00
|
|
|
folder := t.TempDir()
|
|
|
|
file := filepath.Join(folder, "subject")
|
2021-04-25 13:00:51 -03:00
|
|
|
require.NoError(t, os.WriteFile(file, []byte("lorem ipsum"), 0o644))
|
2018-08-21 15:55:35 -03:00
|
|
|
|
2021-04-25 11:34:40 -03:00
|
|
|
artifact := Artifact{
|
2018-08-21 15:55:35 -03:00
|
|
|
Path: file,
|
|
|
|
}
|
|
|
|
|
2019-02-04 17:27:51 -02:00
|
|
|
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)
|
|
|
|
})
|
|
|
|
}
|
2018-08-21 15:55:35 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestChecksumFileDoesntExist(t *testing.T) {
|
2021-04-25 11:34:40 -03:00
|
|
|
file := filepath.Join(t.TempDir(), "nope")
|
|
|
|
artifact := Artifact{
|
|
|
|
Path: file,
|
2018-08-21 15:55:35 -03:00
|
|
|
}
|
2019-02-04 17:27:51 -02:00
|
|
|
sum, err := artifact.Checksum("sha1")
|
2021-04-25 11:34:40 -03:00
|
|
|
require.EqualError(t, err, fmt.Sprintf(`failed to checksum: open %s: no such file or directory`, file))
|
2018-08-21 15:55:35 -03:00
|
|
|
require.Empty(t, sum)
|
|
|
|
}
|
2019-01-01 14:40:17 -02:00
|
|
|
|
2019-02-04 17:27:51 -02:00
|
|
|
func TestInvalidAlgorithm(t *testing.T) {
|
2021-11-21 15:10:08 +01:00
|
|
|
f, err := os.CreateTemp(t.TempDir(), "")
|
2019-02-04 17:27:51 -02:00
|
|
|
require.NoError(t, err)
|
2021-04-25 11:34:40 -03:00
|
|
|
require.NoError(t, f.Close())
|
|
|
|
artifact := Artifact{
|
2019-02-04 17:27:51 -02:00
|
|
|
Path: f.Name(),
|
|
|
|
}
|
|
|
|
sum, err := artifact.Checksum("sha1ssss")
|
2020-09-02 12:44:25 -07:00
|
|
|
require.EqualError(t, err, `invalid algorithm: sha1ssss`)
|
2019-02-04 17:27:51 -02:00
|
|
|
require.Empty(t, sum)
|
|
|
|
}
|
|
|
|
|
2022-06-23 23:36:19 -03:00
|
|
|
func TestExtra(t *testing.T) {
|
|
|
|
a := Artifact{
|
2019-01-01 14:40:17 -02:00
|
|
|
Extra: map[string]interface{}{
|
|
|
|
"Foo": "foo",
|
2022-06-23 23:36:19 -03:00
|
|
|
"docker": config.Docker{
|
|
|
|
ID: "id",
|
|
|
|
Use: "docker",
|
|
|
|
},
|
|
|
|
"fail-plz": config.Homebrew{
|
|
|
|
Plist: "aaaa",
|
|
|
|
},
|
|
|
|
"unsupported": func() {},
|
|
|
|
"binaries": []string{"foo", "bar"},
|
2019-01-01 14:40:17 -02:00
|
|
|
},
|
|
|
|
}
|
2022-06-23 23:36:19 -03:00
|
|
|
|
|
|
|
t.Run("string", func(t *testing.T) {
|
|
|
|
foo, err := Extra[string](a, "Foo")
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, "foo", foo)
|
|
|
|
require.Equal(t, "foo", ExtraOr(a, "Foo", "bar"))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("missing field", func(t *testing.T) {
|
|
|
|
bar, err := Extra[string](a, "Foobar")
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, "", bar)
|
|
|
|
require.Equal(t, "bar", ExtraOr(a, "Foobar", "bar"))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("complex", func(t *testing.T) {
|
|
|
|
docker, err := Extra[config.Docker](a, "docker")
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, "id", docker.ID)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("array", func(t *testing.T) {
|
|
|
|
binaries, err := Extra[[]string](a, "binaries")
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, []string{"foo", "bar"}, binaries)
|
|
|
|
require.Equal(t, []string{"foo", "bar"}, ExtraOr(a, "binaries", []string{}))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("unmarshal error", func(t *testing.T) {
|
|
|
|
_, err := Extra[config.Docker](a, "fail-plz")
|
2022-08-06 18:44:23 -03:00
|
|
|
require.EqualError(t, err, "json: unknown field \"tap\"")
|
2022-06-23 23:36:19 -03:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("marshal error", func(t *testing.T) {
|
|
|
|
_, err := Extra[config.Docker](a, "unsupported")
|
|
|
|
require.EqualError(t, err, "json: unsupported type: func()")
|
|
|
|
})
|
2019-01-01 14:40:17 -02:00
|
|
|
}
|
2019-04-16 10:19:15 -03:00
|
|
|
|
|
|
|
func TestByIDs(t *testing.T) {
|
2021-04-25 11:34:40 -03:00
|
|
|
data := []*Artifact{
|
2019-04-16 10:19:15 -03:00
|
|
|
{
|
|
|
|
Name: "foo",
|
|
|
|
Extra: map[string]interface{}{
|
2021-10-16 22:46:11 -03:00
|
|
|
ExtraID: "foo",
|
2019-04-16 10:19:15 -03:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "bar",
|
|
|
|
Extra: map[string]interface{}{
|
2021-10-16 22:46:11 -03:00
|
|
|
ExtraID: "bar",
|
2019-04-16 10:19:15 -03:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "foobar",
|
|
|
|
Extra: map[string]interface{}{
|
2021-10-16 22:46:11 -03:00
|
|
|
ExtraID: "foo",
|
2019-04-16 10:19:15 -03:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "check",
|
|
|
|
Extra: map[string]interface{}{
|
2021-10-16 22:46:11 -03:00
|
|
|
ExtraID: "check",
|
2019-04-16 10:19:15 -03:00
|
|
|
},
|
|
|
|
},
|
2019-11-08 09:10:56 -03:00
|
|
|
{
|
|
|
|
Name: "checksum",
|
|
|
|
Type: Checksum,
|
|
|
|
},
|
2019-04-16 10:19:15 -03:00
|
|
|
}
|
2021-04-25 11:34:40 -03:00
|
|
|
artifacts := New()
|
2019-04-16 10:19:15 -03:00
|
|
|
for _, a := range data {
|
|
|
|
artifacts.Add(a)
|
|
|
|
}
|
|
|
|
|
2019-11-08 09:10:56 -03:00
|
|
|
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)
|
2019-04-16 10:19:15 -03:00
|
|
|
}
|
2019-06-10 10:35:19 -03:00
|
|
|
|
2022-03-19 17:44:34 -03:00
|
|
|
func TestByExts(t *testing.T) {
|
|
|
|
data := []*Artifact{
|
|
|
|
{
|
|
|
|
Name: "foo",
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraExt: "deb",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "bar",
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraExt: "deb",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "foobar",
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraExt: "rpm",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "check",
|
|
|
|
Extra: map[string]interface{}{},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
artifacts := New()
|
|
|
|
for _, a := range data {
|
|
|
|
artifacts.Add(a)
|
|
|
|
}
|
|
|
|
|
|
|
|
require.Len(t, artifacts.Filter(ByExt("deb")).items, 2)
|
|
|
|
require.Len(t, artifacts.Filter(ByExt("rpm")).items, 1)
|
|
|
|
require.Len(t, artifacts.Filter(ByExt("rpm", "deb")).items, 3)
|
|
|
|
require.Len(t, artifacts.Filter(ByExt("foo")).items, 0)
|
|
|
|
}
|
|
|
|
|
2019-06-10 10:35:19 -03:00
|
|
|
func TestByFormats(t *testing.T) {
|
2021-04-25 11:34:40 -03:00
|
|
|
data := []*Artifact{
|
2019-06-10 10:35:19 -03:00
|
|
|
{
|
|
|
|
Name: "foo",
|
|
|
|
Extra: map[string]interface{}{
|
2021-10-16 22:46:11 -03:00
|
|
|
ExtraFormat: "zip",
|
2019-06-10 10:35:19 -03:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "bar",
|
|
|
|
Extra: map[string]interface{}{
|
2021-10-16 22:46:11 -03:00
|
|
|
ExtraFormat: "tar.gz",
|
2019-06-10 10:35:19 -03:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "foobar",
|
|
|
|
Extra: map[string]interface{}{
|
2021-10-16 22:46:11 -03:00
|
|
|
ExtraFormat: "zip",
|
2019-06-10 10:35:19 -03:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "bin",
|
|
|
|
Extra: map[string]interface{}{
|
2021-10-16 22:46:11 -03:00
|
|
|
ExtraFormat: "binary",
|
2019-06-10 10:35:19 -03:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
2021-04-25 11:34:40 -03:00
|
|
|
artifacts := New()
|
2019-06-10 10:35:19 -03:00
|
|
|
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)
|
|
|
|
}
|
2020-11-29 14:33:31 -03:00
|
|
|
|
2021-01-07 16:21:12 -03:00
|
|
|
func TestPaths(t *testing.T) {
|
2021-04-25 11:34:40 -03:00
|
|
|
paths := []string{"a/b", "b/c", "d/e", "f/g"}
|
|
|
|
artifacts := New()
|
2021-01-07 16:21:12 -03:00
|
|
|
for _, a := range paths {
|
|
|
|
artifacts.Add(&Artifact{
|
|
|
|
Path: a,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
require.ElementsMatch(t, paths, artifacts.Paths())
|
|
|
|
}
|
2021-12-05 22:42:13 -03:00
|
|
|
|
|
|
|
func TestRefresher(t *testing.T) {
|
|
|
|
t.Run("ok", func(t *testing.T) {
|
|
|
|
artifacts := New()
|
|
|
|
path := filepath.Join(t.TempDir(), "f")
|
|
|
|
artifacts.Add(&Artifact{
|
|
|
|
Name: "f",
|
|
|
|
Path: path,
|
|
|
|
Type: Checksum,
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
"Refresh": func() error {
|
|
|
|
return os.WriteFile(path, []byte("hello"), 0o765)
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
artifacts.Add(&Artifact{
|
|
|
|
Name: "no refresh",
|
|
|
|
Type: Checksum,
|
|
|
|
})
|
|
|
|
|
|
|
|
for _, item := range artifacts.List() {
|
|
|
|
require.NoError(t, item.Refresh())
|
|
|
|
}
|
|
|
|
|
|
|
|
bts, err := os.ReadFile(path)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, "hello", string(bts))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("nok", func(t *testing.T) {
|
|
|
|
artifacts := New()
|
|
|
|
artifacts.Add(&Artifact{
|
|
|
|
Name: "fail",
|
|
|
|
Type: Checksum,
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
"ID": "nok",
|
|
|
|
"Refresh": func() error {
|
|
|
|
return fmt.Errorf("fake err")
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
for _, item := range artifacts.List() {
|
|
|
|
require.EqualError(t, item.Refresh(), `failed to refresh "fail": fake err`)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("not a checksum", func(t *testing.T) {
|
|
|
|
artifacts := New()
|
|
|
|
artifacts.Add(&Artifact{
|
|
|
|
Name: "will be ignored",
|
|
|
|
Type: Binary,
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
"ID": "ignored",
|
|
|
|
"Refresh": func() error {
|
|
|
|
return fmt.Errorf("err that should not happen")
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
for _, item := range artifacts.List() {
|
|
|
|
require.NoError(t, item.Refresh())
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestVisit(t *testing.T) {
|
|
|
|
artifacts := New()
|
|
|
|
artifacts.Add(&Artifact{
|
|
|
|
Name: "foo",
|
|
|
|
Type: Checksum,
|
|
|
|
})
|
|
|
|
artifacts.Add(&Artifact{
|
|
|
|
Name: "foo",
|
|
|
|
Type: Binary,
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("ok", func(t *testing.T) {
|
|
|
|
require.NoError(t, artifacts.Visit(func(a *Artifact) error {
|
|
|
|
require.Equal(t, "foo", a.Name)
|
|
|
|
return nil
|
|
|
|
}))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("nok", func(t *testing.T) {
|
|
|
|
require.EqualError(t, artifacts.Visit(func(a *Artifact) error {
|
|
|
|
return fmt.Errorf("fake err")
|
|
|
|
}), `fake err`)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestMarshalJSON(t *testing.T) {
|
|
|
|
artifacts := New()
|
|
|
|
artifacts.Add(&Artifact{
|
|
|
|
Name: "foo",
|
|
|
|
Type: Binary,
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraID: "adsad",
|
|
|
|
},
|
|
|
|
})
|
2021-12-07 21:52:35 -03:00
|
|
|
artifacts.Add(&Artifact{
|
|
|
|
Name: "foo",
|
|
|
|
Type: UploadableArchive,
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraID: "adsad",
|
|
|
|
},
|
|
|
|
})
|
2021-12-05 22:42:13 -03:00
|
|
|
artifacts.Add(&Artifact{
|
|
|
|
Name: "foo",
|
|
|
|
Type: Checksum,
|
|
|
|
Extra: map[string]interface{}{
|
|
|
|
ExtraRefresh: func() error { return nil },
|
|
|
|
},
|
|
|
|
})
|
|
|
|
bts, err := json.Marshal(artifacts.List())
|
|
|
|
require.NoError(t, err)
|
|
|
|
golden.RequireEqualJSON(t, bts)
|
|
|
|
}
|
2022-02-25 09:28:09 -05:00
|
|
|
|
|
|
|
func Test_ByBinaryLikeArtifacts(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
initial []*Artifact
|
|
|
|
expected []*Artifact
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "keep all unique paths",
|
|
|
|
initial: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "binary-path",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "uploadable-binary-path",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "universal-binary-path",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expected: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "binary-path",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "uploadable-binary-path",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "universal-binary-path",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "duplicate path between binaries ignored (odd configuration)",
|
|
|
|
initial: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "uploadable-binary-path",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expected: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "uploadable-binary-path",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "remove duplicate binary",
|
|
|
|
initial: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "universal-binary-path",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expected: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "universal-binary-path",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "remove duplicate universal binary",
|
|
|
|
initial: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "binary-path",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expected: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "binary-path",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "remove multiple duplicates",
|
|
|
|
initial: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expected: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "keep duplicate uploadable binaries (odd configuration)",
|
|
|
|
initial: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expected: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UploadableBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "keeps duplicates when there is no uploadable binary",
|
|
|
|
initial: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expected: []*Artifact{
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: Binary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Path: "!!!duplicate!!!",
|
|
|
|
Type: UniversalBinary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
arts := New()
|
|
|
|
for _, a := range tt.initial {
|
|
|
|
arts.Add(a)
|
|
|
|
}
|
|
|
|
actual := arts.Filter(ByBinaryLikeArtifacts(arts)).List()
|
2022-06-22 01:48:11 -03:00
|
|
|
expected := New()
|
|
|
|
for _, a := range tt.expected {
|
|
|
|
expected.Add(a)
|
|
|
|
}
|
|
|
|
assert.Equal(t, expected.List(), actual)
|
2022-02-25 09:28:09 -05:00
|
|
|
|
|
|
|
if t.Failed() {
|
|
|
|
t.Log("expected:")
|
|
|
|
for _, a := range tt.expected {
|
|
|
|
t.Logf(" %s: %s", a.Type.String(), a.Path)
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Log("got:")
|
|
|
|
for _, a := range actual {
|
|
|
|
t.Logf(" %s: %s", a.Type.String(), a.Path)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2022-04-11 22:43:22 -03:00
|
|
|
|
|
|
|
func TestArtifactStringer(t *testing.T) {
|
|
|
|
require.Equal(t, "foobar", Artifact{
|
|
|
|
Name: "foobar",
|
|
|
|
}.String())
|
|
|
|
}
|