summaryrefslogtreecommitdiffstats
path: root/test/integration/lib/redmine/menu_manager_test.rb
diff options
context:
space:
mode:
Diffstat (limited to 'test/integration/lib/redmine/menu_manager_test.rb')
-rw-r--r--test/integration/lib/redmine/menu_manager_test.rb26
1 files changed, 26 insertions, 0 deletions
diff --git a/test/integration/lib/redmine/menu_manager_test.rb b/test/integration/lib/redmine/menu_manager_test.rb
index 0b01f5d7f..eb81d9cf4 100644
--- a/test/integration/lib/redmine/menu_manager_test.rb
+++ b/test/integration/lib/redmine/menu_manager_test.rb
@@ -84,4 +84,30 @@ class MenuManagerTest < Redmine::IntegrationTest
get '/'
assert_select 'body.has-main-menu', 0
end
+
+ def test_cross_project_menu_should_hide_item_if_module_is_not_enabled_for_any_project
+ user = User.find_by_login('dlopper')
+ assert_equal [1, 3, 4, 6], Project.visible(user).ids
+
+ # gantt and news are not enabled for any visible project
+ Project.find(1).enabled_module_names = %w(issue_tracking calendar)
+ Project.find(3).enabled_module_names = %w(time_tracking)
+ EnabledModule.where(:project_id => [4, 6]).delete_all
+
+ log_user('dlopper', 'foo')
+ get '/projects'
+ assert_select '#main-menu' do
+ assert_select 'a.projects', :count => 1
+ assert_select 'a.activity', :count => 1
+
+ assert_select 'a.issues', :count => 1 # issue_tracking
+ assert_select 'a.time-entries', :count => 1 # time_tracking
+ assert_select 'a.gantt', :count => 0 # gantt
+ assert_select 'a.calendar', :count => 1 # calendar
+ assert_select 'a.news', :count => 0 # news
+ end
+ assert_select '#projects-index' do
+ assert_select 'a.project', :count => 4
+ end
+ end
end