mirror of
https://github.com/PR0M3TH3AN/SeedPass.git
synced 2025-09-09 07:48:57 +00:00
Enhance entry detail display and tests
This commit is contained in:
@@ -2934,8 +2934,9 @@ class PasswordManager:
|
|||||||
return
|
return
|
||||||
|
|
||||||
etype = entry.get("type", entry.get("kind", EntryType.PASSWORD.value))
|
etype = entry.get("type", entry.get("kind", EntryType.PASSWORD.value))
|
||||||
if isinstance(etype, str):
|
if isinstance(etype, EntryType):
|
||||||
etype = etype.lower()
|
etype = etype.value
|
||||||
|
etype = str(etype).lower()
|
||||||
print(color_text(f"Index: {index}", "index"))
|
print(color_text(f"Index: {index}", "index"))
|
||||||
if etype == EntryType.TOTP.value:
|
if etype == EntryType.TOTP.value:
|
||||||
print(color_text(f" Label: {entry.get('label', '')}", "index"))
|
print(color_text(f" Label: {entry.get('label', '')}", "index"))
|
||||||
@@ -2957,9 +2958,13 @@ class PasswordManager:
|
|||||||
elif etype == EntryType.SEED.value:
|
elif etype == EntryType.SEED.value:
|
||||||
print(color_text(" Type: Seed Phrase", "index"))
|
print(color_text(" Type: Seed Phrase", "index"))
|
||||||
print(color_text(f" Label: {entry.get('label', '')}", "index"))
|
print(color_text(f" Label: {entry.get('label', '')}", "index"))
|
||||||
print(color_text(f" Words: {entry.get('words', 24)}", "index"))
|
words = entry.get("word_count", entry.get("words", 24))
|
||||||
|
print(color_text(f" Words: {words}", "index"))
|
||||||
print(
|
print(
|
||||||
color_text(f" Derivation Index: {entry.get('index', index)}", "index")
|
color_text(
|
||||||
|
f" Derivation Index: {entry.get('index', index)}",
|
||||||
|
"index",
|
||||||
|
)
|
||||||
)
|
)
|
||||||
notes = entry.get("notes", "")
|
notes = entry.get("notes", "")
|
||||||
if notes:
|
if notes:
|
||||||
@@ -3009,6 +3014,37 @@ class PasswordManager:
|
|||||||
tags = entry.get("tags", [])
|
tags = entry.get("tags", [])
|
||||||
if tags:
|
if tags:
|
||||||
print(color_text(f" Tags: {', '.join(tags)}", "index"))
|
print(color_text(f" Tags: {', '.join(tags)}", "index"))
|
||||||
|
elif etype == EntryType.KEY_VALUE.value:
|
||||||
|
print(color_text(" Type: Key/Value", "index"))
|
||||||
|
print(color_text(f" Label: {entry.get('label', '')}", "index"))
|
||||||
|
print(color_text(f" Value: {entry.get('value', '')}", "index"))
|
||||||
|
notes = entry.get("notes", "")
|
||||||
|
if notes:
|
||||||
|
print(color_text(f" Notes: {notes}", "index"))
|
||||||
|
tags = entry.get("tags", [])
|
||||||
|
if tags:
|
||||||
|
print(color_text(f" Tags: {', '.join(tags)}", "index"))
|
||||||
|
blacklisted = entry.get("archived", entry.get("blacklisted", False))
|
||||||
|
print(color_text(f" Archived: {'Yes' if blacklisted else 'No'}", "index"))
|
||||||
|
elif etype == EntryType.MANAGED_ACCOUNT.value:
|
||||||
|
print(color_text(" Type: Managed Account", "index"))
|
||||||
|
print(color_text(f" Label: {entry.get('label', '')}", "index"))
|
||||||
|
words = entry.get("word_count", entry.get("words", 24))
|
||||||
|
print(color_text(f" Words: {words}", "index"))
|
||||||
|
print(
|
||||||
|
color_text(f" Derivation Index: {entry.get('index', index)}", "index")
|
||||||
|
)
|
||||||
|
fingerprint = entry.get("fingerprint", "")
|
||||||
|
if fingerprint:
|
||||||
|
print(color_text(f" Fingerprint: {fingerprint}", "index"))
|
||||||
|
notes = entry.get("notes", "")
|
||||||
|
if notes:
|
||||||
|
print(color_text(f" Notes: {notes}", "index"))
|
||||||
|
tags = entry.get("tags", [])
|
||||||
|
if tags:
|
||||||
|
print(color_text(f" Tags: {', '.join(tags)}", "index"))
|
||||||
|
blacklisted = entry.get("archived", entry.get("blacklisted", False))
|
||||||
|
print(color_text(f" Archived: {'Yes' if blacklisted else 'No'}", "index"))
|
||||||
else:
|
else:
|
||||||
website = entry.get("label", entry.get("website", ""))
|
website = entry.get("label", entry.get("website", ""))
|
||||||
username = entry.get("username", "")
|
username = entry.get("username", "")
|
||||||
|
@@ -134,3 +134,119 @@ def test_show_entry_details_by_index(monkeypatch):
|
|||||||
|
|
||||||
assert len(header_calls) == 1
|
assert len(header_calls) == 1
|
||||||
assert call_order == ["display", "actions"]
|
assert call_order == ["display", "actions"]
|
||||||
|
|
||||||
|
|
||||||
|
def _setup_manager(tmp_path):
|
||||||
|
vault, enc_mgr = create_vault(tmp_path, TEST_SEED, TEST_PASSWORD)
|
||||||
|
cfg_mgr = ConfigManager(vault, tmp_path)
|
||||||
|
backup_mgr = BackupManager(tmp_path, cfg_mgr)
|
||||||
|
entry_mgr = EntryManager(vault, backup_mgr)
|
||||||
|
|
||||||
|
pm = PasswordManager.__new__(PasswordManager)
|
||||||
|
pm.encryption_mode = EncryptionMode.SEED_ONLY
|
||||||
|
pm.encryption_manager = enc_mgr
|
||||||
|
pm.vault = vault
|
||||||
|
pm.entry_manager = entry_mgr
|
||||||
|
pm.backup_manager = backup_mgr
|
||||||
|
pm.parent_seed = TEST_SEED
|
||||||
|
pm.nostr_client = SimpleNamespace()
|
||||||
|
pm.fingerprint_dir = tmp_path
|
||||||
|
pm.secret_mode_enabled = False
|
||||||
|
return pm, entry_mgr
|
||||||
|
|
||||||
|
|
||||||
|
def _detail_common(monkeypatch, pm):
|
||||||
|
monkeypatch.setattr(
|
||||||
|
"password_manager.manager.clear_header_with_notification",
|
||||||
|
lambda *a, **k: None,
|
||||||
|
)
|
||||||
|
monkeypatch.setattr("password_manager.manager.pause", lambda *a, **k: None)
|
||||||
|
called = []
|
||||||
|
monkeypatch.setattr(pm, "_entry_actions_menu", lambda *a, **k: called.append(True))
|
||||||
|
return called
|
||||||
|
|
||||||
|
|
||||||
|
def test_show_seed_entry_details(monkeypatch, capsys):
|
||||||
|
with TemporaryDirectory() as tmpdir:
|
||||||
|
tmp_path = Path(tmpdir)
|
||||||
|
pm, entry_mgr = _setup_manager(tmp_path)
|
||||||
|
idx = entry_mgr.add_seed("seed", TEST_SEED, words_num=12)
|
||||||
|
|
||||||
|
called = _detail_common(monkeypatch, pm)
|
||||||
|
|
||||||
|
pm.show_entry_details_by_index(idx)
|
||||||
|
out = capsys.readouterr().out
|
||||||
|
assert "Type: Seed Phrase" in out
|
||||||
|
assert "Label: seed" in out
|
||||||
|
assert "Words: 12" in out
|
||||||
|
assert f"Derivation Index: {idx}" in out
|
||||||
|
assert called == [True]
|
||||||
|
|
||||||
|
|
||||||
|
def test_show_ssh_entry_details(monkeypatch, capsys):
|
||||||
|
with TemporaryDirectory() as tmpdir:
|
||||||
|
tmp_path = Path(tmpdir)
|
||||||
|
pm, entry_mgr = _setup_manager(tmp_path)
|
||||||
|
idx = entry_mgr.add_ssh_key("ssh", TEST_SEED)
|
||||||
|
|
||||||
|
called = _detail_common(monkeypatch, pm)
|
||||||
|
|
||||||
|
pm.show_entry_details_by_index(idx)
|
||||||
|
out = capsys.readouterr().out
|
||||||
|
assert "Type: SSH Key" in out
|
||||||
|
assert "Label: ssh" in out
|
||||||
|
assert f"Derivation Index: {idx}" in out
|
||||||
|
assert called == [True]
|
||||||
|
|
||||||
|
|
||||||
|
def test_show_pgp_entry_details(monkeypatch, capsys):
|
||||||
|
with TemporaryDirectory() as tmpdir:
|
||||||
|
tmp_path = Path(tmpdir)
|
||||||
|
pm, entry_mgr = _setup_manager(tmp_path)
|
||||||
|
idx = entry_mgr.add_pgp_key("pgp", TEST_SEED, user_id="test")
|
||||||
|
|
||||||
|
called = _detail_common(monkeypatch, pm)
|
||||||
|
|
||||||
|
pm.show_entry_details_by_index(idx)
|
||||||
|
out = capsys.readouterr().out
|
||||||
|
assert "Type: PGP Key" in out
|
||||||
|
assert "Label: pgp" in out
|
||||||
|
assert "Key Type: ed25519" in out
|
||||||
|
assert "User ID: test" in out
|
||||||
|
assert f"Derivation Index: {idx}" in out
|
||||||
|
assert called == [True]
|
||||||
|
|
||||||
|
|
||||||
|
def test_show_nostr_entry_details(monkeypatch, capsys):
|
||||||
|
with TemporaryDirectory() as tmpdir:
|
||||||
|
tmp_path = Path(tmpdir)
|
||||||
|
pm, entry_mgr = _setup_manager(tmp_path)
|
||||||
|
idx = entry_mgr.add_nostr_key("nostr")
|
||||||
|
|
||||||
|
called = _detail_common(monkeypatch, pm)
|
||||||
|
|
||||||
|
pm.show_entry_details_by_index(idx)
|
||||||
|
out = capsys.readouterr().out
|
||||||
|
assert "Type: Nostr Key" in out
|
||||||
|
assert "Label: nostr" in out
|
||||||
|
assert f"Derivation Index: {idx}" in out
|
||||||
|
assert called == [True]
|
||||||
|
|
||||||
|
|
||||||
|
def test_show_managed_account_entry_details(monkeypatch, capsys):
|
||||||
|
with TemporaryDirectory() as tmpdir:
|
||||||
|
tmp_path = Path(tmpdir)
|
||||||
|
pm, entry_mgr = _setup_manager(tmp_path)
|
||||||
|
idx = entry_mgr.add_managed_account("acct", TEST_SEED)
|
||||||
|
fp = entry_mgr.retrieve_entry(idx).get("fingerprint")
|
||||||
|
|
||||||
|
called = _detail_common(monkeypatch, pm)
|
||||||
|
|
||||||
|
pm.show_entry_details_by_index(idx)
|
||||||
|
out = capsys.readouterr().out
|
||||||
|
assert "Type: Managed Account" in out
|
||||||
|
assert "Label: acct" in out
|
||||||
|
assert f"Derivation Index: {idx}" in out
|
||||||
|
assert "Words: 12" in out
|
||||||
|
assert fp in out
|
||||||
|
assert called == [True]
|
||||||
|
Reference in New Issue
Block a user