aboutsummaryrefslogtreecommitdiffstats
path: root/railties/test/plugin_test.rb
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2005-11-07 08:09:38 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2005-11-07 08:09:38 +0000
commit6c434e8b8e420c76f86ba6605e98426fddca5031 (patch)
tree3f5a5f83f41a3e30e37f6b1b03106d000f84d871 /railties/test/plugin_test.rb
parent5c1eb899dea9aad18220b6403d3dd83863591f28 (diff)
downloadrails-6c434e8b8e420c76f86ba6605e98426fddca5031.tar.gz
rails-6c434e8b8e420c76f86ba6605e98426fddca5031.tar.bz2
rails-6c434e8b8e420c76f86ba6605e98426fddca5031.zip
New configuration option config.plugin_paths which may be a single path like the default 'vendor/plugins' or an array of paths: ['vendor/plugins', 'lib/plugins']. Plugins are discovered in nested paths, so you can organize your plugins directory as you like. Refactor load_plugin from load_plugins. Simplify initializer unit test. Closes #2757.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@2904 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'railties/test/plugin_test.rb')
-rw-r--r--railties/test/plugin_test.rb72
1 files changed, 72 insertions, 0 deletions
diff --git a/railties/test/plugin_test.rb b/railties/test/plugin_test.rb
new file mode 100644
index 0000000000..54eea13538
--- /dev/null
+++ b/railties/test/plugin_test.rb
@@ -0,0 +1,72 @@
+$:.unshift File.dirname(__FILE__) + "/../lib"
+$:.unshift File.dirname(__FILE__) + "/../../activesupport/lib"
+
+require 'test/unit'
+require 'active_support'
+require 'initializer'
+
+class PluginTest < Test::Unit::TestCase
+ class TestConfig < Rails::Configuration
+ protected
+ def root_path
+ File.dirname(__FILE__)
+ end
+ end
+
+ def setup
+ @init = Rails::Initializer.new(TestConfig.new)
+ end
+
+ def test_plugin_path?
+ assert @init.send(:plugin_path?, "#{File.dirname(__FILE__)}/fixtures/plugins/default/stubby")
+ assert !@init.send(:plugin_path?, "#{File.dirname(__FILE__)}/fixtures/plugins/default/empty")
+ assert !@init.send(:plugin_path?, "#{File.dirname(__FILE__)}/fixtures/plugins/default/jalskdjflkas")
+ end
+
+ def test_find_plugins
+ base = "#{File.dirname(__FILE__)}/fixtures/plugins"
+ default = "#{base}/default"
+ alt = "#{base}/alternate"
+ acts = "#{default}/acts"
+ assert_equal ["#{acts}/acts_as_chunky_bacon"], @init.send(:find_plugins, acts)
+ assert_equal ["#{acts}/acts_as_chunky_bacon", "#{default}/stubby"], @init.send(:find_plugins, default).sort
+ assert_equal ["#{alt}/a", "#{acts}/acts_as_chunky_bacon", "#{default}/stubby"], @init.send(:find_plugins, base).sort
+ end
+
+ def test_load_plugin
+ stubby = "#{File.dirname(__FILE__)}/fixtures/plugins/default/stubby"
+ expected = Set.new(['stubby'])
+
+ assert @init.send(:load_plugin, stubby)
+ assert_equal expected, @init.loaded_plugins
+
+ assert !@init.send(:load_plugin, stubby)
+ assert_equal expected, @init.loaded_plugins
+
+ assert_raise(LoadError) { @init.send(:load_plugin, 'lakjsdfkasljdf') }
+ assert_equal expected, @init.loaded_plugins
+ end
+
+ def test_load_default_plugins
+ assert_loaded_plugins %w(stubby acts_as_chunky_bacon), 'default'
+ end
+
+ def test_load_alternate_plugins
+ assert_loaded_plugins %w(a), 'alternate'
+ end
+
+ def test_load_plugins_from_two_sources
+ assert_loaded_plugins %w(a stubby acts_as_chunky_bacon), ['default', 'alternate']
+ end
+
+ protected
+ def assert_loaded_plugins(plugins, path)
+ assert_equal Set.new(plugins), load_plugins(path)
+ end
+
+ def load_plugins(*paths)
+ @init.configuration.plugin_paths = paths.flatten.map { |p| "#{File.dirname(__FILE__)}/fixtures/plugins/#{p}" }
+ @init.load_plugins
+ @init.loaded_plugins
+ end
+end