Browse Source

Added Project#enable_module! and Project#disable_module! (#7115)

git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@6098 e93f8b46-1217-0410-a6f0-8f06a7374b81
tags/1.3.0
Jean-Baptiste Barth 13 years ago
parent
commit
88bd76b0e4
2 changed files with 69 additions and 1 deletions
  1. 21
    1
      app/models/project.rb
  2. 48
    0
      test/unit/project_test.rb

+ 21
- 1
app/models/project.rb View File

@@ -544,7 +544,27 @@ class Project < ActiveRecord::Base
def enabled_module_names
enabled_modules.collect(&:name)
end

# Enable a specific module
#
# Examples:
# project.enable_module!(:issue_tracking)
# project.enable_module!("issue_tracking")
def enable_module!(name)
enabled_modules << EnabledModule.new(:name => name.to_s) unless module_enabled?(name)
end

# Disable a module if it exists
#
# Examples:
# project.disable_module!(:issue_tracking)
# project.disable_module!("issue_tracking")
# project.disable_module!(project.enabled_modules.first)
def disable_module!(target)
target = enabled_modules.detect{|mod| target.to_s == mod.name} unless enabled_modules.include?(target)
target.destroy unless target.blank?
end

safe_attributes 'name',
'description',
'homepage',

+ 48
- 0
test/unit/project_test.rb View File

@@ -597,6 +597,54 @@ class ProjectTest < ActiveSupport::TestCase
end
end

context "enabled_modules" do
setup do
@project = Project.find(1)
end

should "define module by names and preserve ids" do
# Remove one module
modules = @project.enabled_modules.slice(0..-2)
assert modules.any?
assert_difference 'EnabledModule.count', -1 do
@project.enabled_module_names = modules.collect(&:name)
end
@project.reload
# Ids should be preserved
assert_equal @project.enabled_module_ids.sort, modules.collect(&:id).sort
end

should "enable a module" do
@project.enabled_module_names = []
@project.reload
assert_equal [], @project.enabled_module_names
#with string
@project.enable_module!("issue_tracking")
assert_equal ["issue_tracking"], @project.enabled_module_names
#with symbol
@project.enable_module!(:gantt)
assert_equal ["issue_tracking", "gantt"], @project.enabled_module_names
#don't add a module twice
@project.enable_module!("issue_tracking")
assert_equal ["issue_tracking", "gantt"], @project.enabled_module_names
end

should "disable a module" do
#with string
assert @project.enabled_module_names.include?("issue_tracking")
@project.disable_module!("issue_tracking")
assert ! @project.reload.enabled_module_names.include?("issue_tracking")
#with symbol
assert @project.enabled_module_names.include?("gantt")
@project.disable_module!(:gantt)
assert ! @project.reload.enabled_module_names.include?("gantt")
#with EnabledModule object
first_module = @project.enabled_modules.first
@project.disable_module!(first_module)
assert ! @project.reload.enabled_module_names.include?(first_module.name)
end
end

def test_enabled_module_names_should_not_recreate_enabled_modules
project = Project.find(1)
# Remove one module

Loading…
Cancel
Save