forked from p34709852/monkey
Agent: add mimikatz collector unit tests
This commit is contained in:
parent
a6c2762823
commit
f5740b2a6e
|
@ -0,0 +1,56 @@
|
|||
from infection_monkey.credential_collectors import Credentials, NTHashes, Password, Username
|
||||
from infection_monkey.credential_collectors.mimikatz_collector.mimikatz_cred_collector import (
|
||||
MimikatzCredentialCollector,
|
||||
)
|
||||
from infection_monkey.credential_collectors.mimikatz_collector.windows_credentials import (
|
||||
WindowsCredentials,
|
||||
)
|
||||
|
||||
|
||||
def patch_pypykatz(win_creds: [WindowsCredentials], monkeypatch):
|
||||
monkeypatch.setattr(
|
||||
"infection_monkey.credential_collectors"
|
||||
".mimikatz_collector.pypykatz_handler.get_windows_creds",
|
||||
lambda: win_creds,
|
||||
)
|
||||
|
||||
|
||||
def test_empty_results(monkeypatch):
|
||||
win_creds = [WindowsCredentials(username="", password="", ntlm_hash="", lm_hash="")]
|
||||
patch_pypykatz(win_creds, monkeypatch)
|
||||
expected = []
|
||||
collected = MimikatzCredentialCollector().collect_credentials()
|
||||
assert expected == collected
|
||||
|
||||
patch_pypykatz([], monkeypatch)
|
||||
collected = MimikatzCredentialCollector().collect_credentials()
|
||||
assert [] == collected
|
||||
|
||||
|
||||
def test_pypykatz_result_parsing(monkeypatch):
|
||||
win_creds = [
|
||||
WindowsCredentials(username="user", password="secret", ntlm_hash="", lm_hash=""),
|
||||
WindowsCredentials(username="", password="", ntlm_hash="ntlm_hash", lm_hash="lm_hash"),
|
||||
WindowsCredentials(username="user", password="secret", ntlm_hash="", lm_hash=""),
|
||||
WindowsCredentials(
|
||||
username="user2", password="secret2", ntlm_hash="ntlm_hash2", lm_hash="lm_hash2"
|
||||
),
|
||||
]
|
||||
patch_pypykatz(win_creds, monkeypatch)
|
||||
|
||||
# Expected credentials
|
||||
username = Username("user")
|
||||
username2 = Username("user2")
|
||||
password = Password("secret")
|
||||
password2 = Password("secret2")
|
||||
hash = NTHashes(ntlm_hash="ntlm_hash", lm_hash="lm_hash")
|
||||
hash2 = NTHashes(ntlm_hash="ntlm_hash2", lm_hash="lm_hash2")
|
||||
|
||||
expected = [
|
||||
Credentials(identities=[username], secrets=[password]),
|
||||
Credentials(identities=[], secrets=[hash]),
|
||||
Credentials(identities=[username], secrets=[password]),
|
||||
Credentials(identities=[username2], secrets=[password2, hash2]),
|
||||
]
|
||||
collected = MimikatzCredentialCollector().collect_credentials()
|
||||
assert expected == collected
|
Loading…
Reference in New Issue