diff options
author | Etienne Massip <etienne.massip@gmail.com> | 2011-10-05 22:03:19 +0000 |
---|---|---|
committer | Etienne Massip <etienne.massip@gmail.com> | 2011-10-05 22:03:19 +0000 |
commit | a84f877099e74b7377433e9a45877893942220fd (patch) | |
tree | ce2a6486e5936d88ff55a062b729c27c90a40766 /test/integration/api_test | |
parent | 1de0714fdac868276bfc0374ad86b214b18f91bb (diff) | |
download | redmine-a84f877099e74b7377433e9a45877893942220fd.tar.gz redmine-a84f877099e74b7377433e9a45877893942220fd.zip |
Added 2 tests about passing custom field filter to /issues.xml
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@7581 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test/integration/api_test')
-rw-r--r-- | test/integration/api_test/issues_test.rb | 37 |
1 files changed, 34 insertions, 3 deletions
diff --git a/test/integration/api_test/issues_test.rb b/test/integration/api_test/issues_test.rb index d755959d2..3a9c333bf 100644 --- a/test/integration/api_test/issues_test.rb +++ b/test/integration/api_test/issues_test.rb @@ -130,6 +130,34 @@ class ApiTest::IssuesTest < ActionController::IntegrationTest assert_tag 'errors', :child => {:tag => 'error', :content => "Start date can't be blank"} end end + + context "with custom field filter" do + should "show only issues with the custom field value" do + get '/issues.xml', { :set_filter => 1, :f => ['cf_1'], :op => {:cf_1 => '='}, :v => {:cf_1 => ['MySQL']}} + + expected_ids = Issue.visible.all( + :include => :custom_values, + :conditions => {:custom_values => {:custom_field_id => 1, :value => 'MySQL'}}).map(&:id) + + assert_select 'issues > issue > id', :count => expected_ids.count do |ids| + ids.each { |id| assert expected_ids.delete(id.children.first.content.to_i) } + end + end + end + + context "with custom field filter (shorthand method)" do + should "show only issues with the custom field value" do + get '/issues.xml', { :cf_1 => 'MySQL' } + + expected_ids = Issue.visible.all( + :include => :custom_values, + :conditions => {:custom_values => {:custom_field_id => 1, :value => 'MySQL'}}).map(&:id) + + assert_select 'issues > issue > id', :count => expected_ids.count do |ids| + ids.each { |id| assert expected_ids.delete(id.children.first.content.to_i) } + end + end + end end context "/index.json" do @@ -139,9 +167,12 @@ class ApiTest::IssuesTest < ActionController::IntegrationTest context "/index.xml with filter" do should "show only issues with the status_id" do get '/issues.xml?status_id=5' - assert_tag :tag => 'issues', - :children => { :count => Issue.visible.count(:conditions => {:status_id => 5}), - :only => { :tag => 'issue' } } + + expected_ids = Issue.visible.all(:conditions => {:status_id => 5}).map(&:id) + + assert_select 'issues > issue > id', :count => expected_ids.count do |ids| + ids.each { |id| assert expected_ids.delete(id.children.first.content.to_i) } + end end end |