diff options
author | Go MAEDA <maeda@farend.jp> | 2021-07-06 06:01:50 +0000 |
---|---|---|
committer | Go MAEDA <maeda@farend.jp> | 2021-07-06 06:01:50 +0000 |
commit | 7f965286ed6b1d7e906e8662daba0d49b1cf7666 (patch) | |
tree | aea4a14340b1e4ec29743bddf2cdef5f9b643206 /test/functional | |
parent | 1b0bf2880374307e9669cfd4ed32cfe6677a3503 (diff) | |
download | redmine-7f965286ed6b1d7e906e8662daba0d49b1cf7666.tar.gz redmine-7f965286ed6b1d7e906e8662daba0d49b1cf7666.zip |
Default issue query (#7360).
Patch by Katsuya HIDAKA (the author of https://github.com/hidakatsuya/redmine_default_custom_query), Takenori TAKAKI, Olivier Chabert, and Jens Krämer.
git-svn-id: http://svn.redmine.org/redmine/trunk@21061 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test/functional')
-rw-r--r-- | test/functional/issues_controller_test.rb | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/test/functional/issues_controller_test.rb b/test/functional/issues_controller_test.rb index ccebb4311..87a6ec704 100644 --- a/test/functional/issues_controller_test.rb +++ b/test/functional/issues_controller_test.rb @@ -8225,4 +8225,76 @@ class IssuesControllerTest < Redmine::ControllerTest end end end + + def test_index_should_retrieve_default_query + query = IssueQuery.find(4) + IssueQuery.stubs(:default).returns query + + [nil, 1].each do |user_id| + @request.session[:user_id] = user_id + get :index + assert_select 'h2', text: query.name + + get :index, params: { project_id: 1 } + assert_select 'h2', text: query.name + end + end + + def test_index_should_ignore_default_query_with_without_default + query = IssueQuery.find(4) + IssueQuery.stubs(:default).returns query + + [nil, 1].each do |user_id| + @request.session[:user_id] = user_id + get :index, params: { set_filter: '1', without_default: '1' } + assert_select 'h2', text: I18n.t(:label_issue_plural) + + get :index, params: { project_id: 1, set_filter: '1', without_default: '1' } + assert_select 'h2', text: I18n.t(:label_issue_plural) + end + end + + def test_index_should_ignore_default_query_with_session_query + query = IssueQuery.find 4 + IssueQuery.stubs(:default).returns query + session_query = IssueQuery.find 1 + + @request.session[:issue_query] = { id: 1, project_id: 1} + @request.session[:user_id] = 1 + get :index, params: { project_id: '1' } + assert_select 'h2', text: session_query.name + end + + def test_index_global_should_ignore_default_query_with_session_query + query = IssueQuery.find 4 + IssueQuery.stubs(:default).returns query + session_query = IssueQuery.find 5 + + @request.session[:issue_query] = { id: 5, project_id: nil} + @request.session[:user_id] = 1 + get :index + assert_select 'h2', text: session_query.name + end + + def test_index_should_use_default_query_with_invalid_session_query + query = IssueQuery.find 4 + IssueQuery.stubs(:default).returns query + + @request.session[:issue_query] = { id: 1, project_id: 1} + @request.session[:user_id] = 1 + get :index + assert_select 'h2', text: query.name + end + + def test_index_should_not_load_default_query_for_api_request + query = IssueQuery.find 4 + IssueQuery.stubs(:default).returns query + + @request.session[:user_id] = 1 + get :index, params: { format: 'json' } + + assert results = JSON.parse(@response.body)['issues'] + # query filters for tracker_id == 3 + assert results.detect{ |i| i['tracker_id'] != 3 } + end end |