Skip to content

Commit

Permalink
Update plugin loading tests to reflect changes in plugin fixtures.
Browse files Browse the repository at this point in the history
  • Loading branch information
josh committed Apr 21, 2008
1 parent 1642b23 commit eef9002
Show file tree
Hide file tree
Showing 3 changed files with 79 additions and 86 deletions.
49 changes: 24 additions & 25 deletions railties/test/initializer_test.rb
Expand Up @@ -38,27 +38,27 @@ def setup
end
config.after_initialize do
$test_after_initialize_block2 = "congratulations"
end
end
assert_nil $test_after_initialize_block1
assert_nil $test_after_initialize_block2
assert_nil $test_after_initialize_block2

Rails::Initializer.run(:after_initialize, config)
end

def teardown
$test_after_initialize_block1 = nil
$test_after_initialize_block2 = nil
$test_after_initialize_block2 = nil
end

def test_should_have_called_the_first_after_initialize_block
assert_equal "success", $test_after_initialize_block1
end

def test_should_have_called_the_second_after_initialize_block
assert_equal "congratulations", $test_after_initialize_block2
end
end

class Initializer_after_initialize_with_no_block_environment_Test < Test::Unit::TestCase

def setup
Expand All @@ -69,15 +69,15 @@ def setup
config.after_initialize # don't pass a block, this is what we're testing!
config.after_initialize do
$test_after_initialize_block2 = "congratulations"
end
end
assert_nil $test_after_initialize_block1

Rails::Initializer.run(:after_initialize, config)
end

def teardown
$test_after_initialize_block1 = nil
$test_after_initialize_block2 = nil
$test_after_initialize_block2 = nil
end

def test_should_have_called_the_first_after_initialize_block
Expand All @@ -95,7 +95,7 @@ class ConfigurationFrameworkPathsTests < Test::Unit::TestCase
def setup
@config = Rails::Configuration.new
@config.frameworks.clear

File.stubs(:directory?).returns(true)
@config.stubs(:framework_root_path).returns('')
end
Expand All @@ -112,7 +112,7 @@ def test_minimal
def test_actioncontroller_or_actionview_add_actionpack
@config.frameworks << :action_controller
assert_framework_path '/actionpack/lib'

@config.frameworks = [:action_view]
assert_framework_path '/actionpack/lib'
end
Expand Down Expand Up @@ -162,7 +162,7 @@ def test_no_plugins_are_loaded_if_the_configuration_has_an_empty_plugin_list
end

def test_only_the_specified_plugins_are_located_in_the_order_listed
plugin_names = [:plugin_with_no_lib_dir, :acts_as_chunky_bacon]
plugin_names = [:plugin_with_no_lib_dir]
only_load_the_following_plugins! plugin_names
load_plugins!
assert_plugins plugin_names, @initializer.loaded_plugins
Expand All @@ -171,27 +171,27 @@ def test_only_the_specified_plugins_are_located_in_the_order_listed
def test_all_plugins_are_loaded_when_registered_plugin_list_is_untouched
failure_tip = "It's likely someone has added a new plugin fixture without updating this list"
load_plugins!
assert_plugins [:a, :acts_as_chunky_bacon, :plugin_with_no_lib_dir, :stubby], @initializer.loaded_plugins, failure_tip
assert_plugins [:plugin_with_no_lib_dir, :stubby], @initializer.loaded_plugins, failure_tip
end

def test_all_plugins_loaded_when_all_is_used
plugin_names = [:stubby, :acts_as_chunky_bacon, :all]
plugin_names = [:stubby, :all]
only_load_the_following_plugins! plugin_names
load_plugins!
failure_tip = "It's likely someone has added a new plugin fixture without updating this list"
assert_plugins [:stubby, :acts_as_chunky_bacon, :a, :plugin_with_no_lib_dir], @initializer.loaded_plugins, failure_tip
assert_plugins [:stubby, :plugin_with_no_lib_dir], @initializer.loaded_plugins, failure_tip
end

