From 93366c7c913bf0883f140fa782d3e198593477be Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafael=20Mendon=C3=A7a=20Fran=C3=A7a?= Date: Wed, 26 Dec 2012 19:05:03 -0300 Subject: Fix `validates_presence_of` with `:allow_nil` or `:allow_blank` options. MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Fix #8621 [Colin Kelley + Rafael Mendonça França] --- .../cases/validations/presence_validation_test.rb | 34 ++++++++++++++++++++++ 1 file changed, 34 insertions(+) (limited to 'activemodel/test/cases/validations/presence_validation_test.rb') diff --git a/activemodel/test/cases/validations/presence_validation_test.rb b/activemodel/test/cases/validations/presence_validation_test.rb index 510c13a7c3..fbb008f9ff 100644 --- a/activemodel/test/cases/validations/presence_validation_test.rb +++ b/activemodel/test/cases/validations/presence_validation_test.rb @@ -70,4 +70,38 @@ class PresenceValidationTest < ActiveModel::TestCase p[:karma] = "Cold" assert p.valid? end + + def test_validates_presence_of_with_allow_nil_option + Topic.validates_presence_of(:title, :allow_nil => true) + + t = Topic.new(:title => "something") + assert t.valid? + + t.title = "" + assert t.invalid? + assert_equal ["can't be blank"], t.errors[:title] + + t.title = " " + assert t.invalid? + assert_equal ["can't be blank"], t.errors[:title] + + t.title = nil + assert t.valid? + end + + def test_validates_presence_of_with_allow_blank_option + Topic.validates_presence_of(:title, :allow_blank => true) + + t = Topic.new(:title => "something") + assert t.valid? + + t.title = "" + assert t.valid? + + t.title = " " + assert t.valid? + + t.title = nil + assert t.valid? + end end -- cgit v1.2.3