Skip to content

Commit

Permalink
fix: Gracefully handle an invalid log_level (#225)
Browse files Browse the repository at this point in the history
Co-authored-by: Adam McCrea <[email protected]>
  • Loading branch information
lucaseras and adamlogic authored Oct 19, 2024
1 parent 079a361 commit 514976c
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 1 deletion.
18 changes: 17 additions & 1 deletion judoscale-ruby/lib/judoscale/config.rb
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,7 @@ def reset
end

def log_level=(new_level)
@log_level = new_level ? ::Logger::Severity.const_get(new_level.to_s.upcase) : nil
@log_level = get_severity_log_level(new_level)
end

def as_json
Expand All @@ -127,5 +127,21 @@ def as_json
def ignore_large_requests?
@max_request_size_bytes
end

private

def get_severity_log_level(log_level)
return nil if log_level.to_s.strip.empty?

upcased_log_level = log_level.to_s.upcase

if ::Logger::Severity.const_defined?(upcased_log_level)
::Logger::Severity.const_get(upcased_log_level)
else
logger.warn "Invalid log_level detected: #{log_level}"

nil
end
end
end
end
35 changes: 35 additions & 0 deletions judoscale-ruby/test/config_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,19 @@ module Judoscale
end
end

it "gracefully handles invalid JUDOSCALE_LOG_LEVEL values" do
env = {
"JUDOSCALE_LOG_LEVEL" => "not_a_real_log_level"
}

use_env env do
config = Config.instance
_(config.log_level).must_be_nil
end

_(log_string).must_include "Invalid log_level detected: not_a_real_log_level"
end

it "supports legacy ENV var configs" do
env = {
"RAILS_AUTOSCALE_MAX_QUEUES" => "42",
Expand Down Expand Up @@ -133,6 +146,28 @@ module Judoscale
_(enabled_adapter_configs).must_be :empty?
end

it "gracefully handles invalid log_level values and logs a warning" do
Judoscale.configure do |config|
config.log_level = :not_a_real_log_level
end

config = Config.instance
_(config.log_level).must_be_nil

_(log_string).must_include "Invalid log_level detected: not_a_real_log_level"
end

it "gracefully handles blank log_level values" do
Judoscale.configure do |config|
config.log_level = " "
end

config = Config.instance
_(config.log_level).must_be_nil

_(log_string).wont_include "Invalid log_level detected"
end

it "dumps the configuration options as json" do
_(Config.instance.as_json).must_equal({
log_level: nil,
Expand Down

0 comments on commit 514976c

Please sign in to comment.