1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-03-31 21:55:34 +02:00
goreleaser/internal/pipe/notary/macos_test.go
Carlos Alexandro Becker 3cd2e07c68
feat: notarize macos binaries (#4774)
this includes anchore/quill as a pipe to sign and notarize macos
binaries

TODO:

- [x] find a way to test this
- [x] docs
- [x] maybe get someone from anchore to take a look?

---------

Signed-off-by: Carlos Alexandro Becker <caarlos0@users.noreply.github.com>
2024-04-19 22:27:50 -03:00

163 lines
3.8 KiB
Go

package notary
import (
"testing"
"time"
"github.com/goreleaser/goreleaser/internal/skips"
"github.com/goreleaser/goreleaser/internal/testctx"
"github.com/goreleaser/goreleaser/internal/testlib"
"github.com/goreleaser/goreleaser/pkg/config"
"github.com/goreleaser/goreleaser/pkg/context"
"github.com/stretchr/testify/require"
)
func TestMacOSString(t *testing.T) {
require.NotEmpty(t, MacOS{}.String())
}
func TestMacOSSkip(t *testing.T) {
p := MacOS{}
t.Run("skip notarize", func(t *testing.T) {
require.True(t,
p.Skip(testctx.NewWithCfg(config.Project{
Notarize: config.Notarize{
MacOS: []config.MacOSSignNotarize{
{},
},
},
}, testctx.Skip(skips.Notarize))))
})
t.Run("skip no configs", func(t *testing.T) {
require.True(t,
p.Skip(testctx.NewWithCfg(config.Project{})))
})
t.Run("dont skip", func(t *testing.T) {
require.False(t,
p.Skip(testctx.NewWithCfg(config.Project{
Notarize: config.Notarize{
MacOS: []config.MacOSSignNotarize{
{},
},
},
})))
})
}
func TestMacOSDefault(t *testing.T) {
ctx := testctx.NewWithCfg(config.Project{
ProjectName: "foo",
Notarize: config.Notarize{
MacOS: []config.MacOSSignNotarize{
{},
{
Notarize: config.MacOSNotarize{
Timeout: time.Second,
},
},
{
IDs: []string{"hi"},
},
},
},
})
require.NoError(t, MacOS{}.Default(ctx))
require.Equal(t, []config.MacOSSignNotarize{
{
IDs: []string{"foo"},
Notarize: config.MacOSNotarize{
Timeout: 10 * time.Minute,
},
},
{
IDs: []string{"foo"},
Notarize: config.MacOSNotarize{
Timeout: time.Second,
},
},
{
IDs: []string{"hi"},
Notarize: config.MacOSNotarize{
Timeout: 10 * time.Minute,
},
},
}, ctx.Config.Notarize.MacOS)
}
func TestMacOSRun(t *testing.T) {
t.Run("bad tmpl", func(t *testing.T) {
for name, fn := range map[string]func(ctx *context.Context){
"enabled": func(ctx *context.Context) {
ctx.Config.Notarize.MacOS = append(ctx.Config.Notarize.MacOS, config.MacOSSignNotarize{
Enabled: "{{.Nope}}",
})
},
"certificate": func(ctx *context.Context) {
ctx.Config.Notarize.MacOS = append(ctx.Config.Notarize.MacOS, config.MacOSSignNotarize{
Enabled: "true",
Sign: config.MacOSSign{
Certificate: "{{.Nope}}",
},
})
},
"password": func(ctx *context.Context) {
ctx.Config.Notarize.MacOS = append(ctx.Config.Notarize.MacOS, config.MacOSSignNotarize{
Enabled: "true",
Sign: config.MacOSSign{
Password: "{{.Nope}}",
},
})
},
"key": func(ctx *context.Context) {
ctx.Config.Notarize.MacOS = append(ctx.Config.Notarize.MacOS, config.MacOSSignNotarize{
Enabled: "true",
Notarize: config.MacOSNotarize{
Key: "{{.Nope}}",
},
})
},
"keyid": func(ctx *context.Context) {
ctx.Config.Notarize.MacOS = append(ctx.Config.Notarize.MacOS, config.MacOSSignNotarize{
Enabled: "true",
Notarize: config.MacOSNotarize{
KeyID: "{{.Nope}}",
},
})
},
"issuerid": func(ctx *context.Context) {
ctx.Config.Notarize.MacOS = append(ctx.Config.Notarize.MacOS, config.MacOSSignNotarize{
Enabled: "true",
Notarize: config.MacOSNotarize{
IssuerID: "{{.Nope}}",
},
})
},
} {
t.Run(name, func(t *testing.T) {
ctx := testctx.NewWithCfg(config.Project{
Notarize: config.Notarize{
MacOS: []config.MacOSSignNotarize{
{},
},
},
})
fn(ctx)
testlib.RequireTemplateError(t, MacOS{}.Run(ctx))
})
}
})
t.Run("skip", func(t *testing.T) {
ctx := testctx.NewWithCfg(config.Project{
Notarize: config.Notarize{
MacOS: []config.MacOSSignNotarize{
{},
{
Enabled: "{{.Env.SKIP}}",
},
},
},
}, testctx.WithEnv(map[string]string{"SKIP": "false"}))
testlib.AssertSkipped(t, MacOS{}.Run(ctx))
})
}