def test_all_plugins_loaded_after_all
plugin_names = [:stubby, :all, :acts_as_chunky_bacon]
plugin_names = [:all, :stubby]
only_load_the_following_plugins! plugin_names
load_plugins!
failure_tip = "It's likely someone has added a new plugin fixture without updating this list"
assert_plugins [:stubby, :a, :plugin_with_no_lib_dir, :acts_as_chunky_bacon], @initializer.loaded_plugins, failure_tip
assert_plugins [:plugin_with_no_lib_dir, :stubby], @initializer.loaded_plugins, failure_tip
end

def test_plugin_names_may_be_strings
plugin_names = ['stubby', 'acts_as_chunky_bacon', :a, :plugin_with_no_lib_dir]
plugin_names = ['stubby', :plugin_with_no_lib_dir]
only_load_the_following_plugins! plugin_names
load_plugins!
failure_tip = "It's likely someone has added a new plugin fixture without updating this list"
Expand All @@ -204,22 +204,21 @@ def test_registering_a_plugin_name_that_does_not_exist_raises_a_load_error
load_plugins!
end
end

def test_should_ensure_all_loaded_plugins_load_paths_are_added_to_the_load_path
only_load_the_following_plugins! [:stubby, :acts_as_chunky_bacon]
only_load_the_following_plugins! [:stubby]

@initializer.add_plugin_load_paths

assert $LOAD_PATH.include?(File.join(plugin_fixture_path('default/stubby'), 'lib'))
assert $LOAD_PATH.include?(File.join(plugin_fixture_path('default/acts/acts_as_chunky_bacon'), 'lib'))
end

private

def load_plugins!
@initializer.add_plugin_load_paths
@initializer.load_plugins
end
end
end

end
89 changes: 43 additions & 46 deletions railties/test/plugin_loader_test.rb
Expand Up @@ -11,18 +11,18 @@ def self.configuration

class TestPluginLoader < Test::Unit::TestCase
ORIGINAL_LOAD_PATH = $LOAD_PATH.dup

def setup
reset_load_path!

@configuration = Rails::Configuration.new
@configuration.plugin_paths << plugin_fixture_root_path
@initializer = Rails::Initializer.new(@configuration)
@valid_plugin_path = plugin_fixture_path('default/stubby')
@empty_plugin_path = plugin_fixture_path('default/empty')

@failure_tip = "It's likely someone has added a new plugin fixture without updating this list"

@loader = Rails::Plugin::Loader.new(@initializer)
end

Expand All @@ -34,109 +34,106 @@ def test_should_locate_plugins_by_asking_each_locator_specifed_in_configuration_
@configuration.plugin_locators = [locator_class_1, locator_class_2]
assert_equal [:a, :b, :c, :d, :e, :f], @loader.send(:locate_plugins)
end

def test_should_memoize_the_result_of_locate_plugins_as_all_plugins
plugin_list = [:a, :b, :c]
@loader.expects(:locate_plugins).once.returns(plugin_list)
assert_equal plugin_list, @loader.all_plugins
assert_equal plugin_list, @loader.all_plugins # ensuring that locate_plugins isn't called again
end

def test_should_return_empty_array_if_configuration_plugins_is_empty
@configuration.plugins = []
assert_equal [], @loader.plugins
end

def test_should_find_all_availble_plugins_and_return_as_all_plugins
assert_plugins [:a, :acts_as_chunky_bacon, :plugin_with_no_lib_dir, :stubby], @loader.all_plugins.reverse, @failure_tip
assert_plugins [:stubby, :plugin_with_no_lib_dir], @loader.all_plugins.reverse, @failure_tip
end

def test_should_return_all_plugins_as_plugins_when_registered_plugin_list_is_untouched
assert_plugins [:a, :acts_as_chunky_bacon, :plugin_with_no_lib_dir, :stubby], @loader.plugins, @failure_tip
assert_plugins [:plugin_with_no_lib_dir, :stubby], @loader.plugins, @failure_tip
end

