From 6dd94846082e54ff8468089616dbf0adf0ef6245 Mon Sep 17 00:00:00 2001 From: tempate Date: Thu, 11 Apr 2024 09:17:22 +0200 Subject: [PATCH] Validate new YAML options Signed-off-by: tempate --- .../cpp/recorder/YamlReaderConfiguration.cpp | 28 +++++++++++++++---- 1 file changed, 23 insertions(+), 5 deletions(-) diff --git a/ddsrecorder_yaml/src/cpp/recorder/YamlReaderConfiguration.cpp b/ddsrecorder_yaml/src/cpp/recorder/YamlReaderConfiguration.cpp index f2f991055..afd09dc98 100644 --- a/ddsrecorder_yaml/src/cpp/recorder/YamlReaderConfiguration.cpp +++ b/ddsrecorder_yaml/src/cpp/recorder/YamlReaderConfiguration.cpp @@ -234,6 +234,16 @@ void RecorderConfiguration::load_recorder_configuration_( { auto output_yml = YamlReader::get_value_in_tag(yml, RECORDER_OUTPUT_TAG); + const std::set output_tags{ + RECORDER_OUTPUT_PATH_FILE_TAG, + RECORDER_OUTPUT_FILE_NAME_TAG, + RECORDER_OUTPUT_TIMESTAMP_FORMAT_TAG, + RECORDER_OUTPUT_LOCAL_TIMESTAMP_TAG, + RECORDER_OUTPUT_SAFETY_MARGIN_TAG, + RECORDER_OUTPUT_RESOURCE_LIMITS_TAG}; + + YamlValidator::validate_tags(output_yml, output_tags); + ///// // Get optional file path if (YamlReader::is_tag_present(output_yml, RECORDER_OUTPUT_PATH_FILE_TAG)) @@ -277,6 +287,13 @@ void RecorderConfiguration::load_recorder_configuration_( { auto resource_limits_yml = YamlReader::get_value_in_tag(output_yml, RECORDER_OUTPUT_RESOURCE_LIMITS_TAG); + const std::set resource_limits_tags{ + RECORDER_OUTPUT_RESOURCE_LIMITS_FILE_ROTATION_TAG, + RECORDER_OUTPUT_RESOURCE_LIMITS_MAX_FILE_SIZE_TAG, + RECORDER_OUTPUT_RESOURCE_LIMITS_MAX_SIZE_TAG}; + + YamlValidator::validate_tags(resource_limits_yml, resource_limits_tags); + ///// // Get optional file rotation if (YamlReader::is_tag_present(resource_limits_yml, RECORDER_OUTPUT_RESOURCE_LIMITS_FILE_ROTATION_TAG)) @@ -358,8 +375,8 @@ void RecorderConfiguration::load_recorder_configuration_( } void RecorderConfiguration::load_output_configuration_( - const Yaml& yml, - const YamlReaderVersion& version) + const Yaml& yml, + const YamlReaderVersion& version) { const std::set tags{ RECORDER_OUTPUT_PATH_FILE_TAG, @@ -428,8 +445,7 @@ void RecorderConfiguration::load_controller_configuration_( if (YamlReader::is_tag_present(yml, RECORDER_REMOTE_CONTROLLER_INITIAL_STATE_TAG)) { // Convert to enum and check valid wherever used to avoid mcap library dependency in YAML module - initial_state = YamlReader::get(yml, - RECORDER_REMOTE_CONTROLLER_INITIAL_STATE_TAG, version); + initial_state = YamlReader::get(yml, RECORDER_REMOTE_CONTROLLER_INITIAL_STATE_TAG, version); // Case insensitive eprosima::utils::to_uppercase(initial_state); } @@ -457,7 +473,9 @@ void RecorderConfiguration::load_specs_configuration_( NUMBER_THREADS_TAG, SPECS_QOS_TAG, RECORDER_SPECS_MAX_PENDING_SAMPLES_TAG, - RECORDER_SPECS_CLEANUP_PERIOD_TAG}; + RECORDER_SPECS_CLEANUP_PERIOD_TAG, + LOG_CONFIGURATION_TAG, + MONITOR_TAG}; YamlValidator::validate_tags(yml, tags);