diff options
author | Juanjo Bazan <jjbazan@gmail.com> | 2010-03-30 23:39:00 +0200 |
---|---|---|
committer | Xavier Noria <fxn@hashref.com> | 2010-03-30 15:25:38 -0700 |
commit | 589deb39c79cac40eec40d4ee3d86fac16c1f31f (patch) | |
tree | 112aca950139cc39ac213cb0a8ee16c8d042395b | |
parent | 7212c29802e34fe7368d5b484a479c31fad49c5d (diff) | |
download | rails-589deb39c79cac40eec40d4ee3d86fac16c1f31f.tar.gz rails-589deb39c79cac40eec40d4ee3d86fac16c1f31f.tar.bz2 rails-589deb39c79cac40eec40d4ee3d86fac16c1f31f.zip |
New assertion: assert_present [#4299 state:committed]
Signed-off-by: Xavier Noria <fxn@hashref.com>
-rw-r--r-- | activesupport/lib/active_support/testing/assertions.rb | 7 | ||||
-rw-r--r-- | activesupport/test/test_test.rb | 22 |
2 files changed, 28 insertions, 1 deletions
diff --git a/activesupport/lib/active_support/testing/assertions.rb b/activesupport/lib/active_support/testing/assertions.rb index 30a22fcc0e..e01aa80877 100644 --- a/activesupport/lib/active_support/testing/assertions.rb +++ b/activesupport/lib/active_support/testing/assertions.rb @@ -69,6 +69,13 @@ module ActiveSupport def assert_blank(object) assert object.blank?, "#{object.inspect} is not blank" end + + # Test if an expression is not blank. Passes if object.present? is true. + # + # assert_present {:data => 'x' } # => true + def assert_present(object) + assert object.present?, "#{object.inspect} is blank" + end end end end diff --git a/activesupport/test/test_test.rb b/activesupport/test/test_test.rb index 390670570d..f9482c8e90 100644 --- a/activesupport/test/test_test.rb +++ b/activesupport/test/test_test.rb @@ -96,7 +96,7 @@ end class AssertBlankTest < ActiveSupport::TestCase BLANK = [ EmptyTrue.new, nil, false, '', ' ', " \n\t \r ", [], {} ] - NOT_BLANK = [ EmptyFalse.new, Object.new, true, 0, 1, 'j', [nil], { nil => 0 } ] + NOT_BLANK = [ EmptyFalse.new, Object.new, true, 0, 1, 'x', [nil], { nil => 0 } ] def test_assert_blank_true BLANK.each { |v| assert_blank v } @@ -114,6 +114,26 @@ class AssertBlankTest < ActiveSupport::TestCase end end +class AssertPresentTest < ActiveSupport::TestCase + BLANK = [ EmptyTrue.new, nil, false, '', ' ', " \n\t \r ", [], {} ] + NOT_BLANK = [ EmptyFalse.new, Object.new, true, 0, 1, 'x', [nil], { nil => 0 } ] + + def test_assert_blank_true + NOT_BLANK.each { |v| assert_present v } + end + + def test_assert_blank_false + BLANK.each { |v| + begin + assert_present v + fail 'should not get to here' + rescue Exception => e + assert_match(/is blank/, e.message) + end + } + end +end + # These should always pass if ActiveSupport::Testing.const_defined?(:Default) class NotTestingThingsTest < Test::Unit::TestCase |