Skip to content
Snippets Groups Projects
Commit 28e9bc5d authored by Eric Davis's avatar Eric Davis
Browse files

Fix an IndexError if all the :last menu items are deleted from a menu. #4718

git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@3447 e93f8b46-1217-0410-a6f0-8f06a7374b81
parent 0fcc436f
Branches
Tags
No related merge requests found
...@@ -84,6 +84,14 @@ module TreeNodePatch ...@@ -84,6 +84,14 @@ module TreeNodePatch
end end
# Wrapp remove! making sure to decrement the last_items counter if
# the removed child was a last item
def remove!(child)
@last_items_count -= +1 if child && child.last
super
end
# Will return the position (zero-based) of the current child in # Will return the position (zero-based) of the current child in
# it's parent # it's parent
def position def position
...@@ -352,7 +360,7 @@ module Redmine ...@@ -352,7 +360,7 @@ module Redmine
target_root.add(MenuItem.new(name, url, options)) target_root.add(MenuItem.new(name, url, options))
end end
elsif options.delete(:last) elsif options[:last] # don't delete, needs to be stored
target_root.add_last(MenuItem.new(name, url, options)) target_root.add_last(MenuItem.new(name, url, options))
else else
target_root.add(MenuItem.new(name, url, options)) target_root.add(MenuItem.new(name, url, options))
...@@ -386,7 +394,7 @@ module Redmine ...@@ -386,7 +394,7 @@ module Redmine
class MenuItem < Tree::TreeNode class MenuItem < Tree::TreeNode
include Redmine::I18n include Redmine::I18n
attr_reader :name, :url, :param, :condition, :parent, :child_menus attr_reader :name, :url, :param, :condition, :parent, :child_menus, :last
def initialize(name, url, options) def initialize(name, url, options)
raise ArgumentError, "Invalid option :if for menu item '#{name}'" if options[:if] && !options[:if].respond_to?(:call) raise ArgumentError, "Invalid option :if for menu item '#{name}'" if options[:if] && !options[:if].respond_to?(:call)
...@@ -403,6 +411,7 @@ module Redmine ...@@ -403,6 +411,7 @@ module Redmine
@html_options[:class] = [@html_options[:class], @name.to_s.dasherize].compact.join(' ') @html_options[:class] = [@html_options[:class], @name.to_s.dasherize].compact.join(' ')
@parent = options[:parent] @parent = options[:parent]
@child_menus = options[:children] @child_menus = options[:children]
@last = options[:last] || false
super @name.to_sym super @name.to_sym
end end
......
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
require File.dirname(__FILE__) + '/../../../../test_helper' require File.dirname(__FILE__) + '/../../../../test_helper'
class Redmine::MenuManager::MapperTest < Test::Unit::TestCase class Redmine::MenuManager::MapperTest < ActiveSupport::TestCase
context "Mapper#initialize" do context "Mapper#initialize" do
should "be tested" should "be tested"
end end
...@@ -163,4 +163,21 @@ class Redmine::MenuManager::MapperTest < Test::Unit::TestCase ...@@ -163,4 +163,21 @@ class Redmine::MenuManager::MapperTest < Test::Unit::TestCase
menu_mapper = Redmine::MenuManager::Mapper.new(:test_menu, {}) menu_mapper = Redmine::MenuManager::Mapper.new(:test_menu, {})
assert_nil menu_mapper.delete(:test_missing) assert_nil menu_mapper.delete(:test_missing)
end end
test 'deleting all items' do
# Exposed by deleting :last items
Redmine::MenuManager.map :test_menu do |menu|
menu.push :not_last, Redmine::Info.help_url
menu.push :administration, { :controller => 'projects', :action => 'show'}, {:last => true}
menu.push :help, Redmine::Info.help_url, :last => true
end
assert_nothing_raised do
Redmine::MenuManager.map :test_menu do |menu|
menu.delete(:administration)
menu.delete(:help)
menu.push :test_overview, { :controller => 'projects', :action => 'show'}, {}
end
end
end
end end
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment