UT: improve unit tests in test_server_setup.py

This commit is contained in:
VakarisZ 2021-12-01 10:54:05 +02:00
parent 854ca7fa89
commit 8304a4ea19
1 changed files with 34 additions and 29 deletions

View File

@ -5,23 +5,21 @@ import pytest
import monkey_island.cc.setup.config_setup # noqa: F401 import monkey_island.cc.setup.config_setup # noqa: F401
from monkey_island.cc.arg_parser import IslandCmdArgs from monkey_island.cc.arg_parser import IslandCmdArgs
from monkey_island.cc.server_setup import _extract_config from monkey_island.cc.server_setup import _extract_config, get_server_config
from monkey_island.cc.server_utils.file_utils import is_windows_os from monkey_island.cc.server_utils.file_utils import is_windows_os
from monkey_island.cc.setup.island_config_options import IslandConfigOptions from monkey_island.cc.setup.island_config_options import IslandConfigOptions
BAD_JSON = '{"data_dir": "C:\\test\\test"'
@pytest.fixture @pytest.fixture
def cmd_server_config_path(tmpdir) -> Path: def cmd_server_config_path(tmp_path) -> Path:
# Represents the config that user can provide via cmd arguments # Represents the config that user can provide via cmd arguments
return tmpdir / "fake_server_config.json" return tmp_path / "fake_server_config.json"
@pytest.fixture @pytest.fixture
def deployment_server_config_path(tmpdir) -> Path: def deployment_server_config_path(tmp_path) -> Path:
# Represents the config that is built in, deployment specific # Represents the config that is built in, deployment specific
return tmpdir / "fake_server_config3.json" return tmp_path / "fake_server_config3.json"
def create_server_config(config_contents: str, server_config_path: Path): def create_server_config(config_contents: str, server_config_path: Path):
@ -37,54 +35,61 @@ def mock_deployment_config_path(monkeypatch, deployment_server_config_path):
) )
def test_extract_config_defaults(): @pytest.fixture
def empty_cmd_args():
return IslandCmdArgs(setup_only=False, server_config_path=None)
@pytest.fixture
def cmd_args_with_server_config(cmd_server_config_path):
return IslandCmdArgs(setup_only=False, server_config_path=cmd_server_config_path)
def test_extract_config_defaults(empty_cmd_args):
expected = IslandConfigOptions({}) expected = IslandConfigOptions({})
assert ( assert expected.__dict__ == get_server_config(empty_cmd_args).__dict__
expected.__dict__
== _extract_config(IslandCmdArgs(setup_only=False, server_config_path=None)).__dict__
)
def test_deployment_config_overrides_defaults(deployment_server_config_path): def test_deployment_config_overrides_defaults(deployment_server_config_path, empty_cmd_args):
expected = IslandConfigOptions({"log_level": "/log_level_2"}) expected = IslandConfigOptions({"log_level": "/log_level_2"})
create_server_config(dumps({"log_level": "/log_level_2"}), deployment_server_config_path) create_server_config(dumps({"log_level": "/log_level_2"}), deployment_server_config_path)
assert ( assert expected.__dict__ == get_server_config(empty_cmd_args).__dict__
expected.__dict__
== _extract_config(IslandCmdArgs(setup_only=False, server_config_path=None)).__dict__
)
def test_cmd_config_overrides_everything(deployment_server_config_path, cmd_server_config_path): def test_cmd_config_overrides_everything(
deployment_server_config_path, cmd_server_config_path, cmd_args_with_server_config
):
expected = IslandConfigOptions({"log_level": "/log_level_3"}) expected = IslandConfigOptions({"log_level": "/log_level_3"})
create_server_config(dumps({"log_level": "/log_level_2"}), deployment_server_config_path) create_server_config(dumps({"log_level": "/log_level_2"}), deployment_server_config_path)
create_server_config(dumps({"log_level": "/log_level_3"}), cmd_server_config_path) create_server_config(dumps({"log_level": "/log_level_3"}), cmd_server_config_path)
extracted_config = _extract_config( extracted_config = get_server_config(cmd_args_with_server_config)
IslandCmdArgs(setup_only=False, server_config_path=cmd_server_config_path)
)
assert expected.__dict__ == extracted_config.__dict__ assert expected.__dict__ == extracted_config.__dict__
def test_not_overriding_unspecified_values(deployment_server_config_path, cmd_server_config_path): def test_not_overriding_unspecified_values(
deployment_server_config_path, cmd_server_config_path, cmd_args_with_server_config
):
expected = IslandConfigOptions({"log_level": "/log_level_2", "data_dir": "/data_dir1"}) expected = IslandConfigOptions({"log_level": "/log_level_2", "data_dir": "/data_dir1"})
create_server_config(dumps({"data_dir": "/data_dir1"}), deployment_server_config_path) create_server_config(dumps({"data_dir": "/data_dir1"}), deployment_server_config_path)
create_server_config(dumps({"log_level": "/log_level_2"}), cmd_server_config_path) create_server_config(dumps({"log_level": "/log_level_2"}), cmd_server_config_path)
extracted_config = _extract_config( extracted_config = get_server_config(cmd_args_with_server_config)
IslandCmdArgs(setup_only=False, server_config_path=cmd_server_config_path)
)
assert expected.__dict__ == extracted_config.__dict__ assert expected.__dict__ == extracted_config.__dict__
def test_paths_get_expanded(deployment_server_config_path): def test_paths_get_expanded(deployment_server_config_path, empty_cmd_args):
if is_windows_os(): if is_windows_os():
path = "%temp%/path" path = "%temp%/path"
else: else:
path = "$HOME/path" path = "$HOME/path"
create_server_config(dumps({"data_dir": path}), deployment_server_config_path) create_server_config(dumps({"data_dir": path}), deployment_server_config_path)
extracted_config = _extract_config(IslandCmdArgs(setup_only=False, server_config_path=None)) extracted_config = get_server_config(empty_cmd_args)
assert not extracted_config.data_dir == path assert not extracted_config.data_dir == path
def test_malformed_json(cmd_server_config_path): BAD_JSON = '{"data_dir": "C:\\test\\test"'
def test_malformed_json(cmd_server_config_path, cmd_args_with_server_config):
create_server_config(BAD_JSON, cmd_server_config_path) create_server_config(BAD_JSON, cmd_server_config_path)
with pytest.raises(SystemExit): with pytest.raises(SystemExit):
_extract_config(IslandCmdArgs(setup_only=False, server_config_path=cmd_server_config_path)) _extract_config(cmd_args_with_server_config)