@@ -509,10 +509,7 class Project < ActiveRecord::Base | |||||
509 | def enabled_module_names=(module_names) |
|
509 | def enabled_module_names=(module_names) | |
510 | if module_names && module_names.is_a?(Array) |
|
510 | if module_names && module_names.is_a?(Array) | |
511 | module_names = module_names.collect(&:to_s).reject(&:blank?) |
|
511 | module_names = module_names.collect(&:to_s).reject(&:blank?) | |
512 | # remove disabled modules |
|
512 | self.enabled_modules = module_names.collect {|name| enabled_modules.detect {|mod| mod.name == name} || EnabledModule.new(:name => name)} | |
513 | enabled_modules.each {|mod| mod.destroy unless module_names.include?(mod.name)} |
|
|||
514 | # add new modules |
|
|||
515 | module_names.reject {|name| module_enabled?(name)}.each {|name| enabled_modules << EnabledModule.new(:name => name)} |
|
|||
516 | else |
|
513 | else | |
517 | enabled_modules.clear |
|
514 | enabled_modules.clear | |
518 | end |
|
515 | end |
@@ -288,6 +288,22 class ProjectsControllerTest < ActionController::TestCase | |||||
288 | end |
|
288 | end | |
289 | end |
|
289 | end | |
290 |
|
290 | |||
|
291 | def test_create_should_preserve_modules_on_validation_failure | |||
|
292 | with_settings :default_projects_modules => ['issue_tracking', 'repository'] do | |||
|
293 | @request.session[:user_id] = 1 | |||
|
294 | assert_no_difference 'Project.count' do | |||
|
295 | post :create, :project => { | |||
|
296 | :name => "blog", | |||
|
297 | :identifier => "", | |||
|
298 | :enabled_module_names => %w(issue_tracking news) | |||
|
299 | } | |||
|
300 | end | |||
|
301 | assert_response :success | |||
|
302 | project = assigns(:project) | |||
|
303 | assert_equal %w(issue_tracking news), project.enabled_module_names.sort | |||
|
304 | end | |||
|
305 | end | |||
|
306 | ||||
291 | def test_create_should_not_accept_get |
|
307 | def test_create_should_not_accept_get | |
292 | @request.session[:user_id] = 1 |
|
308 | @request.session[:user_id] = 1 | |
293 | get :create |
|
309 | get :create |
@@ -553,6 +553,14 class ProjectTest < ActiveSupport::TestCase | |||||
553 | assert_nil Project.next_identifier |
|
553 | assert_nil Project.next_identifier | |
554 | end |
|
554 | end | |
555 |
|
555 | |||
|
556 | def test_enabled_module_names | |||
|
557 | with_settings :default_projects_modules => ['issue_tracking', 'repository'] do | |||
|
558 | project = Project.new | |||
|
559 | ||||
|
560 | project.enabled_module_names = %w(issue_tracking news) | |||
|
561 | assert_equal %w(issue_tracking news), project.enabled_module_names.sort | |||
|
562 | end | |||
|
563 | end | |||
556 |
|
564 | |||
557 | def test_enabled_module_names_should_not_recreate_enabled_modules |
|
565 | def test_enabled_module_names_should_not_recreate_enabled_modules | |
558 | project = Project.find(1) |
|
566 | project = Project.find(1) |
General Comments 0
You need to be logged in to leave comments.
Login now