summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2010-01-31 10:39:42 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2010-01-31 10:39:42 +0000
commita1a24483b5c5736704304ca76c9d9a1f8f6ff48c (patch)
tree1033ca43f7b4f9437a2ce0f4251093a56e86358b
parenta5698b37451357d0037fc50802f2d7f3bbc0dcee (diff)
downloadredmine-a1a24483b5c5736704304ca76c9d9a1f8f6ff48c.tar.gz
redmine-a1a24483b5c5736704304ca76c9d9a1f8f6ff48c.zip
Fixed: deleting a project with subprojects breaks the project tree (#4701).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@3354 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--app/models/project.rb11
-rw-r--r--test/unit/project_nested_set_test.rb58
2 files changed, 67 insertions, 2 deletions
diff --git a/app/models/project.rb b/app/models/project.rb
index 490c290be..b8030d7fd 100644
--- a/app/models/project.rb
+++ b/app/models/project.rb
@@ -51,7 +51,7 @@ class Project < ActiveRecord::Base
:join_table => "#{table_name_prefix}custom_fields_projects#{table_name_suffix}",
:association_foreign_key => 'custom_field_id'
- acts_as_nested_set :order => 'name', :dependent => :destroy
+ acts_as_nested_set :order => 'name'
acts_as_attachable :view_permission => :view_files,
:delete_permission => :manage_files
@@ -74,7 +74,7 @@ class Project < ActiveRecord::Base
# reserved words
validates_exclusion_of :identifier, :in => %w( new )
- before_destroy :delete_all_members
+ before_destroy :delete_all_members, :destroy_children
named_scope :has_module, lambda { |mod| { :conditions => ["#{Project.table_name}.id IN (SELECT em.project_id FROM #{EnabledModule.table_name} em WHERE em.name=?)", mod.to_s] } }
named_scope :active, { :conditions => "#{Project.table_name}.status = #{STATUS_ACTIVE}"}
@@ -499,6 +499,13 @@ class Project < ActiveRecord::Base
private
+ # Destroys children before destroying self
+ def destroy_children
+ children.each do |child|
+ child.destroy
+ end
+ end
+
# Copies wiki from +project+
def copy_wiki(project)
# Check that the source project has a wiki first
diff --git a/test/unit/project_nested_set_test.rb b/test/unit/project_nested_set_test.rb
new file mode 100644
index 000000000..6aa09d61c
--- /dev/null
+++ b/test/unit/project_nested_set_test.rb
@@ -0,0 +1,58 @@
+# Redmine - project management software
+# Copyright (C) 2006-2010 Jean-Philippe Lang
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+
+require File.dirname(__FILE__) + '/../test_helper'
+
+class ProjectNestedSetTest < ActiveSupport::TestCase
+
+ def setup
+ Project.delete_all
+ end
+
+ def test_destroy_root_and_chldren_should_not_mess_up_the_tree
+ a = Project.create!(:name => 'Project A', :identifier => 'projecta')
+ a1 = Project.create!(:name => 'Project A1', :identifier => 'projecta1')
+ a2 = Project.create!(:name => 'Project A2', :identifier => 'projecta2')
+ a1.set_parent!(a)
+ a2.set_parent!(a)
+ b = Project.create!(:name => 'Project B', :identifier => 'projectb')
+ b1 = Project.create!(:name => 'Project B1', :identifier => 'projectb1')
+ b1.set_parent!(b)
+
+ a.reload
+ a1.reload
+ a2.reload
+ b.reload
+ b1.reload
+
+ assert_equal [nil, 1, 6], [a.parent_id, a.lft, a.rgt]
+ assert_equal [a.id, 2, 3], [a1.parent_id, a1.lft, a1.rgt]
+ assert_equal [a.id, 4, 5], [a2.parent_id, a2.lft, a2.rgt]
+ assert_equal [nil, 7, 10], [b.parent_id, b.lft, b.rgt]
+ assert_equal [b.id, 8, 9], [b1.parent_id, b1.lft, b1.rgt]
+
+ assert_difference 'Project.count', -3 do
+ a.destroy
+ end
+
+ b.reload
+ b1.reload
+
+ assert_equal [nil, 1, 4], [b.parent_id, b.lft, b.rgt]
+ assert_equal [b.id, 2, 3], [b1.parent_id, b1.lft, b1.rgt]
+ end
+end \ No newline at end of file