go-crypt/crypt/symmetric_test.go
Claude 8498ecf890
feat: extract crypto/security packages from core/go
ChaCha20-Poly1305, AES-256-GCM, Argon2 key derivation, OpenPGP
challenge-response auth, and trust tier policy engine.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-16 15:25:54 +00:00

55 lines
1.2 KiB
Go

package crypt
import (
"crypto/rand"
"testing"
"github.com/stretchr/testify/assert"
)
func TestChaCha20_Good(t *testing.T) {
key := make([]byte, 32)
_, err := rand.Read(key)
assert.NoError(t, err)
plaintext := []byte("ChaCha20-Poly1305 test data")
encrypted, err := ChaCha20Encrypt(plaintext, key)
assert.NoError(t, err)
assert.NotEqual(t, plaintext, encrypted)
decrypted, err := ChaCha20Decrypt(encrypted, key)
assert.NoError(t, err)
assert.Equal(t, plaintext, decrypted)
}
func TestChaCha20_Bad(t *testing.T) {
key := make([]byte, 32)
wrongKey := make([]byte, 32)
_, _ = rand.Read(key)
_, _ = rand.Read(wrongKey)
plaintext := []byte("secret message")
encrypted, err := ChaCha20Encrypt(plaintext, key)
assert.NoError(t, err)
_, err = ChaCha20Decrypt(encrypted, wrongKey)
assert.Error(t, err)
}
func TestAESGCM_Good(t *testing.T) {
key := make([]byte, 32)
_, err := rand.Read(key)
assert.NoError(t, err)
plaintext := []byte("AES-256-GCM test data")
encrypted, err := AESGCMEncrypt(plaintext, key)
assert.NoError(t, err)
assert.NotEqual(t, plaintext, encrypted)
decrypted, err := AESGCMDecrypt(encrypted, key)
assert.NoError(t, err)
assert.Equal(t, plaintext, decrypted)
}