summaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2013-01-05 16:09:15 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2013-01-05 16:09:15 +0000
commit3e14c3017c037d93e562c3697cf50224dced7b50 (patch)
treed62163eba0051d645d1c7b17e55c434f05a737da /app
parent6ed7e091dfc833830ccd0e689714913c81ef6d22 (diff)
downloadredmine-3e14c3017c037d93e562c3697cf50224dced7b50.tar.gz
redmine-3e14c3017c037d93e562c3697cf50224dced7b50.zip
Adds a custom validator for dates (#12736).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@11124 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app')
-rw-r--r--app/models/issue.rb10
-rw-r--r--app/models/version.rb9
2 files changed, 3 insertions, 16 deletions
diff --git a/app/models/issue.rb b/app/models/issue.rb
index 2d9228b1d..8a0ef7fa8 100644
--- a/app/models/issue.rb
+++ b/app/models/issue.rb
@@ -68,6 +68,8 @@ class Issue < ActiveRecord::Base
validates_length_of :subject, :maximum => 255
validates_inclusion_of :done_ratio, :in => 0..100
validates_numericality_of :estimated_hours, :allow_nil => true
+ validates :start_date, :date => true
+ validates :due_date, :date => true
validate :validate_issue, :validate_required_fields
scope :visible, lambda {|*args|
@@ -532,14 +534,6 @@ class Issue < ActiveRecord::Base
end
def validate_issue
- if due_date.nil? && @attributes['due_date'].present?
- errors.add :due_date, :not_a_date
- end
-
- if start_date.nil? && @attributes['start_date'].present?
- errors.add :start_date, :not_a_date
- end
-
if due_date && start_date && due_date < start_date
errors.add :due_date, :greater_than_start_date
end
diff --git a/app/models/version.rb b/app/models/version.rb
index 50225f362..e7651ad23 100644
--- a/app/models/version.rb
+++ b/app/models/version.rb
@@ -30,10 +30,9 @@ class Version < ActiveRecord::Base
validates_presence_of :name
validates_uniqueness_of :name, :scope => [:project_id]
validates_length_of :name, :maximum => 60
- validates_format_of :effective_date, :with => /\A\d{4}-\d{2}-\d{2}\z/, :message => :not_a_date, :allow_nil => true
+ validates :effective_date, :date => true
validates_inclusion_of :status, :in => VERSION_STATUSES
validates_inclusion_of :sharing, :in => VERSION_SHARINGS
- validate :validate_version
scope :named, lambda {|arg| where("LOWER(#{table_name}.name) = LOWER(?)", arg.to_s.strip)}
scope :open, lambda { where(:status => 'open') }
@@ -287,10 +286,4 @@ class Version < ActiveRecord::Base
progress
end
end
-
- def validate_version
- if effective_date.nil? && @attributes['effective_date'].present?
- errors.add :effective_date, :not_a_date
- end
- end
end