def test_should_return_all_plugins_as_plugins_when_registered_plugin_list_is_nil
@configuration.plugins = nil
assert_plugins [:a, :acts_as_chunky_bacon, :plugin_with_no_lib_dir, :stubby], @loader.plugins, @failure_tip
assert_plugins [:plugin_with_no_lib_dir, :stubby], @loader.plugins, @failure_tip
end

def test_should_return_specific_plugins_named_in_config_plugins_array_if_set
plugin_names = [:acts_as_chunky_bacon, :stubby]
plugin_names = [:stubby]
only_load_the_following_plugins! plugin_names
assert_plugins plugin_names, @loader.plugins
end

def test_should_respect_the_order_of_plugins_given_in_configuration
plugin_names = [:stubby, :acts_as_chunky_bacon]
plugin_names = [:stubby]
only_load_the_following_plugins! plugin_names
assert_plugins plugin_names, @loader.plugins
assert_plugins plugin_names, @loader.plugins
end

def test_should_load_all_plugins_in_natural_order_when_all_is_used
only_load_the_following_plugins! [:all]
assert_plugins [:a, :acts_as_chunky_bacon, :plugin_with_no_lib_dir, :stubby], @loader.plugins, @failure_tip
assert_plugins [:plugin_with_no_lib_dir, :stubby], @loader.plugins, @failure_tip
end

def test_should_load_specified_plugins_in_order_and_then_all_remaining_plugins_when_all_is_used
only_load_the_following_plugins! [:stubby, :acts_as_chunky_bacon, :all]
assert_plugins [:stubby, :acts_as_chunky_bacon, :a, :plugin_with_no_lib_dir], @loader.plugins, @failure_tip
only_load_the_following_plugins! [:stubby, :all]
assert_plugins [:stubby, :plugin_with_no_lib_dir], @loader.plugins, @failure_tip
end

def test_should_be_able_to_specify_loading_of_plugins_loaded_after_all
only_load_the_following_plugins! [:stubby, :all, :acts_as_chunky_bacon]
assert_plugins [:stubby, :a, :plugin_with_no_lib_dir, :acts_as_chunky_bacon], @loader.plugins, @failure_tip
only_load_the_following_plugins! [:stubby, :all]
assert_plugins [:stubby, :plugin_with_no_lib_dir], @loader.plugins, @failure_tip
end

def test_should_accept_plugin_names_given_as_strings
only_load_the_following_plugins! ['stubby', 'acts_as_chunky_bacon', :a, :plugin_with_no_lib_dir]
assert_plugins [:stubby, :acts_as_chunky_bacon, :a, :plugin_with_no_lib_dir], @loader.plugins, @failure_tip
only_load_the_following_plugins! ['stubby', :plugin_with_no_lib_dir]
assert_plugins [:stubby, :plugin_with_no_lib_dir], @loader.plugins, @failure_tip
end

def test_should_add_plugin_load_paths_to_global_LOAD_PATH_array
only_load_the_following_plugins! [:stubby, :acts_as_chunky_bacon]
only_load_the_following_plugins! [:stubby]
stubbed_application_lib_index_in_LOAD_PATHS = 5
@loader.stubs(:application_lib_index).returns(stubbed_application_lib_index_in_LOAD_PATHS)

@loader.add_plugin_load_paths

assert $LOAD_PATH.index(File.join(plugin_fixture_path('default/stubby'), 'lib')) >= stubbed_application_lib_index_in_LOAD_PATHS
assert $LOAD_PATH.index(File.join(plugin_fixture_path('default/acts/acts_as_chunky_bacon'), 'lib')) >= stubbed_application_lib_index_in_LOAD_PATHS
end

end

def test_should_add_plugin_load_paths_to_Dependencies_load_paths
only_load_the_following_plugins! [:stubby, :acts_as_chunky_bacon]
only_load_the_following_plugins! [:stubby]

@loader.add_plugin_load_paths

assert Dependencies.load_paths.include?(File.join(plugin_fixture_path('default/stubby'), 'lib'))
assert Dependencies.load_paths.include?(File.join(plugin_fixture_path('default/acts/acts_as_chunky_bacon'), 'lib'))
end

def test_should_add_plugin_load_paths_to_Dependencies_load_once_paths
only_load_the_following_plugins! [:stubby, :acts_as_chunky_bacon]
only_load_the_following_plugins! [:stubby]

@loader.add_plugin_load_paths

assert Dependencies.load_once_paths.include?(File.join(plugin_fixture_path('default/stubby'), 'lib'))
assert Dependencies.load_once_paths.include?(File.join(plugin_fixture_path('default/acts/acts_as_chunky_bacon'), 'lib'))
end

def test_should_add_all_load_paths_from_a_plugin_to_LOAD_PATH_array
plugin_load_paths = ["a", "b"]
plugin = stub(:load_paths => plugin_load_paths)
@loader.stubs(:plugins).returns([plugin])

@loader.add_plugin_load_paths

plugin_load_paths.each { |path| assert $LOAD_PATH.include?(path) }
end

private

def reset_load_path!
$LOAD_PATH.clear
ORIGINAL_LOAD_PATH.each { |path| $LOAD_PATH << path }
ORIGINAL_LOAD_PATH.each { |path| $LOAD_PATH << path }
end
end

end
27 changes: 12 additions & 15 deletions railties/test/plugin_locator_test.rb
Expand Up @@ -3,26 +3,26 @@
uses_mocha "Plugin Locator Tests" do

class PluginLocatorTest < Test::Unit::TestCase

def test_should_require_subclasses_to_implement_the_plugins_method
assert_raises(RuntimeError) do
Rails::Plugin::Locator.new(nil).plugins
end
end

def test_should_iterator_over_plugins_returned_by_plugins_when_calling_each
locator = Rails::Plugin::Locator.new(nil)
locator.stubs(:plugins).returns([:a, :b, :c])
plugin_consumer = mock
plugin_consumer.expects(:consume).with(:a)
plugin_consumer.expects(:consume).with(:b)
plugin_consumer.expects(:consume).with(:c)

locator.each do |plugin|
plugin_consumer.consume(plugin)
end
end

end


Expand All @@ -39,25 +39,22 @@ def setup
end

def test_should_return_rails_plugin_instances_when_calling_create_plugin_with_a_valid_plugin_directory
assert_kind_of Rails::Plugin, @locator.send(:create_plugin, @valid_plugin_path)
assert_kind_of Rails::Plugin, @locator.send(:create_plugin, @valid_plugin_path)
end

def test_should_return_nil_when_calling_create_plugin_with_an_invalid_plugin_directory
assert_nil @locator.send(:create_plugin, @empty_plugin_path)
assert_nil @locator.send(:create_plugin, @empty_plugin_path)
end

def test_should_return_all_plugins_found_under_the_set_plugin_paths
assert_equal ["a", "acts_as_chunky_bacon", "plugin_with_no_lib_dir", "stubby"].sort, @locator.plugins.map(&:name).sort
assert_equal ["plugin_with_no_lib_dir", "stubby"].sort, @locator.plugins.map(&:name).sort
end

def test_should_find_plugins_only_under_the_plugin_paths_set_in_configuration
@configuration.plugin_paths = [File.join(plugin_fixture_root_path, "default")]
assert_equal ["acts_as_chunky_bacon", "plugin_with_no_lib_dir", "stubby"].sort, @locator.plugins.map(&:name).sort

@configuration.plugin_paths = [File.join(plugin_fixture_root_path, "alternate")]
assert_equal ["a"], @locator.plugins.map(&:name)
assert_equal ["plugin_with_no_lib_dir", "stubby"].sort, @locator.plugins.map(&:name).sort
end

def test_should_not_raise_any_error_and_return_no_plugins_if_the_plugin_path_value_does_not_exist
@configuration.plugin_paths = ["some_missing_directory"]
assert_nothing_raised do
Expand Down

0 comments on commit eef9002

Please sign in to comment.