From 47b1255918bd7c0c9e231753ddc940a88c4e12e9 Mon Sep 17 00:00:00 2001 From: Andrzej Stencel Date: Mon, 12 Feb 2024 16:22:36 +0100 Subject: [PATCH] fix: fix how `compress` configuration flag works In v1.8.0, setting `compress` flag to either `true` or `false` caused compression to be enabled. This fixes multiple problems in the `configure` method of the plugin. --- lib/fluent/plugin/out_sumologic.rb | 73 +++++++++++------------------- test/plugin/test_out_sumologic.rb | 57 ++++++++++++++++++++--- 2 files changed, 78 insertions(+), 52 deletions(-) diff --git a/lib/fluent/plugin/out_sumologic.rb b/lib/fluent/plugin/out_sumologic.rb index c4659d8..6b1a470 100644 --- a/lib/fluent/plugin/out_sumologic.rb +++ b/lib/fluent/plugin/out_sumologic.rb @@ -196,69 +196,50 @@ def multi_workers_ready? def configure(conf) compat_parameters_convert(conf, :buffer) + super - unless conf['endpoint'] =~ URI::regexp - raise Fluent::ConfigError, "Invalid SumoLogic endpoint url: #{conf['endpoint']}" + unless @endpoint =~ URI::regexp + raise Fluent::ConfigError, "Invalid SumoLogic endpoint url: #{@endpoint}" end - unless conf['data_type'].nil? - unless conf['data_type'] =~ /\A(?:logs|metrics)\z/ - raise Fluent::ConfigError, "Invalid data_type #{conf['data_type']} must be logs or metrics" - end + unless @data_type =~ /\A(?:logs|metrics)\z/ + raise Fluent::ConfigError, "Invalid data_type #{@data_type} must be logs or metrics" end - if conf['data_type'].nil? || conf['data_type'] == LOGS_DATA_TYPE - unless conf['log_format'].nil? - unless conf['log_format'] =~ /\A(?:json|text|json_merge|fields)\z/ - raise Fluent::ConfigError, "Invalid log_format #{conf['log_format']} must be text, json, json_merge or fields" - end + if @data_type == LOGS_DATA_TYPE + unless @log_format =~ /\A(?:json|text|json_merge|fields)\z/ + raise Fluent::ConfigError, "Invalid log_format #{@log_format} must be text, json, json_merge or fields" end end - if conf['data_type'] == METRICS_DATA_TYPE && ! conf['metrics_data_type'].nil? - unless conf['metrics_data_type'] =~ /\A(?:graphite|carbon2|pronetheus)\z/ - raise Fluent::ConfigError, "Invalid metrics_data_type #{conf['metrics_data_type']} must be graphite or carbon2 or prometheus" + if @data_type == METRICS_DATA_TYPE + unless @metric_data_format =~ /\A(?:graphite|carbon2|prometheus)\z/ + raise Fluent::ConfigError, "Invalid metric_data_format #{@metric_data_format} must be graphite or carbon2 or prometheus" end end - conf['custom_fields'] = validate_key_value_pairs(conf['custom_fields']) - if conf['custom_fields'].nil? - conf.delete 'custom_fields' - end - unless conf['custom_fields'] - @log.debug "Custom fields: #{conf['custom_fields']}" - end - - conf['custom_dimensions'] = validate_key_value_pairs(conf['custom_dimensions']) - if conf['custom_dimensions'].nil? - conf.delete 'custom_dimensions' - end - unless conf['custom_dimensions'] - @log.debug "Custom dimensions: #{conf['custom_dimensions']}" + @custom_fields = validate_key_value_pairs(@custom_fields) + if @custom_fields + @log.debug "Custom fields: #{@custom_fields}" end - # For some reason default is set incorrectly in unit-tests - if conf['sumo_client'].nil? || conf['sumo_client'].strip.length == 0 - conf['sumo_client'] = 'fluentd-output' + @custom_dimensions = validate_key_value_pairs(@custom_dimensions) + if @custom_dimensions + @log.debug "Custom dimensions: #{@custom_dimensions}" end @sumo_conn = SumologicConnection.new( - conf['endpoint'], - conf['verify_ssl'], - conf['open_timeout'].to_i, - conf['send_timeout'].to_i, - conf['proxy_uri'], - conf['disable_cookies'], - conf['sumo_client'], - conf['compress'], - conf['compress_encoding'], - log, + @endpoint, + @verify_ssl, + @open_timeout, + @send_timeout, + @proxy_uri, + @disable_cookies, + @sumo_client, + @compress, + @compress_encoding, + @log, ) - - if !conf['max_request_size'].nil? && conf['max_request_size'].to_i <= 0 - conf['max_request_size'] = '0' - end - super end # This method is called when starting. diff --git a/test/plugin/test_out_sumologic.rb b/test/plugin/test_out_sumologic.rb index f23a8dc..91a7f93 100644 --- a/test/plugin/test_out_sumologic.rb +++ b/test/plugin/test_out_sumologic.rb @@ -19,7 +19,15 @@ def create_driver(conf = CONFIG) def test_no_endpoint_configure config = %{} exception = assert_raise(Fluent::ConfigError) {create_driver(config)} - assert_equal("Invalid SumoLogic endpoint url: ", exception.message) + assert_equal("'endpoint' parameter is required", exception.message) + end + + def test_invalid_endpoint + config = %{ + endpoint Not-a-URL + } + exception = assert_raise(Fluent::ConfigError) {create_driver(config)} + assert_equal("Invalid SumoLogic endpoint url: Not-a-URL", exception.message) end def test_invalid_data_type_configure @@ -40,14 +48,14 @@ def test_invalid_log_format_configure assert_equal("Invalid log_format foo must be text, json, json_merge or fields", exception.message) end - def test_invalid_metrics_data_type + def test_invalid_metric_data_format config = %{ endpoint https://SUMOLOGIC_URL data_type metrics - metrics_data_type foo + metric_data_format foo } exception = assert_raise(Fluent::ConfigError) {create_driver(config)} - assert_equal("Invalid metrics_data_type foo must be graphite or carbon2 or prometheus", exception.message) + assert_equal("Invalid metric_data_format foo must be graphite or carbon2 or prometheus", exception.message) end def test_default_configure @@ -73,11 +81,13 @@ def test_default_configure assert_equal instance.proxy_uri, nil assert_equal instance.disable_cookies, false assert_equal instance.sumo_client, 'fluentd-output' + assert_equal instance.compress, true assert_equal instance.compress_encoding, 'gzip' end def test_emit_text config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format text source_category test @@ -99,6 +109,7 @@ def test_emit_text def test_emit_text_custom_sumo_client config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format text source_category test @@ -121,6 +132,7 @@ def test_emit_text_custom_sumo_client def test_emit_json config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format json source_category test @@ -142,6 +154,7 @@ def test_emit_json def test_emit_empty_fields config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format fields source_category test @@ -163,6 +176,7 @@ def test_emit_empty_fields def test_emit_json_double_encoded config = %{ + compress false endpoint https://endpoint3.collection.us2.sumologic.com/receiver/v1/http/1234 log_format json source_category test @@ -184,6 +198,7 @@ def test_emit_json_double_encoded def test_emit_text_format_as_json config = %{ + compress false endpoint https://endpoint3.collection.us2.sumologic.com/receiver/v1/http/1234 log_format json source_category test @@ -205,6 +220,7 @@ def test_emit_text_format_as_json def test_emit_json_merge config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format json_merge source_category test @@ -226,6 +242,7 @@ def test_emit_json_merge def test_emit_json_merge_timestamp config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format json_merge source_category test @@ -247,6 +264,7 @@ def test_emit_json_merge_timestamp def test_emit_with_sumo_metadata_with_fields_json_format config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format json } @@ -270,6 +288,7 @@ def test_emit_with_sumo_metadata_with_fields_json_format def test_emit_with_sumo_metadata_with_fields_fields_format config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format fields } @@ -293,6 +312,7 @@ def test_emit_with_sumo_metadata_with_fields_fields_format def test_emit_with_sumo_metadata_with_fields_and_custom_fields_fields_format config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format fields custom_fields "lorem=ipsum,dolor=amet" @@ -317,6 +337,7 @@ def test_emit_with_sumo_metadata_with_fields_and_custom_fields_fields_format def test_emit_with_sumo_metadata_with_fields_and_empty_custom_fields_fields_format config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format fields custom_fields "" @@ -341,6 +362,7 @@ def test_emit_with_sumo_metadata_with_fields_and_empty_custom_fields_fields_form def test_emit_with_sumo_metadata_with_empty_fields_and_custom_fields_fields_format config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format fields custom_fields "lorem=ipsum,invalid" @@ -365,6 +387,7 @@ def test_emit_with_sumo_metadata_with_empty_fields_and_custom_fields_fields_form def test_emit_with_sumo_metadata config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format json } @@ -387,6 +410,7 @@ def test_emit_with_sumo_metadata def test_emit_json_no_timestamp config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format json source_category test @@ -408,6 +432,7 @@ def test_emit_json_no_timestamp def test_emit_json_timestamp_key config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format json source_category test @@ -429,6 +454,7 @@ def test_emit_json_timestamp_key def test_emit_graphite config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 data_type metrics metric_data_format graphite @@ -450,6 +476,7 @@ def test_emit_graphite def test_emit_carbon config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 data_type metrics metric_data_format carbon2 @@ -471,6 +498,7 @@ def test_emit_carbon def test_emit_prometheus config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 data_type metrics metric_data_format prometheus @@ -492,6 +520,7 @@ def test_emit_prometheus def test_emit_prometheus_with_custom_dimensions config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 data_type metrics metric_data_format prometheus @@ -520,6 +549,7 @@ def test_emit_prometheus_with_custom_dimensions def test_emit_prometheus_with_empty_custom_metadata config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 data_type metrics metric_data_format prometheus @@ -547,6 +577,7 @@ def test_emit_prometheus_with_empty_custom_metadata def test_batching_same_headers config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format json source_category test @@ -568,6 +599,7 @@ def test_batching_same_headers def test_batching_different_headers config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format json source_category test @@ -593,6 +625,7 @@ def test_batching_different_headers def test_batching_different_fields config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format fields source_category test @@ -635,7 +668,6 @@ def test_emit_json_merge_timestamp_compress_deflate source_name test compress true compress_encoding deflate - } driver = create_driver(config) time = event_time @@ -657,7 +689,6 @@ def test_emit_json_merge_timestamp_compress_gzip source_host test source_name test compress true - } driver = create_driver(config) time = event_time @@ -673,6 +704,7 @@ def test_emit_json_merge_timestamp_compress_gzip def test_emit_text_from_array config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format text source_category test @@ -694,6 +726,7 @@ def test_emit_text_from_array def test_emit_text_from_dict config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format text source_category test @@ -715,6 +748,7 @@ def test_emit_text_from_dict def test_emit_fields_string_based config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format fields source_category test @@ -736,6 +770,7 @@ def test_emit_fields_string_based def test_emit_fields_invalid_json_string_based_1 config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format fields source_category test @@ -757,6 +792,7 @@ def test_emit_fields_invalid_json_string_based_1 def test_emit_fields_invalid_json_string_based_2 config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format fields source_category test @@ -778,6 +814,7 @@ def test_emit_fields_invalid_json_string_based_2 def test_emit_fields_invalid_json_string_based_3 config = %{ + compress false endpoint https://collectors.sumologic.com/v1/receivers/http/1234 log_format fields source_category test @@ -800,6 +837,7 @@ def test_emit_fields_invalid_json_string_based_3 def test_warning_response_from_receiver endpoint = "https://collectors.sumologic.com/v1/receivers/http/1234" config = %{ + compress false endpoint #{endpoint} } testdata = [ @@ -828,6 +866,7 @@ def test_warning_response_from_receiver def test_resend endpoint = "https://collectors.sumologic.com/v1/receivers/http/1234" config = %{ + compress false endpoint #{endpoint} retry_min_interval 0s retry_max_times 3 @@ -851,6 +890,7 @@ def test_resend def test_resend_failed endpoint = "https://collectors.sumologic.com/v1/receivers/http/1234" config = %{ + compress false endpoint #{endpoint} retry_min_interval 0s retry_max_times 15 @@ -873,6 +913,7 @@ def test_resend_failed def test_resend_forever endpoint = "https://collectors.sumologic.com/v1/receivers/http/1234" config = %{ + compress false endpoint #{endpoint} retry_min_interval 0s retry_max_times 0 @@ -897,6 +938,7 @@ def test_resend_forever def test_skip_retry endpoint = "https://collectors.sumologic.com/v1/receivers/http/1234" config = %{ + compress false endpoint #{endpoint} } time = event_time @@ -917,10 +959,12 @@ def test_split_negative_or_zero configs = [ %{ + compress false endpoint #{endpoint} max_request_size -5 }, %{ + compress false endpoint #{endpoint} max_request_size 0 } @@ -949,6 +993,7 @@ def test_split endpoint = "https://collectors.sumologic.com/v1/receivers/http/1234" config = %{ + compress false endpoint #{endpoint} max_request_size 80 }