summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorEric Davis <edavis@littlestreamsoftware.com>2009-11-25 05:36:50 +0000
committerEric Davis <edavis@littlestreamsoftware.com>2009-11-25 05:36:50 +0000
commitb0999e3764f0554d40d243f273f23fe53e164066 (patch)
tree6ad211b83516bf9db17d7bf84af8794875a760e9 /test
parent1f06cf889990d9640f7160c4969ed074fb68a7ca (diff)
downloadredmine-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.rb101
-rw-r--r--test/unit/lib/redmine/menu_manager/menu_item_test.rb14
-rw-r--r--test/unit/lib/redmine/menu_manager_test.rb4
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