forked from p15670423/monkey
Test for AttackTechnique
This commit is contained in:
parent
a927da3bef
commit
92ab1ad2f2
|
@ -144,7 +144,7 @@ class AttackTechnique(object, metaclass=abc.ABCMeta):
|
|||
|
||||
@classmethod
|
||||
def _check_status(cls, status):
|
||||
if status == ScanStatus.UNSCANNED.value and cls._is_disabled_in_config():
|
||||
if status == ScanStatus.UNSCANNED.value and not cls._is_enabled_in_config():
|
||||
return ScanStatus.DISABLED.value
|
||||
return status
|
||||
|
||||
|
|
|
@ -1,6 +1,9 @@
|
|||
import copy
|
||||
from unittest import TestCase
|
||||
from unittest.mock import patch
|
||||
|
||||
from common.utils.attack_utils import ScanStatus
|
||||
from monkey_island.cc.services.attack.attack_config import AttackConfig
|
||||
|
||||
from .pba_technique import PostBreachTechnique
|
||||
|
||||
|
@ -24,7 +27,7 @@ config =\
|
|||
'necessary': False,
|
||||
'title': '',
|
||||
'type': 'bool',
|
||||
'value': False # this field denotes whether technique is enabled or disabled in config
|
||||
'value': None # denotes whether technique is enabled/disabled in config (set below in param_list)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -45,7 +48,7 @@ param_list = [
|
|||
'status': ScanStatus.UNSCANNED.value,
|
||||
'title': 'Unscanned technique'
|
||||
},
|
||||
set_config(True), # configuration
|
||||
copy.deepcopy(set_config(True)), # configuration
|
||||
ScanStatus.UNSCANNED.value # expected status
|
||||
),
|
||||
|
||||
|
@ -57,7 +60,7 @@ param_list = [
|
|||
'status': ScanStatus.SCANNED.value,
|
||||
'title': 'Scanned technique'
|
||||
},
|
||||
set_config(True), # configuration
|
||||
copy.deepcopy(set_config(True)), # configuration
|
||||
ScanStatus.SCANNED.value # expected status
|
||||
),
|
||||
|
||||
|
@ -69,7 +72,7 @@ param_list = [
|
|||
'status': ScanStatus.USED.value,
|
||||
'title': 'Used technique'
|
||||
},
|
||||
set_config(True), # configuration
|
||||
copy.deepcopy(set_config(True)), # configuration
|
||||
ScanStatus.USED.value # expected status
|
||||
),
|
||||
|
||||
|
@ -81,7 +84,7 @@ param_list = [
|
|||
'status': ScanStatus.UNSCANNED.value,
|
||||
'title': 'Disabled technique'
|
||||
},
|
||||
set_config(False), # configuration
|
||||
copy.deepcopy(set_config(False)), # configuration
|
||||
ScanStatus.DISABLED.value # expected status
|
||||
)
|
||||
]
|
||||
|
@ -91,4 +94,5 @@ class TestAttackTechnique(TestCase):
|
|||
def test__check_status(self):
|
||||
for telem_data, config, expected_status in param_list:
|
||||
with self.subTest(msg=f"Checking if correct status is returned (status: {telem_data['message']})"):
|
||||
self.assertEqual(T9999._check_status(telem_data['status']), expected_status)
|
||||
with patch.object(AttackConfig, 'get_config', return_value=config):
|
||||
self.assertEqual(T9999._check_status(telem_data['status']), expected_status)
|
||||
|
|
Loading…
Reference in New Issue