diff options
author | Eric Davis <edavis@littlestreamsoftware.com> | 2009-11-25 05:36:50 +0000 |
---|---|---|
committer | Eric Davis <edavis@littlestreamsoftware.com> | 2009-11-25 05:36:50 +0000 |
commit | b0999e3764f0554d40d243f273f23fe53e164066 (patch) | |
tree | 6ad211b83516bf9db17d7bf84af8794875a760e9 /test | |
parent | 1f06cf889990d9640f7160c4969ed074fb68a7ca (diff) | |
download | redmine-b0999e3764f0554d40d243f273f23fe53e164066.tar.gz redmine-b0999e3764f0554d40d243f273f23fe53e164066.zip |
Add support for unattached menus (generated dynamically)
A MenuItem can define a :child_menus option with a Proc. When the menus
are rendered, the Proc will be run and the resulting MenuItems will be
added to the page as child menus
#4250
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@3091 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test')
-rw-r--r-- | test/unit/lib/redmine/menu_manager/menu_helper_test.rb | 101 | ||||
-rw-r--r-- | test/unit/lib/redmine/menu_manager/menu_item_test.rb | 14 | ||||
-rw-r--r-- | test/unit/lib/redmine/menu_manager_test.rb | 4 |
3 files changed, 119 insertions, 0 deletions
diff --git a/test/unit/lib/redmine/menu_manager/menu_helper_test.rb b/test/unit/lib/redmine/menu_manager/menu_helper_test.rb index 6f259f425..2d4778cbe 100644 --- a/test/unit/lib/redmine/menu_manager/menu_helper_test.rb +++ b/test/unit/lib/redmine/menu_manager/menu_helper_test.rb @@ -101,6 +101,107 @@ class Redmine::MenuManager::MenuHelperTest < HelperTestCase end + def test_render_menu_node_with_child_menus + User.current = User.find(2) + + parent_node = Redmine::MenuManager::MenuItem.new(:parent_node, + '/test', + { + :child_menus => Proc.new {|p| + child_menus = [] + 3.times do |time| + child_menus << Redmine::MenuManager::MenuItem.new("test_child_#{time}", + {:controller => 'issues', :action => 'index'}, + {}) + end + child_menus + } + }) + @response.body = render_menu_node(parent_node, Project.find(1)) + + assert_select("li") do + assert_select("a.parent-node", "Parent node") + assert_select("ul") do + assert_select("li a.test-child-0", "Test child 0") + assert_select("li a.test-child-1", "Test child 1") + assert_select("li a.test-child-2", "Test child 2") + end + end + end + + def test_render_menu_node_with_nested_items_and_child_menus + User.current = User.find(2) + + parent_node = Redmine::MenuManager::MenuItem.new(:parent_node, + '/test', + { + :child_menus => Proc.new {|p| + child_menus = [] + 3.times do |time| + child_menus << Redmine::MenuManager::MenuItem.new("test_child_#{time}", {:controller => 'issues', :action => 'index'}, {}) + end + child_menus + } + }) + + parent_node << Redmine::MenuManager::MenuItem.new(:child_node, + '/test', + { + :child_menus => Proc.new {|p| + child_menus = [] + 6.times do |time| + child_menus << Redmine::MenuManager::MenuItem.new("test_dynamic_child_#{time}", {:controller => 'issues', :action => 'index'}, {}) + end + child_menus + } + }) + + @response.body = render_menu_node(parent_node, Project.find(1)) + + assert_select("li") do + assert_select("a.parent-node", "Parent node") + assert_select("ul") do + assert_select("li a.child-node", "Child node") + assert_select("ul") do + assert_select("li a.test-dynamic-child-0", "Test dynamic child 0") + assert_select("li a.test-dynamic-child-1", "Test dynamic child 1") + assert_select("li a.test-dynamic-child-2", "Test dynamic child 2") + assert_select("li a.test-dynamic-child-3", "Test dynamic child 3") + assert_select("li a.test-dynamic-child-4", "Test dynamic child 4") + assert_select("li a.test-dynamic-child-5", "Test dynamic child 5") + end + assert_select("li a.test-child-0", "Test child 0") + assert_select("li a.test-child-1", "Test child 1") + assert_select("li a.test-child-2", "Test child 2") + end + end + end + + def test_render_menu_node_with_child_menus_without_an_array + parent_node = Redmine::MenuManager::MenuItem.new(:parent_node, + '/test', + { + :child_menus => Proc.new {|p| Redmine::MenuManager::MenuItem.new("test_child", "/testing", {})} + }) + + assert_raises Redmine::MenuManager::MenuError, ":child_menus must be an array of MenuItems" do + @response.body = render_menu_node(parent_node, Project.find(1)) + end + end + + def test_render_menu_node_with_incorrect_child_menus + parent_node = Redmine::MenuManager::MenuItem.new(:parent_node, + '/test', + { + :child_menus => Proc.new {|p| ["a string"] } + }) + + assert_raises Redmine::MenuManager::MenuError, ":child_menus must be an array of MenuItems" do + @response.body = render_menu_node(parent_node, Project.find(1)) + end + + end + def test_menu_items_for_should_yield_all_items_if_passed_a_block menu_name = :test_menu_items_for_should_yield_all_items_if_passed_a_block Redmine::MenuManager.map menu_name do |menu| diff --git a/test/unit/lib/redmine/menu_manager/menu_item_test.rb b/test/unit/lib/redmine/menu_manager/menu_item_test.rb index ee302fc00..ccb52df6d 100644 --- a/test/unit/lib/redmine/menu_manager/menu_item_test.rb +++ b/test/unit/lib/redmine/menu_manager/menu_item_test.rb @@ -92,6 +92,20 @@ class Redmine::MenuManager::MenuItemTest < Test::Unit::TestCase }) end + def test_new_menu_item_should_require_a_proc_to_use_the_child_menus_option + assert_raises ArgumentError do + Redmine::MenuManager::MenuItem.new(:test_error, '/test', + { + :child_menus => ['not_a_proc'] + }) + end + + assert Redmine::MenuManager::MenuItem.new(:test_good_child_menus, '/test', + { + :child_menus => Proc.new{} + }) + end + def test_new_should_not_allow_setting_the_parent_menu_item_to_the_current_item assert_raises ArgumentError do Redmine::MenuManager::MenuItem.new(:test_error, '/test', { :parent_menu => :test_error }) diff --git a/test/unit/lib/redmine/menu_manager_test.rb b/test/unit/lib/redmine/menu_manager_test.rb index 8c6ecda92..0c01ca323 100644 --- a/test/unit/lib/redmine/menu_manager_test.rb +++ b/test/unit/lib/redmine/menu_manager_test.rb @@ -25,4 +25,8 @@ class Redmine::MenuManagerTest < Test::Unit::TestCase context "MenuManager#items" do should "be tested" end + + should "be tested" do + assert true + end end |