orama/pkg/encryption/identity_test.go
2026-02-13 16:18:22 +02:00

179 lines
4.5 KiB
Go

package encryption
import (
"os"
"path/filepath"
"testing"
)
func TestGenerateIdentity(t *testing.T) {
t.Run("returns non-nil IdentityInfo", func(t *testing.T) {
id, err := GenerateIdentity()
if err != nil {
t.Fatalf("GenerateIdentity() returned error: %v", err)
}
if id == nil {
t.Fatal("GenerateIdentity() returned nil")
}
})
t.Run("PeerID is non-empty", func(t *testing.T) {
id, err := GenerateIdentity()
if err != nil {
t.Fatalf("GenerateIdentity() returned error: %v", err)
}
if id.PeerID == "" {
t.Error("expected non-empty PeerID")
}
})
t.Run("PrivateKey is non-nil", func(t *testing.T) {
id, err := GenerateIdentity()
if err != nil {
t.Fatalf("GenerateIdentity() returned error: %v", err)
}
if id.PrivateKey == nil {
t.Error("expected non-nil PrivateKey")
}
})
t.Run("PublicKey is non-nil", func(t *testing.T) {
id, err := GenerateIdentity()
if err != nil {
t.Fatalf("GenerateIdentity() returned error: %v", err)
}
if id.PublicKey == nil {
t.Error("expected non-nil PublicKey")
}
})
t.Run("two calls produce different identities", func(t *testing.T) {
id1, err := GenerateIdentity()
if err != nil {
t.Fatalf("first GenerateIdentity() returned error: %v", err)
}
id2, err := GenerateIdentity()
if err != nil {
t.Fatalf("second GenerateIdentity() returned error: %v", err)
}
if id1.PeerID == id2.PeerID {
t.Errorf("expected different PeerIDs, both got %s", id1.PeerID)
}
})
}
func TestSaveAndLoadIdentity(t *testing.T) {
t.Run("round-trip preserves PeerID", func(t *testing.T) {
dir := t.TempDir()
path := filepath.Join(dir, "identity.key")
id, err := GenerateIdentity()
if err != nil {
t.Fatalf("GenerateIdentity() returned error: %v", err)
}
if err := SaveIdentity(id, path); err != nil {
t.Fatalf("SaveIdentity() returned error: %v", err)
}
loaded, err := LoadIdentity(path)
if err != nil {
t.Fatalf("LoadIdentity() returned error: %v", err)
}
if id.PeerID != loaded.PeerID {
t.Errorf("PeerID mismatch: saved %s, loaded %s", id.PeerID, loaded.PeerID)
}
})
t.Run("round-trip preserves key material", func(t *testing.T) {
dir := t.TempDir()
path := filepath.Join(dir, "identity.key")
id, err := GenerateIdentity()
if err != nil {
t.Fatalf("GenerateIdentity() returned error: %v", err)
}
if err := SaveIdentity(id, path); err != nil {
t.Fatalf("SaveIdentity() returned error: %v", err)
}
loaded, err := LoadIdentity(path)
if err != nil {
t.Fatalf("LoadIdentity() returned error: %v", err)
}
if loaded.PrivateKey == nil {
t.Error("loaded PrivateKey is nil")
}
if loaded.PublicKey == nil {
t.Error("loaded PublicKey is nil")
}
if !id.PrivateKey.Equals(loaded.PrivateKey) {
t.Error("PrivateKey does not match after round-trip")
}
if !id.PublicKey.Equals(loaded.PublicKey) {
t.Error("PublicKey does not match after round-trip")
}
})
t.Run("save creates parent directories", func(t *testing.T) {
dir := t.TempDir()
path := filepath.Join(dir, "nested", "deep", "identity.key")
id, err := GenerateIdentity()
if err != nil {
t.Fatalf("GenerateIdentity() returned error: %v", err)
}
if err := SaveIdentity(id, path); err != nil {
t.Fatalf("SaveIdentity() should create parent dirs, got error: %v", err)
}
// Verify the file actually exists
if _, err := os.Stat(path); os.IsNotExist(err) {
t.Error("expected file to exist after SaveIdentity")
}
})
t.Run("load from non-existent file returns error", func(t *testing.T) {
dir := t.TempDir()
path := filepath.Join(dir, "does-not-exist.key")
_, err := LoadIdentity(path)
if err == nil {
t.Error("expected error when loading from non-existent file, got nil")
}
})
t.Run("load from corrupted file returns error", func(t *testing.T) {
dir := t.TempDir()
path := filepath.Join(dir, "corrupted.key")
// Write garbage bytes
if err := os.WriteFile(path, []byte("this is not a valid key"), 0600); err != nil {
t.Fatalf("failed to write corrupted file: %v", err)
}
_, err := LoadIdentity(path)
if err == nil {
t.Error("expected error when loading corrupted file, got nil")
}
})
t.Run("load from empty file returns error", func(t *testing.T) {
dir := t.TempDir()
path := filepath.Join(dir, "empty.key")
if err := os.WriteFile(path, []byte{}, 0600); err != nil {
t.Fatalf("failed to write empty file: %v", err)
}
_, err := LoadIdentity(path)
if err == nil {
t.Error("expected error when loading empty file, got nil")
}
})
}