During conflict resolution for PR #313 (streaming API), the agent incorrectly assumed that modify/delete conflicts meant the PR intended to remove these packages. This was wrong - PR #313 was only about adding streaming API to pkg/io. Restored packages: - pkg/workspace - workspace management service - pkg/unifi - UniFi controller client - pkg/gitea - Gitea API client - pkg/crypt/openpgp - OpenPGP encryption service - internal/cmd/gitea - Gitea CLI commands - internal/cmd/unifi - UniFi CLI commands Also restored: - Various test files (bench_test.go, integration_test.go, etc.) - pkg/framework/core/interfaces.go (Workspace/Crypt interfaces) - pkg/log/errors.go (error helpers) - Documentation (faq.md, user-guide.md) This allows PR #297 (MCP daemon mode) to proceed as it depends on pkg/workspace. Co-authored-by: Claude <developers@lethean.io> Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
43 lines
1 KiB
Go
43 lines
1 KiB
Go
package openpgp
|
|
|
|
import (
|
|
"bytes"
|
|
"testing"
|
|
|
|
core "github.com/host-uk/core/pkg/framework/core"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestCreateKeyPair(t *testing.T) {
|
|
c, _ := core.New()
|
|
s := &Service{core: c}
|
|
|
|
privKey, err := s.CreateKeyPair("test user", "password123")
|
|
assert.NoError(t, err)
|
|
assert.NotEmpty(t, privKey)
|
|
assert.Contains(t, privKey, "-----BEGIN PGP PRIVATE KEY BLOCK-----")
|
|
}
|
|
|
|
func TestEncryptDecrypt(t *testing.T) {
|
|
c, _ := core.New()
|
|
s := &Service{core: c}
|
|
|
|
passphrase := "secret"
|
|
privKey, err := s.CreateKeyPair("test user", passphrase)
|
|
assert.NoError(t, err)
|
|
|
|
// In this simple test, the public key is also in the armored private key string
|
|
// (openpgp.ReadArmoredKeyRing reads both)
|
|
publicKey := privKey
|
|
|
|
data := "hello openpgp"
|
|
var buf bytes.Buffer
|
|
armored, err := s.EncryptPGP(&buf, publicKey, data)
|
|
assert.NoError(t, err)
|
|
assert.NotEmpty(t, armored)
|
|
assert.NotEmpty(t, buf.String())
|
|
|
|
decrypted, err := s.DecryptPGP(privKey, armored, passphrase)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, data, decrypted)
|
|
}
|