From 83e56a9028e8759eec66ca1b78f439d63ef75ff7 Mon Sep 17 00:00:00 2001 From: Shreya Malviya Date: Tue, 26 Jul 2022 16:30:10 +0530 Subject: [PATCH] UT: Add tests for CustomPBAConfiguration filename validation --- .../configuration/test_agent_configuration.py | 25 +++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/monkey/tests/unit_tests/common/configuration/test_agent_configuration.py b/monkey/tests/unit_tests/common/configuration/test_agent_configuration.py index d2029d84a..962d2cd4c 100644 --- a/monkey/tests/unit_tests/common/configuration/test_agent_configuration.py +++ b/monkey/tests/unit_tests/common/configuration/test_agent_configuration.py @@ -2,6 +2,7 @@ import json from copy import deepcopy import pytest +from marshmallow import ValidationError from tests.common.example_agent_configuration import ( AGENT_CONFIGURATION, BLOCKED_IPS, @@ -68,6 +69,30 @@ def test_custom_pba_configuration_schema(): assert config.windows_filename == WINDOWS_FILENAME +def test_custom_pba_configuration_schema__empty_filename_allowed(): + schema = CustomPBAConfigurationSchema() + + empty_filename_configuration = CUSTOM_PBA_CONFIGURATION.copy() + empty_filename_configuration.update({"linux_filename": ""}) + + config = schema.load(empty_filename_configuration) + + assert config.linux_command == LINUX_COMMAND + assert config.linux_filename == "" + assert config.windows_command == WINDOWS_COMMAND + assert config.windows_filename == WINDOWS_FILENAME + + +def test_custom_pba_configuration_schema__invalid_filename(): + schema = CustomPBAConfigurationSchema() + + invalid_filename_configuration = CUSTOM_PBA_CONFIGURATION.copy() + invalid_filename_configuration["linux_filename"] = "???" + + with pytest.raises(ValidationError): + schema.load(invalid_filename_configuration) + + def test_scan_target_configuration(): schema = ScanTargetConfigurationSchema()