2019-10-01 15:42:51 +08:00
|
|
|
import logging
|
2020-07-15 23:46:04 +08:00
|
|
|
import os
|
|
|
|
from time import sleep
|
2019-10-01 15:42:51 +08:00
|
|
|
|
2019-08-29 20:14:07 +08:00
|
|
|
import pytest
|
2021-03-02 21:01:56 +08:00
|
|
|
from typing_extensions import Type
|
|
|
|
|
2021-04-06 21:19:27 +08:00
|
|
|
from envs.monkey_zoo.blackbox.analyzers.communication_analyzer import CommunicationAnalyzer
|
2021-03-08 19:58:11 +08:00
|
|
|
from envs.monkey_zoo.blackbox.analyzers.zerologon_analyzer import ZerologonAnalyzer
|
2021-03-08 21:41:22 +08:00
|
|
|
from envs.monkey_zoo.blackbox.config_templates.config_template import ConfigTemplate
|
2022-04-12 19:59:19 +08:00
|
|
|
from envs.monkey_zoo.blackbox.config_templates.grouped.depth_1_a import Depth1A
|
|
|
|
from envs.monkey_zoo.blackbox.config_templates.grouped.depth_1_b import Depth1B
|
2022-04-13 20:27:28 +08:00
|
|
|
from envs.monkey_zoo.blackbox.config_templates.grouped.depth_2_a import Depth2A
|
2022-04-13 16:02:34 +08:00
|
|
|
from envs.monkey_zoo.blackbox.config_templates.grouped.depth_3_a import Depth3A
|
2021-08-02 19:09:37 +08:00
|
|
|
from envs.monkey_zoo.blackbox.gcp_test_machine_list import GCP_TEST_MACHINE_LIST
|
2021-04-07 05:55:44 +08:00
|
|
|
from envs.monkey_zoo.blackbox.island_client.island_config_parser import IslandConfigParser
|
|
|
|
from envs.monkey_zoo.blackbox.island_client.monkey_island_client import MonkeyIslandClient
|
2021-04-06 21:19:27 +08:00
|
|
|
from envs.monkey_zoo.blackbox.log_handlers.test_logs_handler import TestLogsHandler
|
2020-04-24 18:19:07 +08:00
|
|
|
from envs.monkey_zoo.blackbox.tests.exploitation import ExploitationTest
|
2021-08-24 21:11:22 +08:00
|
|
|
from envs.monkey_zoo.blackbox.utils.gcp_machine_handlers import (
|
|
|
|
initialize_gcp_client,
|
|
|
|
start_machines,
|
|
|
|
stop_machines,
|
|
|
|
)
|
2021-07-30 21:54:15 +08:00
|
|
|
from monkey_island.cc.services.mode.mode_enum import IslandModeEnum
|
2019-08-27 20:52:39 +08:00
|
|
|
|
2022-04-13 16:03:59 +08:00
|
|
|
DEFAULT_TIMEOUT_SECONDS = 2 * 60 + 30
|
2019-09-13 21:12:58 +08:00
|
|
|
MACHINE_BOOTUP_WAIT_SECONDS = 30
|
2019-10-01 15:42:51 +08:00
|
|
|
LOG_DIR_PATH = "./logs"
|
2021-03-05 16:46:07 +08:00
|
|
|
logging.basicConfig(level=logging.INFO)
|
2019-10-01 21:11:53 +08:00
|
|
|
LOGGER = logging.getLogger(__name__)
|
2019-08-29 19:57:04 +08:00
|
|
|
|
2019-09-07 01:59:11 +08:00
|
|
|
|
2021-04-06 21:19:27 +08:00
|
|
|
@pytest.fixture(autouse=True, scope="session")
|
2020-05-13 15:44:04 +08:00
|
|
|
def GCPHandler(request, no_gcp):
|
|
|
|
if not no_gcp:
|
2021-05-11 15:44:02 +08:00
|
|
|
try:
|
2021-08-24 21:11:22 +08:00
|
|
|
initialize_gcp_client()
|
|
|
|
start_machines(GCP_TEST_MACHINE_LIST)
|
2021-05-11 15:44:02 +08:00
|
|
|
except Exception as e:
|
|
|
|
LOGGER.error("GCP Handler failed to initialize: %s." % e)
|
|
|
|
pytest.exit("Encountered an error while starting GCP machines. Stopping the tests.")
|
2020-05-13 15:44:04 +08:00
|
|
|
wait_machine_bootup()
|
2019-09-07 01:59:11 +08:00
|
|
|
|
2020-05-13 15:44:04 +08:00
|
|
|
def fin():
|
2021-08-24 21:11:22 +08:00
|
|
|
stop_machines(GCP_TEST_MACHINE_LIST)
|
2019-09-07 01:59:11 +08:00
|
|
|
|
2020-05-13 15:44:04 +08:00
|
|
|
request.addfinalizer(fin)
|
2019-09-07 01:59:11 +08:00
|
|
|
|
|
|
|
|
2021-04-06 21:19:27 +08:00
|
|
|
@pytest.fixture(autouse=True, scope="session")
|
2019-09-13 21:12:58 +08:00
|
|
|
def delete_logs():
|
2019-10-01 21:11:53 +08:00
|
|
|
LOGGER.info("Deleting monkey logs before new tests.")
|
2019-10-01 15:42:51 +08:00
|
|
|
TestLogsHandler.delete_log_folder_contents(TestMonkeyBlackbox.get_log_dir_path())
|
2019-09-13 21:12:58 +08:00
|
|
|
|
|
|
|
|
|
|
|
def wait_machine_bootup():
|
|
|
|
sleep(MACHINE_BOOTUP_WAIT_SECONDS)
|
|
|
|
|
|
|
|
|
2021-04-06 21:19:27 +08:00
|
|
|
@pytest.fixture(scope="class")
|
2020-05-13 15:44:04 +08:00
|
|
|
def island_client(island, quick_performance_tests):
|
2021-05-20 13:44:12 +08:00
|
|
|
client_established = False
|
|
|
|
try:
|
|
|
|
island_client_object = MonkeyIslandClient(island)
|
|
|
|
client_established = island_client_object.get_api_status()
|
|
|
|
except Exception:
|
2021-05-21 13:41:28 +08:00
|
|
|
logging.exception("Got an exception while trying to establish connection to the Island.")
|
2021-05-20 13:44:12 +08:00
|
|
|
finally:
|
|
|
|
if not client_established:
|
|
|
|
pytest.exit("BB tests couldn't establish communication to the island.")
|
2020-05-13 15:44:04 +08:00
|
|
|
if not quick_performance_tests:
|
|
|
|
island_client_object.reset_env()
|
2021-07-30 21:54:15 +08:00
|
|
|
island_client_object.set_scenario(IslandModeEnum.ADVANCED.value)
|
2019-09-11 17:39:28 +08:00
|
|
|
yield island_client_object
|
2019-09-07 01:59:11 +08:00
|
|
|
|
|
|
|
|
2021-04-06 21:19:27 +08:00
|
|
|
@pytest.mark.usefixtures("island_client")
|
2019-09-11 17:39:28 +08:00
|
|
|
# noinspection PyUnresolvedReferences
|
2021-03-02 21:01:56 +08:00
|
|
|
class TestMonkeyBlackbox:
|
2019-09-13 21:12:58 +08:00
|
|
|
@staticmethod
|
2021-04-06 21:19:27 +08:00
|
|
|
def run_exploitation_test(
|
|
|
|
island_client: MonkeyIslandClient,
|
|
|
|
config_template: Type[ConfigTemplate],
|
|
|
|
test_name: str,
|
|
|
|
timeout_in_seconds=DEFAULT_TIMEOUT_SECONDS,
|
|
|
|
):
|
2021-03-02 21:01:56 +08:00
|
|
|
raw_config = IslandConfigParser.get_raw_config(config_template, island_client)
|
2021-04-06 21:19:27 +08:00
|
|
|
analyzer = CommunicationAnalyzer(
|
|
|
|
island_client, IslandConfigParser.get_ips_of_targets(raw_config)
|
|
|
|
)
|
|
|
|
log_handler = TestLogsHandler(
|
|
|
|
test_name, island_client, TestMonkeyBlackbox.get_log_dir_path()
|
|
|
|
)
|
2020-04-10 19:32:39 +08:00
|
|
|
ExploitationTest(
|
2020-02-25 17:24:28 +08:00
|
|
|
name=test_name,
|
|
|
|
island_client=island_client,
|
2021-03-02 21:01:56 +08:00
|
|
|
raw_config=raw_config,
|
2020-02-25 17:24:28 +08:00
|
|
|
analyzers=[analyzer],
|
|
|
|
timeout=timeout_in_seconds,
|
2021-04-06 21:19:27 +08:00
|
|
|
log_handler=log_handler,
|
|
|
|
).run()
|
2019-10-01 15:42:51 +08:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_log_dir_path():
|
|
|
|
return os.path.abspath(LOG_DIR_PATH)
|
2019-09-07 01:59:11 +08:00
|
|
|
|
2022-04-12 19:59:19 +08:00
|
|
|
def test_depth_1_a(self, island_client):
|
|
|
|
TestMonkeyBlackbox.run_exploitation_test(island_client, Depth1A, "Depth1A test suite")
|
2022-01-13 22:10:36 +08:00
|
|
|
|
2022-04-12 19:59:19 +08:00
|
|
|
def test_depth_1_b(self, island_client):
|
2021-03-08 19:58:11 +08:00
|
|
|
test_name = "Zerologon_exploiter"
|
2021-04-06 21:19:27 +08:00
|
|
|
expected_creds = [
|
|
|
|
"Administrator",
|
|
|
|
"aad3b435b51404eeaad3b435b51404ee",
|
|
|
|
"2864b62ea4496934a5d6e86f50b834a5",
|
|
|
|
]
|
2022-04-12 19:59:19 +08:00
|
|
|
raw_config = IslandConfigParser.get_raw_config(Depth1B, island_client)
|
2021-10-26 22:14:02 +08:00
|
|
|
zero_logon_analyzer = ZerologonAnalyzer(island_client, expected_creds)
|
|
|
|
communication_analyzer = CommunicationAnalyzer(
|
|
|
|
island_client, IslandConfigParser.get_ips_of_targets(raw_config)
|
|
|
|
)
|
2021-04-06 21:19:27 +08:00
|
|
|
log_handler = TestLogsHandler(
|
|
|
|
test_name, island_client, TestMonkeyBlackbox.get_log_dir_path()
|
|
|
|
)
|
2021-03-08 17:07:24 +08:00
|
|
|
ExploitationTest(
|
|
|
|
name=test_name,
|
|
|
|
island_client=island_client,
|
|
|
|
raw_config=raw_config,
|
2021-10-26 22:14:02 +08:00
|
|
|
analyzers=[zero_logon_analyzer, communication_analyzer],
|
2021-03-08 17:07:24 +08:00
|
|
|
timeout=DEFAULT_TIMEOUT_SECONDS,
|
2021-04-06 21:19:27 +08:00
|
|
|
log_handler=log_handler,
|
|
|
|
).run()
|
2021-03-08 17:07:24 +08:00
|
|
|
|
2022-04-13 20:27:28 +08:00
|
|
|
def test_depth_2_a(self, island_client):
|
|
|
|
TestMonkeyBlackbox.run_exploitation_test(island_client, Depth2A, "Depth2A test suite")
|
|
|
|
|
2022-04-13 16:02:34 +08:00
|
|
|
def test_depth_3_a(self, island_client):
|
|
|
|
TestMonkeyBlackbox.run_exploitation_test(island_client, Depth3A, "Depth4A test suite")
|