2026-01-29 02:48:54 +00:00
|
|
|
package signing
|
|
|
|
|
|
|
|
|
|
import (
|
2026-01-29 14:28:23 +00:00
|
|
|
"context"
|
2026-01-29 02:48:54 +00:00
|
|
|
"runtime"
|
|
|
|
|
"testing"
|
2026-01-29 14:28:23 +00:00
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2026-01-29 02:48:54 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestMacOSSigner_Good_Name(t *testing.T) {
|
|
|
|
|
s := NewMacOSSigner(MacOSConfig{Identity: "Developer ID Application: Test"})
|
2026-01-29 14:28:23 +00:00
|
|
|
assert.Equal(t, "codesign", s.Name())
|
2026-01-29 02:48:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestMacOSSigner_Good_Available(t *testing.T) {
|
|
|
|
|
s := NewMacOSSigner(MacOSConfig{Identity: "Developer ID Application: Test"})
|
|
|
|
|
|
|
|
|
|
if runtime.GOOS == "darwin" {
|
2026-01-29 14:28:23 +00:00
|
|
|
// Just verify it doesn't panic
|
2026-01-29 02:48:54 +00:00
|
|
|
_ = s.Available()
|
|
|
|
|
} else {
|
2026-01-29 14:28:23 +00:00
|
|
|
assert.False(t, s.Available())
|
2026-01-29 02:48:54 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestMacOSSigner_Bad_NoIdentity(t *testing.T) {
|
|
|
|
|
s := NewMacOSSigner(MacOSConfig{})
|
2026-01-29 14:28:23 +00:00
|
|
|
assert.False(t, s.Available())
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestMacOSSigner_Sign_Bad(t *testing.T) {
|
|
|
|
|
t.Run("fails when not available", func(t *testing.T) {
|
|
|
|
|
if runtime.GOOS == "darwin" {
|
|
|
|
|
t.Skip("skipping on macOS")
|
|
|
|
|
}
|
|
|
|
|
s := NewMacOSSigner(MacOSConfig{Identity: "test"})
|
|
|
|
|
err := s.Sign(context.Background(), "test")
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
assert.Contains(t, err.Error(), "not available")
|
|
|
|
|
})
|
2026-01-29 02:48:54 +00:00
|
|
|
}
|
2026-01-29 14:28:23 +00:00
|
|
|
|
|
|
|
|
func TestMacOSSigner_Notarize_Bad(t *testing.T) {
|
|
|
|
|
t.Run("fails with missing credentials", func(t *testing.T) {
|
|
|
|
|
s := NewMacOSSigner(MacOSConfig{})
|
|
|
|
|
err := s.Notarize(context.Background(), "test")
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
assert.Contains(t, err.Error(), "missing Apple credentials")
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestMacOSSigner_ShouldNotarize(t *testing.T) {
|
|
|
|
|
s := NewMacOSSigner(MacOSConfig{Notarize: true})
|
|
|
|
|
assert.True(t, s.ShouldNotarize())
|
|
|
|
|
|
|
|
|
|
s2 := NewMacOSSigner(MacOSConfig{Notarize: false})
|
|
|
|
|
assert.False(t, s2.ShouldNotarize())
|
|
|
|
|
}
|