aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord
diff options
context:
space:
mode:
Diffstat (limited to 'activerecord')
-rw-r--r--activerecord/CHANGELOG16
-rwxr-xr-xactiverecord/lib/active_record/validations.rb23
-rwxr-xr-xactiverecord/test/validations_test.rb21
3 files changed, 51 insertions, 9 deletions
diff --git a/activerecord/CHANGELOG b/activerecord/CHANGELOG
index 7c12ad482e..6299d386f4 100644
--- a/activerecord/CHANGELOG
+++ b/activerecord/CHANGELOG
@@ -17,6 +17,22 @@
NOTE: This validation is only happening on create. When you want to update the record, you'll have to decide and pursue your
own course of action.
+
+* Added Base.validate_confirmation that encapsulates the pattern of wanting to validate the acceptance of a terms of service check box (or similar agreement). Example:
+
+ Model:
+ class Person < ActiveRecord::Base
+ validate_acceptance :terms_of_service
+ end
+
+ View:
+ <%= check_box "person", "terms_of_service" %>
+
+ The terms_of_service attribute is entirely virtual. It's only used for validation at the time of creation. No database column is needed.
+
+ NOTE: The agreement is considered valid if it's set to the string "1". This makes it easy to relate it to an HTML checkbox.
+
+
* Added validation macros to make the stackable just like the lifecycle callbacks. Examples:
class Person < ActiveRecord::Base
diff --git a/activerecord/lib/active_record/validations.rb b/activerecord/lib/active_record/validations.rb
index 705cad20df..71cbb5a6e5 100755
--- a/activerecord/lib/active_record/validations.rb
+++ b/activerecord/lib/active_record/validations.rb
@@ -80,6 +80,29 @@ module ActiveRecord
EOM
end
end
+
+
+ # Encapsulates the pattern of wanting to validate the acceptance of a terms of service check box (or similar agreement). Example:
+ #
+ # Model:
+ # class Person < ActiveRecord::Base
+ # validate_acceptance :terms_of_service
+ # end
+ #
+ # View:
+ # <%= check_box "person", "terms_of_service" %>
+ #
+ # The terms_of_service attribute is entirely virtual. It's only used for validation at the time of creation. No database column is needed.
+ #
+ # NOTE: The agreement is considered valid if it's set to the string "1". This makes it easy to relate it to an HTML checkbox.
+ def validate_acceptance(*attr_names)
+ for attr_name in attr_names
+ attr_accessor(attr_name)
+ class_eval <<-EOM
+ validate_on_create %{errors.add('#{attr_name}', "must be accepted") unless #{attr_name} == "1"}
+EOM
+ end
+ end
end
# The validation process on save can be skipped by passing false. The regular Base#save method is
diff --git a/activerecord/test/validations_test.rb b/activerecord/test/validations_test.rb
index a6cdc0a706..c396d30630 100755
--- a/activerecord/test/validations_test.rb
+++ b/activerecord/test/validations_test.rb
@@ -120,25 +120,28 @@ class ValidationsTest < Test::Unit::TestCase
developer.name = "Just right"
assert developer.save
end
-end
+ def test_title_confirmation
+ Topic.validate_confirmation(:title)
-class MacroValidationsTest < Test::Unit::TestCase
- fixtures :topics, :developers
+ t = Topic.create("title" => "We should be confirmed")
+ assert !t.save
- def setup
- Topic.validate_confirmation(:title)
- end
+ t.title_confirmation = "We should be confirmed"
+ assert t.save
- def teardown
Topic.write_inheritable_attribute("validate_on_create", [])
end
- def test_title_confirmation
+ def test_terms_of_service_agreement
+ Topic.validate_acceptance(:terms_of_service)
+
t = Topic.create("title" => "We should be confirmed")
assert !t.save
- t.title_confirmation = "We should be confirmed"
+ t.terms_of_service = "1"
assert t.save
+
+ Topic.write_inheritable_attribute("validate_on_create", [])
end
end \ No newline at end of file