summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGo MAEDA <maeda@farend.jp>2019-04-19 15:30:41 +0000
committerGo MAEDA <maeda@farend.jp>2019-04-19 15:30:41 +0000
commit9cce7e85a20d18a207158a65dcca41caf573bcd8 (patch)
tree793ea585b2069af6abe7f7e50f4ad88490101b18
parent18a4f64547488db9973551ce54329699299b2d8a (diff)
downloadredmine-9cce7e85a20d18a207158a65dcca41caf573bcd8.tar.gz
redmine-9cce7e85a20d18a207158a65dcca41caf573bcd8.zip
Raise an exception if the plugin directory name differs from the plugin id (#31110).
Patch by Mizuki ISHIKAWA. git-svn-id: http://svn.redmine.org/redmine/trunk@18064 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--lib/redmine/plugin.rb4
-rw-r--r--test/unit/lib/redmine/plugin_test.rb8
2 files changed, 12 insertions, 0 deletions
diff --git a/lib/redmine/plugin.rb b/lib/redmine/plugin.rb
index a8e523bfe..b5fa3d209 100644
--- a/lib/redmine/plugin.rb
+++ b/lib/redmine/plugin.rb
@@ -98,6 +98,10 @@ module Redmine
# Set a default directory if it was not provided during registration
p.directory(File.join(self.directory, id.to_s)) if p.directory.nil?
+ unless File.directory?(p.directory)
+ raise PluginNotFound, "Plugin not found. The directory for plugin #{p.id} should be #{p.directory}."
+ end
+
# Adds plugin locales if any
# YAML translation files should be found under <plugin>/config/locales/
Rails.application.config.i18n.load_path += Dir.glob(File.join(p.directory, 'config', 'locales', '*.yml'))
diff --git a/test/unit/lib/redmine/plugin_test.rb b/test/unit/lib/redmine/plugin_test.rb
index 29facdd3a..e56de307b 100644
--- a/test/unit/lib/redmine/plugin_test.rb
+++ b/test/unit/lib/redmine/plugin_test.rb
@@ -57,6 +57,14 @@ class Redmine::PluginTest < ActiveSupport::TestCase
assert_equal '0.0.1', plugin.version
end
+ def test_register_should_raise_error_if_plugin_directory_does_not_exist
+ e = assert_raises Redmine::PluginNotFound do
+ @klass.register(:bar_plugin) {}
+ end
+
+ assert_equal "Plugin not found. The directory for plugin bar_plugin should be #{Rails.root.join('test/fixtures/plugins/bar_plugin')}.", e.message
+ end
+
def test_installed
@klass.register(:foo_plugin) {}
assert_equal true, @klass.installed?(:foo_plugin)