summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorGo MAEDA <maeda@farend.jp>2022-08-02 08:09:50 +0000
committerGo MAEDA <maeda@farend.jp>2022-08-02 08:09:50 +0000
commitdd1e8c6c39c6cc109694d8609a8318e51becefc6 (patch)
tree10a6b945f2f96d566a6343b3976b6a1e2703db55 /test
parent117553bb4902a1123a94214e9021884cfbf4e555 (diff)
downloadredmine-dd1e8c6c39c6cc109694d8609a8318e51becefc6.tar.gz
redmine-dd1e8c6c39c6cc109694d8609a8318e51becefc6.zip
Merged r21748 from trunk to 5.0-stable (#37499).
git-svn-id: https://svn.redmine.org/redmine/branches/5.0-stable@21753 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test')
-rw-r--r--test/functional/issues_controller_test.rb51
-rw-r--r--test/functional/projects_controller_test.rb33
-rw-r--r--test/unit/project_query_test.rb1
-rw-r--r--test/unit/query_test.rb1
4 files changed, 86 insertions, 0 deletions
diff --git a/test/functional/issues_controller_test.rb b/test/functional/issues_controller_test.rb
index 60d1ff638..fa1b6ebd0 100644
--- a/test/functional/issues_controller_test.rb
+++ b/test/functional/issues_controller_test.rb
@@ -8472,4 +8472,55 @@ class IssuesControllerTest < Redmine::ControllerTest
# query filters for tracker_id == 3
assert results.detect{ |i| i['tracker_id'] != 3 }
end
+
+ def test_index_should_ignore_user_default_query_if_it_is_invisible
+ query = IssueQuery.find(4)
+
+ query.update(visibility: Query::VISIBILITY_PRIVATE, user_id: 2)
+ query.save!
+
+ # If visible default query
+ @request.session[:user_id] = 2
+ @request.session[:issue_query] = nil
+ User.find(2).pref.update(default_issue_query: query.id)
+ get :index
+ assert_select 'h2', text: query.name
+
+ # If invisible default query
+ @request.session[:user_id] = 3
+ @request.session[:issue_query] = nil
+ User.find(3).pref.update(default_issue_query: query.id)
+ get :index
+ assert_select 'h2', text: 'Issues'
+ end
+
+ def test_index_should_ignore_project_default_query_if_it_is_not_public
+ query = IssueQuery.find(1)
+ query.project.update(default_issue_query: query)
+
+ query.update(visibility: Query::VISIBILITY_PRIVATE, user_id: 2)
+ query.save!
+
+ [User.find(1), User.find(2)].each do |user|
+ @request.session[:user_id] = user.id
+ @request.session[:issue_query] = nil
+ get :index, params: { project_id: query.project.id }
+ assert_select 'h2', text: 'Issues'
+ end
+ end
+
+ def test_index_should_ignore_global_default_query_if_it_is_not_public
+ query = IssueQuery.find(1)
+ with_settings default_issue_query: query.id do
+ query.update(visibility: Query::VISIBILITY_PRIVATE, user_id: 2)
+ query.save!
+
+ [User.find(1), User.find(2)].each do |user|
+ @request.session[:user_id] = user.id
+ @request.session[:issue_query] = nil
+ get :index
+ assert_select 'h2', text: 'Issues'
+ end
+ end
+ end
end
diff --git a/test/functional/projects_controller_test.rb b/test/functional/projects_controller_test.rb
index 837de343a..edd9af700 100644
--- a/test/functional/projects_controller_test.rb
+++ b/test/functional/projects_controller_test.rb
@@ -273,6 +273,39 @@ class ProjectsControllerTest < Redmine::ControllerTest
end
end
+ def test_index_should_ignore_user_default_query_if_it_is_invisible
+ query = ProjectQuery.find(11)
+
+ query.update(visibility: Query::VISIBILITY_PRIVATE, user_id: 2)
+ query.save!
+
+ # If visible default query
+ @request.session[:user_id] = 2
+ User.find(2).pref.update(default_project_query: query.id)
+ get :index
+ assert_select 'h2', text: query.name
+
+ # If invisible default query
+ @request.session[:user_id] = 3
+ User.find(3).pref.update(default_project_query: query.id)
+ get :index
+ assert_select 'h2', text: I18n.t(:label_project_plural)
+ end
+
+ def test_index_should_ignore_global_default_query_if_it_is_not_public
+ query = ProjectQuery.find(11)
+ with_settings default_project_query: query.id do
+ query.update(visibility: Query::VISIBILITY_PRIVATE, user_id: 2)
+ query.save!
+
+ [User.find(1), User.find(2)].each do |user|
+ @request.session[:user_id] = user.id
+ get :index
+ assert_select 'h2', text: I18n.t(:label_project_plural)
+ end
+ end
+ end
+
def test_autocomplete_js
get(
:autocomplete,
diff --git a/test/unit/project_query_test.rb b/test/unit/project_query_test.rb
index 8166e8363..a3ff930f1 100644
--- a/test/unit/project_query_test.rb
+++ b/test/unit/project_query_test.rb
@@ -75,6 +75,7 @@ class ProjectQueryTest < ActiveSupport::TestCase
user = User.find(1)
query = ProjectQuery.find(11)
user_query = ProjectQuery.find(12)
+ user_query.update(visibility: Query::VISIBILITY_PUBLIC)
[nil, user, User.anonymous].each do |u|
assert_nil IssueQuery.default(user: u)
diff --git a/test/unit/query_test.rb b/test/unit/query_test.rb
index bb097f88a..4d6650ee8 100644
--- a/test/unit/query_test.rb
+++ b/test/unit/query_test.rb
@@ -2814,6 +2814,7 @@ class QueryTest < ActiveSupport::TestCase
project_query = IssueQuery.find(1)
query = IssueQuery.find(4)
user_query = IssueQuery.find(3)
+ user_query.update(visibility: Query::VISIBILITY_PUBLIC)
user_query.update_column :user_id, user.id
[nil, user, User.anonymous].each do |u|