mirror of
https://github.com/DeBrosOfficial/orama.git
synced 2026-03-17 09:36:56 +00:00
179 lines
4.5 KiB
Go
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")
|
|
}
|
|
})
|
|
}
|