]> source.dussan.org Git - redmine.git/commitdiff
Modules selection lost on project form after validation failure (#8012).
authorJean-Philippe Lang <jp_lang@yahoo.fr>
Wed, 30 Mar 2011 17:16:25 +0000 (17:16 +0000)
committerJean-Philippe Lang <jp_lang@yahoo.fr>
Wed, 30 Mar 2011 17:16:25 +0000 (17:16 +0000)
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@5265 e93f8b46-1217-0410-a6f0-8f06a7374b81

app/models/project.rb
test/functional/projects_controller_test.rb
test/unit/project_test.rb

index 0953d786ff4ef49f87f2b873b87bf42123c98d87..cd36bc76ce3ceb5a2bbebe52b51e3e407cd60818 100644 (file)
@@ -517,10 +517,7 @@ class Project < ActiveRecord::Base
   def enabled_module_names=(module_names)
     if module_names && module_names.is_a?(Array)
       module_names = module_names.collect(&:to_s).reject(&:blank?)
-      # remove disabled modules
-      enabled_modules.each {|mod| mod.destroy unless module_names.include?(mod.name)}
-      # add new modules
-      module_names.reject {|name| module_enabled?(name)}.each {|name| enabled_modules << EnabledModule.new(:name => name)}
+      self.enabled_modules = module_names.collect {|name| enabled_modules.detect {|mod| mod.name == name} || EnabledModule.new(:name => name)}
     else
       enabled_modules.clear
     end
index fefb8d53bd0b5b31434b29583d63ce136aa57ab7..74912a764c8d537c6c37ae7f57224be62ce71c5b 100644 (file)
@@ -288,6 +288,22 @@ class ProjectsControllerTest < ActionController::TestCase
     end
   end
   
+  def test_create_should_preserve_modules_on_validation_failure
+    with_settings :default_projects_modules => ['issue_tracking', 'repository'] do
+      @request.session[:user_id] = 1
+      assert_no_difference 'Project.count' do
+        post :create, :project => {
+          :name => "blog",
+          :identifier => "",
+          :enabled_module_names => %w(issue_tracking news)
+        }
+      end
+      assert_response :success
+      project = assigns(:project)
+      assert_equal %w(issue_tracking news), project.enabled_module_names.sort
+    end
+  end
+  
   def test_create_should_not_accept_get
     @request.session[:user_id] = 1
     get :create
index ba61db49c9ac5dff98fc87ed5db9a4d9162ad7ab..d307500e3bc9ce3598ea9fac9e950f170fc66ae8 100644 (file)
@@ -588,6 +588,14 @@ class ProjectTest < ActiveSupport::TestCase
     assert_nil Project.next_identifier
   end
   
+  def test_enabled_module_names
+    with_settings :default_projects_modules => ['issue_tracking', 'repository'] do
+      project = Project.new
+      
+      project.enabled_module_names = %w(issue_tracking news)
+      assert_equal %w(issue_tracking news), project.enabled_module_names.sort
+    end
+  end
 
   def test_enabled_module_names_should_not_recreate_enabled_modules
     project = Project.find(1)