diff options
author | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2015-05-26 13:21:28 -0300 |
---|---|---|
committer | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2015-05-26 13:21:28 -0300 |
commit | b1f6be9b5ea9eae4f6c5762852027d4808a037e2 (patch) | |
tree | f3782b6aa1531d89587720d19aca421f4a2ee580 /activesupport | |
parent | 58ed699376f378f6d9b1a23484fcee4454ddaee5 (diff) | |
parent | e768c519fb6015e00961702a5165c6dab548a954 (diff) | |
download | rails-b1f6be9b5ea9eae4f6c5762852027d4808a037e2.tar.gz rails-b1f6be9b5ea9eae4f6c5762852027d4808a037e2.tar.bz2 rails-b1f6be9b5ea9eae4f6c5762852027d4808a037e2.zip |
Merge pull request #20208 from gaurish/raise_on_missing_ordered_options
Add bang version to OrderedOptions
Diffstat (limited to 'activesupport')
-rw-r--r-- | activesupport/CHANGELOG.md | 17 | ||||
-rw-r--r-- | activesupport/lib/active_support/ordered_options.rb | 8 | ||||
-rw-r--r-- | activesupport/test/ordered_options_test.rb | 15 |
3 files changed, 39 insertions, 1 deletions
diff --git a/activesupport/CHANGELOG.md b/activesupport/CHANGELOG.md index 36be5fe936..2fac308d2e 100644 --- a/activesupport/CHANGELOG.md +++ b/activesupport/CHANGELOG.md @@ -1,3 +1,20 @@ +* Add a bang version to `ActiveSupport::OrderedOptions` get methods which will raise + an `KeyError` if the value is `.blank?` + + Before: + + if (slack_url = Rails.application.secrets.slack_url).present?) + # Do something worthwhile + else + # Raise as important secret password is not specified + end + + After: + + slack_url = Rails.application.secrets.slack_url! + + *Aditya Sanghi*, *Gaurish Sharma* + * Remove deprecated `Class#superclass_delegating_accessor`. Use `Class#class_attribute` instead. diff --git a/activesupport/lib/active_support/ordered_options.rb b/activesupport/lib/active_support/ordered_options.rb index a33e2c58a9..ebf2a9bc29 100644 --- a/activesupport/lib/active_support/ordered_options.rb +++ b/activesupport/lib/active_support/ordered_options.rb @@ -31,7 +31,13 @@ module ActiveSupport if name_string.chomp!('=') self[name_string] = args.first else - self[name] + bangs = name_string.chomp!('!') + + if bangs + fetch(name_string.to_sym).presence || raise(KeyError.new("#{name_string} is blank.")) + else + self[name_string] + end end end diff --git a/activesupport/test/ordered_options_test.rb b/activesupport/test/ordered_options_test.rb index fdc745b23b..18767a3536 100644 --- a/activesupport/test/ordered_options_test.rb +++ b/activesupport/test/ordered_options_test.rb @@ -85,4 +85,19 @@ class OrderedOptionsTest < ActiveSupport::TestCase assert_equal 42, a.method(:blah=).call(42) assert_equal 42, a.method(:blah).call end + + def test_raises_with_bang + a = ActiveSupport::OrderedOptions.new + a[:foo] = :bar + assert a.respond_to?(:foo!) + + assert_nothing_raised { a.foo! } + assert_equal a.foo, a.foo! + + assert_raises(KeyError) do + a.foo = nil + a.foo! + end + assert_raises(KeyError) { a.non_existing_key! } + end end |