diff options
-rw-r--r-- | app/models/issue.rb | 5 | ||||
-rw-r--r-- | app/models/version.rb | 4 | ||||
-rw-r--r-- | test/unit/issue_test.rb | 10 |
3 files changed, 16 insertions, 3 deletions
diff --git a/app/models/issue.rb b/app/models/issue.rb index be69d929f..199efe119 100644 --- a/app/models/issue.rb +++ b/app/models/issue.rb @@ -63,7 +63,10 @@ class Issue < ActiveRecord::Base named_scope :visible, lambda {|*args| { :include => :project, :conditions => Issue.visible_condition(args.shift || User.current, *args) } } - named_scope :open, :conditions => ["#{IssueStatus.table_name}.is_closed = ?", false], :include => :status + named_scope :open, lambda {|*args| + is_closed = args.size > 0 ? !args.first : false + {:conditions => ["#{IssueStatus.table_name}.is_closed = ?", is_closed], :include => :status} + } named_scope :recently_updated, :order => "#{Issue.table_name}.updated_on DESC" named_scope :with_limit, lambda { |limit| { :limit => limit} } diff --git a/app/models/version.rb b/app/models/version.rb index 3340be77e..8002ac9c8 100644 --- a/app/models/version.rb +++ b/app/models/version.rb @@ -124,12 +124,12 @@ class Version < ActiveRecord::Base # Returns the total amount of open issues for this version. def open_issues_count - @open_issues_count ||= Issue.count(:all, :conditions => ["fixed_version_id = ? AND is_closed = ?", self.id, false], :include => :status) + @open_issues_count ||= Issue.open.count(:all, :conditions => ["fixed_version_id = ?", self.id]) end # Returns the total amount of closed issues for this version. def closed_issues_count - @closed_issues_count ||= Issue.count(:all, :conditions => ["fixed_version_id = ? AND is_closed = ?", self.id, true], :include => :status) + @closed_issues_count ||= Issue.open(false).count(:all, :conditions => ["fixed_version_id = ?", self.id]) end def wiki_page diff --git a/test/unit/issue_test.rb b/test/unit/issue_test.rb index e23b52d11..a08ec3f87 100644 --- a/test/unit/issue_test.rb +++ b/test/unit/issue_test.rb @@ -219,6 +219,16 @@ class IssueTest < ActiveSupport::TestCase assert_equal 0, Issue.find(1).descendants.visible.all.size end + def test_open_scope + issues = Issue.open.all + assert_nil issues.detect(&:closed?) + end + + def test_open_scope_with_arg + issues = Issue.open(false).all + assert_equal issues, issues.select(&:closed?) + end + def test_errors_full_messages_should_include_custom_fields_errors field = IssueCustomField.find_by_name('Database') |