Build system, release automation, SDK generation, Ansible executor, LinuxKit dev environments, container runtime, deployment, infra metrics, and developer toolkit. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
34 lines
730 B
Go
34 lines
730 B
Go
package signing
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"forge.lthn.ai/core/go/pkg/io"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestGPGSigner_Good_Name(t *testing.T) {
|
|
s := NewGPGSigner("ABCD1234")
|
|
assert.Equal(t, "gpg", s.Name())
|
|
}
|
|
|
|
func TestGPGSigner_Good_Available(t *testing.T) {
|
|
s := NewGPGSigner("ABCD1234")
|
|
_ = s.Available()
|
|
}
|
|
|
|
func TestGPGSigner_Bad_NoKey(t *testing.T) {
|
|
s := NewGPGSigner("")
|
|
assert.False(t, s.Available())
|
|
}
|
|
|
|
func TestGPGSigner_Sign_Bad(t *testing.T) {
|
|
fs := io.Local
|
|
t.Run("fails when no key", func(t *testing.T) {
|
|
s := NewGPGSigner("")
|
|
err := s.Sign(context.Background(), fs, "test.txt")
|
|
assert.Error(t, err)
|
|
assert.Contains(t, err.Error(), "not available or key not configured")
|
|
})
|
|
}
|