annotate test/functional/queries_controller_test.rb @ 8:0c83d98252d9 yuya

* Add custom repo prefix and proper auth realm, remove auth cache (seems like an unwise feature), pass DB handle around, various other bits of tidying
author Chris Cannam
date Thu, 12 Aug 2010 15:31:37 +0100
parents 513646585e45
children af80e5618e9b
rev   line source
Chris@0 1 # redMine - project management software
Chris@0 2 # Copyright (C) 2006-2008 Jean-Philippe Lang
Chris@0 3 #
Chris@0 4 # This program is free software; you can redistribute it and/or
Chris@0 5 # modify it under the terms of the GNU General Public License
Chris@0 6 # as published by the Free Software Foundation; either version 2
Chris@0 7 # of the License, or (at your option) any later version.
Chris@0 8 #
Chris@0 9 # This program is distributed in the hope that it will be useful,
Chris@0 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
Chris@0 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Chris@0 12 # GNU General Public License for more details.
Chris@0 13 #
Chris@0 14 # You should have received a copy of the GNU General Public License
Chris@0 15 # along with this program; if not, write to the Free Software
Chris@0 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Chris@0 17
Chris@0 18 require File.dirname(__FILE__) + '/../test_helper'
Chris@0 19 require 'queries_controller'
Chris@0 20
Chris@0 21 # Re-raise errors caught by the controller.
Chris@0 22 class QueriesController; def rescue_action(e) raise e end; end
Chris@0 23
Chris@0 24 class QueriesControllerTest < ActionController::TestCase
Chris@0 25 fixtures :projects, :users, :members, :member_roles, :roles, :trackers, :issue_statuses, :issue_categories, :enumerations, :issues, :custom_fields, :custom_values, :queries
Chris@0 26
Chris@0 27 def setup
Chris@0 28 @controller = QueriesController.new
Chris@0 29 @request = ActionController::TestRequest.new
Chris@0 30 @response = ActionController::TestResponse.new
Chris@0 31 User.current = nil
Chris@0 32 end
Chris@0 33
Chris@0 34 def test_get_new_project_query
Chris@0 35 @request.session[:user_id] = 2
Chris@0 36 get :new, :project_id => 1
Chris@0 37 assert_response :success
Chris@0 38 assert_template 'new'
Chris@0 39 assert_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 40 :name => 'query[is_public]',
Chris@0 41 :checked => nil }
Chris@0 42 assert_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 43 :name => 'query_is_for_all',
Chris@0 44 :checked => nil,
Chris@0 45 :disabled => nil }
Chris@0 46 end
Chris@0 47
Chris@0 48 def test_get_new_global_query
Chris@0 49 @request.session[:user_id] = 2
Chris@0 50 get :new
Chris@0 51 assert_response :success
Chris@0 52 assert_template 'new'
Chris@0 53 assert_no_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 54 :name => 'query[is_public]' }
Chris@0 55 assert_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 56 :name => 'query_is_for_all',
Chris@0 57 :checked => 'checked',
Chris@0 58 :disabled => nil }
Chris@0 59 end
Chris@0 60
Chris@0 61 def test_new_project_public_query
Chris@0 62 @request.session[:user_id] = 2
Chris@0 63 post :new,
Chris@0 64 :project_id => 'ecookbook',
Chris@0 65 :confirm => '1',
Chris@0 66 :default_columns => '1',
Chris@0 67 :fields => ["status_id", "assigned_to_id"],
Chris@0 68 :operators => {"assigned_to_id" => "=", "status_id" => "o"},
Chris@0 69 :values => { "assigned_to_id" => ["1"], "status_id" => ["1"]},
Chris@0 70 :query => {"name" => "test_new_project_public_query", "is_public" => "1"}
Chris@0 71
Chris@0 72 q = Query.find_by_name('test_new_project_public_query')
Chris@0 73 assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook', :query_id => q
Chris@0 74 assert q.is_public?
Chris@0 75 assert q.has_default_columns?
Chris@0 76 assert q.valid?
Chris@0 77 end
Chris@0 78
Chris@0 79 def test_new_project_private_query
Chris@0 80 @request.session[:user_id] = 3
Chris@0 81 post :new,
Chris@0 82 :project_id => 'ecookbook',
Chris@0 83 :confirm => '1',
Chris@0 84 :default_columns => '1',
Chris@0 85 :fields => ["status_id", "assigned_to_id"],
Chris@0 86 :operators => {"assigned_to_id" => "=", "status_id" => "o"},
Chris@0 87 :values => { "assigned_to_id" => ["1"], "status_id" => ["1"]},
Chris@0 88 :query => {"name" => "test_new_project_private_query", "is_public" => "1"}
Chris@0 89
Chris@0 90 q = Query.find_by_name('test_new_project_private_query')
Chris@0 91 assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook', :query_id => q
Chris@0 92 assert !q.is_public?
Chris@0 93 assert q.has_default_columns?
Chris@0 94 assert q.valid?
Chris@0 95 end
Chris@0 96
Chris@0 97 def test_new_global_private_query_with_custom_columns
Chris@0 98 @request.session[:user_id] = 3
Chris@0 99 post :new,
Chris@0 100 :confirm => '1',
Chris@0 101 :fields => ["status_id", "assigned_to_id"],
Chris@0 102 :operators => {"assigned_to_id" => "=", "status_id" => "o"},
Chris@0 103 :values => { "assigned_to_id" => ["me"], "status_id" => ["1"]},
Chris@0 104 :query => {"name" => "test_new_global_private_query", "is_public" => "1", "column_names" => ["", "tracker", "subject", "priority", "category"]}
Chris@0 105
Chris@0 106 q = Query.find_by_name('test_new_global_private_query')
Chris@0 107 assert_redirected_to :controller => 'issues', :action => 'index', :project_id => nil, :query_id => q
Chris@0 108 assert !q.is_public?
Chris@0 109 assert !q.has_default_columns?
Chris@0 110 assert_equal [:tracker, :subject, :priority, :category], q.columns.collect {|c| c.name}
Chris@0 111 assert q.valid?
Chris@0 112 end
Chris@0 113
Chris@0 114 def test_new_with_sort
Chris@0 115 @request.session[:user_id] = 1
Chris@0 116 post :new,
Chris@0 117 :confirm => '1',
Chris@0 118 :default_columns => '1',
Chris@0 119 :operators => {"status_id" => "o"},
Chris@0 120 :values => {"status_id" => ["1"]},
Chris@0 121 :query => {:name => "test_new_with_sort",
Chris@0 122 :is_public => "1",
Chris@0 123 :sort_criteria => {"0" => ["due_date", "desc"], "1" => ["tracker", ""]}}
Chris@0 124
Chris@0 125 query = Query.find_by_name("test_new_with_sort")
Chris@0 126 assert_not_nil query
Chris@0 127 assert_equal [['due_date', 'desc'], ['tracker', 'asc']], query.sort_criteria
Chris@0 128 end
Chris@0 129
Chris@0 130 def test_get_edit_global_public_query
Chris@0 131 @request.session[:user_id] = 1
Chris@0 132 get :edit, :id => 4
Chris@0 133 assert_response :success
Chris@0 134 assert_template 'edit'
Chris@0 135 assert_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 136 :name => 'query[is_public]',
Chris@0 137 :checked => 'checked' }
Chris@0 138 assert_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 139 :name => 'query_is_for_all',
Chris@0 140 :checked => 'checked',
Chris@0 141 :disabled => 'disabled' }
Chris@0 142 end
Chris@0 143
Chris@0 144 def test_edit_global_public_query
Chris@0 145 @request.session[:user_id] = 1
Chris@0 146 post :edit,
Chris@0 147 :id => 4,
Chris@0 148 :confirm => '1',
Chris@0 149 :default_columns => '1',
Chris@0 150 :fields => ["status_id", "assigned_to_id"],
Chris@0 151 :operators => {"assigned_to_id" => "=", "status_id" => "o"},
Chris@0 152 :values => { "assigned_to_id" => ["1"], "status_id" => ["1"]},
Chris@0 153 :query => {"name" => "test_edit_global_public_query", "is_public" => "1"}
Chris@0 154
Chris@0 155 assert_redirected_to :controller => 'issues', :action => 'index', :query_id => 4
Chris@0 156 q = Query.find_by_name('test_edit_global_public_query')
Chris@0 157 assert q.is_public?
Chris@0 158 assert q.has_default_columns?
Chris@0 159 assert q.valid?
Chris@0 160 end
Chris@0 161
Chris@0 162 def test_get_edit_global_private_query
Chris@0 163 @request.session[:user_id] = 3
Chris@0 164 get :edit, :id => 3
Chris@0 165 assert_response :success
Chris@0 166 assert_template 'edit'
Chris@0 167 assert_no_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 168 :name => 'query[is_public]' }
Chris@0 169 assert_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 170 :name => 'query_is_for_all',
Chris@0 171 :checked => 'checked',
Chris@0 172 :disabled => 'disabled' }
Chris@0 173 end
Chris@0 174
Chris@0 175 def test_edit_global_private_query
Chris@0 176 @request.session[:user_id] = 3
Chris@0 177 post :edit,
Chris@0 178 :id => 3,
Chris@0 179 :confirm => '1',
Chris@0 180 :default_columns => '1',
Chris@0 181 :fields => ["status_id", "assigned_to_id"],
Chris@0 182 :operators => {"assigned_to_id" => "=", "status_id" => "o"},
Chris@0 183 :values => { "assigned_to_id" => ["me"], "status_id" => ["1"]},
Chris@0 184 :query => {"name" => "test_edit_global_private_query", "is_public" => "1"}
Chris@0 185
Chris@0 186 assert_redirected_to :controller => 'issues', :action => 'index', :query_id => 3
Chris@0 187 q = Query.find_by_name('test_edit_global_private_query')
Chris@0 188 assert !q.is_public?
Chris@0 189 assert q.has_default_columns?
Chris@0 190 assert q.valid?
Chris@0 191 end
Chris@0 192
Chris@0 193 def test_get_edit_project_private_query
Chris@0 194 @request.session[:user_id] = 3
Chris@0 195 get :edit, :id => 2
Chris@0 196 assert_response :success
Chris@0 197 assert_template 'edit'
Chris@0 198 assert_no_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 199 :name => 'query[is_public]' }
Chris@0 200 assert_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 201 :name => 'query_is_for_all',
Chris@0 202 :checked => nil,
Chris@0 203 :disabled => nil }
Chris@0 204 end
Chris@0 205
Chris@0 206 def test_get_edit_project_public_query
Chris@0 207 @request.session[:user_id] = 2
Chris@0 208 get :edit, :id => 1
Chris@0 209 assert_response :success
Chris@0 210 assert_template 'edit'
Chris@0 211 assert_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 212 :name => 'query[is_public]',
Chris@0 213 :checked => 'checked'
Chris@0 214 }
Chris@0 215 assert_tag :tag => 'input', :attributes => { :type => 'checkbox',
Chris@0 216 :name => 'query_is_for_all',
Chris@0 217 :checked => nil,
Chris@0 218 :disabled => 'disabled' }
Chris@0 219 end
Chris@0 220
Chris@0 221 def test_get_edit_sort_criteria
Chris@0 222 @request.session[:user_id] = 1
Chris@0 223 get :edit, :id => 5
Chris@0 224 assert_response :success
Chris@0 225 assert_template 'edit'
Chris@0 226 assert_tag :tag => 'select', :attributes => { :name => 'query[sort_criteria][0][]' },
Chris@0 227 :child => { :tag => 'option', :attributes => { :value => 'priority',
Chris@0 228 :selected => 'selected' } }
Chris@0 229 assert_tag :tag => 'select', :attributes => { :name => 'query[sort_criteria][0][]' },
Chris@0 230 :child => { :tag => 'option', :attributes => { :value => 'desc',
Chris@0 231 :selected => 'selected' } }
Chris@0 232 end
Chris@0 233
Chris@0 234 def test_destroy
Chris@0 235 @request.session[:user_id] = 2
Chris@0 236 post :destroy, :id => 1
Chris@0 237 assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook', :set_filter => 1, :query_id => nil
Chris@0 238 assert_nil Query.find_by_id(1)
Chris@0 239 end
Chris@0 240 end