summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/models/issue.rb5
-rw-r--r--app/models/version.rb4
-rw-r--r--test/unit/issue_test.rb10
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')