Rewrite tests with pytest

This commit is contained in:
Shreya 2021-03-31 14:48:13 +05:30
parent 165b0df195
commit b0f85f6857
1 changed files with 105 additions and 44 deletions
monkey/infection_monkey/network

View File

@ -1,11 +1,11 @@
from unittest import TestCase import pytest
from unittest.mock import Mock
import infection_monkey.network.postgresql_finger
from infection_monkey.network.postgresql_finger import PostgreSQLFinger from infection_monkey.network.postgresql_finger import PostgreSQLFinger
IRRELEVANT_EXCEPTION_STRING = "This is an irrelevant exception string." IRRELEVANT_EXCEPTION_STRING = "This is an irrelevant exception string."
RELEVANT_EXCEPTION_STRINGS =\ _RELEVANT_EXCEPTION_STRING_PARTS =\
{ {
'pwd_auth_failed': 'FATAL: password authentication failed for user "root"', 'pwd_auth_failed': 'FATAL: password authentication failed for user "root"',
'ssl_on_entry_not_found': 'FATAL: no pg_hba.conf entry for host "127.0.0.1",' 'ssl_on_entry_not_found': 'FATAL: no pg_hba.conf entry for host "127.0.0.1",'
@ -14,7 +14,21 @@ RELEVANT_EXCEPTION_STRINGS =\
'user "random", database "postgres", SSL off' 'user "random", database "postgres", SSL off'
} }
RESULT_STRINGS =\ _RELEVANT_EXCEPTION_STRINGS =\
{
'pwd_auth_failed': _RELEVANT_EXCEPTION_STRING_PARTS['pwd_auth_failed'],
'ssl_off_entry_not_found': _RELEVANT_EXCEPTION_STRING_PARTS['ssl_off_entry_not_found'],
'pwd_auth_failed_pwd_auth_failed': '\n'.join([_RELEVANT_EXCEPTION_STRING_PARTS['pwd_auth_failed'],
_RELEVANT_EXCEPTION_STRING_PARTS['pwd_auth_failed']]),
'pwd_auth_failed_ssl_off_entry_not_found': '\n'.join([_RELEVANT_EXCEPTION_STRING_PARTS['pwd_auth_failed'],
_RELEVANT_EXCEPTION_STRING_PARTS['ssl_off_entry_not_found']]),
'ssl_on_entry_not_found_pwd_auth_failed': '\n'.join([_RELEVANT_EXCEPTION_STRING_PARTS['ssl_on_entry_not_found'],
_RELEVANT_EXCEPTION_STRING_PARTS['pwd_auth_failed']]),
'ssl_on_entry_not_found_ssl_off_entry_not_found': '\n'.join([_RELEVANT_EXCEPTION_STRING_PARTS['ssl_on_entry_not_found'],
_RELEVANT_EXCEPTION_STRING_PARTS['ssl_off_entry_not_found']])
}
_RESULT_STRINGS =\
{ {
'ssl_conf': "SSL is configured on the PostgreSQL server.\n", 'ssl_conf': "SSL is configured on the PostgreSQL server.\n",
'ssl_not_conf': "SSL is NOT configured on the PostgreSQL server.\n", 'ssl_not_conf': "SSL is NOT configured on the PostgreSQL server.\n",
@ -27,64 +41,111 @@ RESULT_STRINGS =\
'only_selected': "Only selected hosts can make connections (SSL or non-SSL).\n" 'only_selected': "Only selected hosts can make connections (SSL or non-SSL).\n"
} }
EXAMPLE_EXCEPTIONS_WITH_EXPECTED_RESULTS =\ RELEVANT_EXCEPTIONS_WITH_EXPECTED_RESULTS =\
{ {
# SSL not configured, all non-SSL allowed, # SSL not configured, all non-SSL allowed # SSL not configured, all non-SSL allowed
RELEVANT_EXCEPTION_STRINGS['pwd_auth_failed']: [ _RELEVANT_EXCEPTION_STRINGS['pwd_auth_failed']: [
RESULT_STRINGS['ssl_not_conf'], _RESULT_STRINGS['ssl_not_conf'],
RESULT_STRINGS['all_non_ssl'] _RESULT_STRINGS['all_non_ssl']
], ],
# SSL not configured, selected non-SSL allowed # SSL not configured, selected non-SSL allowed
RELEVANT_EXCEPTION_STRINGS['ssl_off_entry_not_found']: [ _RELEVANT_EXCEPTION_STRINGS['ssl_off_entry_not_found']: [
RESULT_STRINGS['ssl_not_conf'], _RESULT_STRINGS['ssl_not_conf'],
RESULT_STRINGS['selected_non_ssl'] _RESULT_STRINGS['selected_non_ssl']
], ],
# all SSL allowed, all non-SSL allowed # all SSL allowed, all non-SSL allowed
'\n'.join([RELEVANT_EXCEPTION_STRINGS['pwd_auth_failed'], _RELEVANT_EXCEPTION_STRINGS['pwd_auth_failed_pwd_auth_failed']: [
RELEVANT_EXCEPTION_STRINGS['pwd_auth_failed']]): [ _RESULT_STRINGS['ssl_conf'],
RESULT_STRINGS['ssl_conf'], _RESULT_STRINGS['all_ssl'],
RESULT_STRINGS['all_ssl'], _RESULT_STRINGS['all_non_ssl']
RESULT_STRINGS['all_non_ssl']
], ],
# all SSL allowed, selected non-SSL allowed # all SSL allowed, selected non-SSL allowed
'\n'.join([RELEVANT_EXCEPTION_STRINGS['pwd_auth_failed'], _RELEVANT_EXCEPTION_STRINGS['pwd_auth_failed_ssl_off_entry_not_found']: [
RELEVANT_EXCEPTION_STRINGS['ssl_off_entry_not_found']]): [ _RESULT_STRINGS['ssl_conf'],
RESULT_STRINGS['ssl_conf'], _RESULT_STRINGS['all_ssl'],
RESULT_STRINGS['all_ssl'], _RESULT_STRINGS['selected_non_ssl']
RESULT_STRINGS['selected_non_ssl']
], ],
# selected SSL allowed, all non-SSL allowed # selected SSL allowed, all non-SSL allowed
'\n'.join([RELEVANT_EXCEPTION_STRINGS['ssl_on_entry_not_found'], _RELEVANT_EXCEPTION_STRINGS['ssl_on_entry_not_found_pwd_auth_failed']: [
RELEVANT_EXCEPTION_STRINGS['pwd_auth_failed']]): [ _RESULT_STRINGS['ssl_conf'],
RESULT_STRINGS['ssl_conf'], _RESULT_STRINGS['selected_ssl'],
RESULT_STRINGS['selected_ssl'], _RESULT_STRINGS['all_non_ssl']
RESULT_STRINGS['all_non_ssl']
], ],
# selected SSL allowed, selected non-SSL allowed # selected SSL allowed, selected non-SSL allowed
'\n'.join([RELEVANT_EXCEPTION_STRINGS['ssl_on_entry_not_found'], _RELEVANT_EXCEPTION_STRINGS['ssl_on_entry_not_found_ssl_off_entry_not_found']: [
RELEVANT_EXCEPTION_STRINGS['ssl_off_entry_not_found']]): [ _RESULT_STRINGS['ssl_conf'],
RESULT_STRINGS['ssl_conf'], _RESULT_STRINGS['only_selected']
RESULT_STRINGS['only_selected']
] ]
} }
class TestPostgreSQLFinger(TestCase): @pytest.fixture
def test_is_relevant_exception(self): def mock_PostgreSQLFinger():
assert PostgreSQLFinger()._is_relevant_exception(IRRELEVANT_EXCEPTION_STRING) is False return PostgreSQLFinger()
for exception_string in EXAMPLE_EXCEPTIONS_WITH_EXPECTED_RESULTS:
assert PostgreSQLFinger()._is_relevant_exception(exception_string) is True
def test_analyze_operational_error(self):
host = Mock(['services']) class DummyHost:
host.services = {} def __init__(self):
for exception_string in EXAMPLE_EXCEPTIONS_WITH_EXPECTED_RESULTS: self.services = {}
with self.subTest(msg=f"Checking result for exception: {exception_string}"):
PostgreSQLFinger().analyze_operational_error(host, exception_string)
assert host.services['PostgreSQL']['communication_encryption_details'] ==\ @pytest.fixture
''.join(EXAMPLE_EXCEPTIONS_WITH_EXPECTED_RESULTS[exception_string]) def host():
return DummyHost()
def test_irrelevant_exception(mock_PostgreSQLFinger):
assert mock_PostgreSQLFinger._is_relevant_exception(IRRELEVANT_EXCEPTION_STRING) is False
def test_exception_ssl_not_configured_all_non_ssl_allowed(mock_PostgreSQLFinger, host):
exception = _RELEVANT_EXCEPTION_STRINGS['pwd_auth_failed']
assert mock_PostgreSQLFinger._is_relevant_exception(exception) is True
result = mock_PostgreSQLFinger.analyze_operational_error(host, exception)
assert host.services[mock_PostgreSQLFinger._SCANNED_SERVICE]['communication_encryption_details'] == ''.join(RELEVANT_EXCEPTIONS_WITH_EXPECTED_RESULTS[exception])
def test_exception_ssl_not_configured_selected_non_ssl_allowed(mock_PostgreSQLFinger, host):
exception = _RELEVANT_EXCEPTION_STRINGS['ssl_off_entry_not_found']
assert mock_PostgreSQLFinger._is_relevant_exception(exception) is True
result = mock_PostgreSQLFinger.analyze_operational_error(host, exception)
assert host.services[mock_PostgreSQLFinger._SCANNED_SERVICE]['communication_encryption_details'] == ''.join(RELEVANT_EXCEPTIONS_WITH_EXPECTED_RESULTS[exception])
def test_exception_all_ssl_allowed_all_non_ssl_allowed(mock_PostgreSQLFinger, host):
exception = _RELEVANT_EXCEPTION_STRINGS['pwd_auth_failed_pwd_auth_failed']
assert mock_PostgreSQLFinger._is_relevant_exception(exception) is True
result = mock_PostgreSQLFinger.analyze_operational_error(host, exception)
assert host.services[mock_PostgreSQLFinger._SCANNED_SERVICE]['communication_encryption_details'] == ''.join(RELEVANT_EXCEPTIONS_WITH_EXPECTED_RESULTS[exception])
def test_exception_all_ssl_allowed_selected_non_ssl_allowed(mock_PostgreSQLFinger, host):
exception = _RELEVANT_EXCEPTION_STRINGS['pwd_auth_failed_ssl_off_entry_not_found']
assert mock_PostgreSQLFinger._is_relevant_exception(exception) is True
result = mock_PostgreSQLFinger.analyze_operational_error(host, exception)
assert host.services[mock_PostgreSQLFinger._SCANNED_SERVICE]['communication_encryption_details'] == ''.join(RELEVANT_EXCEPTIONS_WITH_EXPECTED_RESULTS[exception])
def test_exception_selected_ssl_allowed_all_non_ssl_allowed(mock_PostgreSQLFinger, host):
exception = _RELEVANT_EXCEPTION_STRINGS['ssl_on_entry_not_found_pwd_auth_failed']
assert mock_PostgreSQLFinger._is_relevant_exception(exception) is True
result = mock_PostgreSQLFinger.analyze_operational_error(host, exception)
assert host.services[mock_PostgreSQLFinger._SCANNED_SERVICE]['communication_encryption_details'] == ''.join(RELEVANT_EXCEPTIONS_WITH_EXPECTED_RESULTS[exception])
def test_exception_selected_ssl_allowed_selected_non_ssl_allowed(mock_PostgreSQLFinger, host):
exception = _RELEVANT_EXCEPTION_STRINGS['ssl_on_entry_not_found_ssl_off_entry_not_found']
assert mock_PostgreSQLFinger._is_relevant_exception(exception) is True
result = mock_PostgreSQLFinger.analyze_operational_error(host, exception)
assert host.services[mock_PostgreSQLFinger._SCANNED_SERVICE]['communication_encryption_details'] == ''.join(RELEVANT_EXCEPTIONS_WITH_EXPECTED_RESULTS[exception])