forked from p15670423/monkey
UT: improve unit tests in test_server_setup.py
This commit is contained in:
parent
854ca7fa89
commit
8304a4ea19
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue