PageRenderTime 44ms CodeModel.GetById 19ms RepoModel.GetById 0ms app.codeStats 0ms

/railties/test/initializer_test.rb

https://github.com/cardmagic/rails
Ruby | 264 lines | 219 code | 44 blank | 1 comment | 0 complexity | 4899c52e6a7cbb1bebf2ea6851be0757 MD5 | raw file
  1. require 'abstract_unit'
  2. require 'initializer'
  3. # Mocks out the configuration
  4. module Rails
  5. def self.configuration
  6. Rails::Configuration.new
  7. end
  8. end
  9. class ConfigurationMock < Rails::Configuration
  10. attr_reader :environment_path
  11. def initialize(envpath)
  12. super()
  13. @environment_path = envpath
  14. end
  15. end
  16. class Initializer_load_environment_Test < Test::Unit::TestCase
  17. def test_load_environment_with_constant
  18. config = ConfigurationMock.new("#{File.dirname(__FILE__)}/fixtures/environment_with_constant.rb")
  19. assert_nil $initialize_test_set_from_env
  20. Rails::Initializer.run(:load_environment, config)
  21. assert_equal "success", $initialize_test_set_from_env
  22. ensure
  23. $initialize_test_set_from_env = nil
  24. end
  25. end
  26. class Initializer_eager_loading_Test < Test::Unit::TestCase
  27. def setup
  28. @config = ConfigurationMock.new("")
  29. @config.cache_classes = true
  30. @config.load_paths = [File.expand_path(File.dirname(__FILE__) + "/fixtures/eager")]
  31. @config.eager_load_paths = [File.expand_path(File.dirname(__FILE__) + "/fixtures/eager")]
  32. @initializer = Rails::Initializer.new(@config)
  33. @initializer.set_load_path
  34. @initializer.set_autoload_paths
  35. end
  36. def test_eager_loading_loads_parent_classes_before_children
  37. assert_nothing_raised do
  38. @initializer.load_application_classes
  39. end
  40. end
  41. end
  42. uses_mocha 'Initializer after_initialize' do
  43. class Initializer_after_initialize_with_blocks_environment_Test < Test::Unit::TestCase
  44. def setup
  45. config = ConfigurationMock.new("")
  46. config.after_initialize do
  47. $test_after_initialize_block1 = "success"
  48. end
  49. config.after_initialize do
  50. $test_after_initialize_block2 = "congratulations"
  51. end
  52. assert_nil $test_after_initialize_block1
  53. assert_nil $test_after_initialize_block2
  54. Rails::Initializer.any_instance.expects(:gems_dependencies_loaded).returns(true)
  55. Rails::Initializer.run(:after_initialize, config)
  56. end
  57. def teardown
  58. $test_after_initialize_block1 = nil
  59. $test_after_initialize_block2 = nil
  60. end
  61. def test_should_have_called_the_first_after_initialize_block
  62. assert_equal "success", $test_after_initialize_block1
  63. end
  64. def test_should_have_called_the_second_after_initialize_block
  65. assert_equal "congratulations", $test_after_initialize_block2
  66. end
  67. end
  68. class Initializer_after_initialize_with_no_block_environment_Test < Test::Unit::TestCase
  69. def setup
  70. config = ConfigurationMock.new("")
  71. config.after_initialize do
  72. $test_after_initialize_block1 = "success"
  73. end
  74. config.after_initialize # don't pass a block, this is what we're testing!
  75. config.after_initialize do
  76. $test_after_initialize_block2 = "congratulations"
  77. end
  78. assert_nil $test_after_initialize_block1
  79. Rails::Initializer.any_instance.expects(:gems_dependencies_loaded).returns(true)
  80. Rails::Initializer.run(:after_initialize, config)
  81. end
  82. def teardown
  83. $test_after_initialize_block1 = nil
  84. $test_after_initialize_block2 = nil
  85. end
  86. def test_should_have_called_the_first_after_initialize_block
  87. assert_equal "success", $test_after_initialize_block1, "should still get set"
  88. end
  89. def test_should_have_called_the_second_after_initialize_block
  90. assert_equal "congratulations", $test_after_initialize_block2
  91. end
  92. end
  93. end
  94. uses_mocha 'framework paths' do
  95. class ConfigurationFrameworkPathsTests < Test::Unit::TestCase
  96. def setup
  97. @config = Rails::Configuration.new
  98. @config.frameworks.clear
  99. File.stubs(:directory?).returns(true)
  100. @config.stubs(:framework_root_path).returns('')
  101. end
  102. def test_minimal
  103. expected = %w(
  104. /railties
  105. /railties/lib
  106. /activesupport/lib
  107. )
  108. assert_equal expected, @config.framework_paths
  109. end
  110. def test_actioncontroller_or_actionview_add_actionpack
  111. @config.frameworks << :action_controller
  112. assert_framework_path '/actionpack/lib'
  113. @config.frameworks = [:action_view]
  114. assert_framework_path '/actionpack/lib'
  115. end
  116. def test_paths_for_ar_ares_and_mailer
  117. [:active_record, :action_mailer, :active_resource, :action_web_service].each do |framework|
  118. @config.frameworks = [framework]
  119. assert_framework_path "/#{framework.to_s.gsub('_', '')}/lib"
  120. end
  121. end
  122. def test_unknown_framework_raises_error
  123. @config.frameworks << :action_foo
  124. initializer = Rails::Initializer.new @config
  125. initializer.expects(:require).raises(LoadError)
  126. assert_raise RuntimeError do
  127. initializer.send :require_frameworks
  128. end
  129. end
  130. def test_action_mailer_load_paths_set_only_if_action_mailer_in_use
  131. @config.frameworks = [:action_controller]
  132. initializer = Rails::Initializer.new @config
  133. initializer.send :require_frameworks
  134. assert_nothing_raised NameError do
  135. initializer.send :load_view_paths
  136. end
  137. end
  138. def test_action_controller_load_paths_set_only_if_action_controller_in_use
  139. @config.frameworks = []
  140. initializer = Rails::Initializer.new @config
  141. initializer.send :require_frameworks
  142. assert_nothing_raised NameError do
  143. initializer.send :load_view_paths
  144. end
  145. end
  146. protected
  147. def assert_framework_path(path)
  148. assert @config.framework_paths.include?(path),
  149. "<#{path.inspect}> not found among <#{@config.framework_paths.inspect}>"
  150. end
  151. end
  152. end
  153. uses_mocha "Initializer plugin loading tests" do
  154. require File.dirname(__FILE__) + '/plugin_test_helper'
  155. class InitializerPluginLoadingTests < Test::Unit::TestCase
  156. def setup
  157. @configuration = Rails::Configuration.new
  158. @configuration.plugin_paths << plugin_fixture_root_path
  159. @initializer = Rails::Initializer.new(@configuration)
  160. @valid_plugin_path = plugin_fixture_path('default/stubby')
  161. @empty_plugin_path = plugin_fixture_path('default/empty')
  162. end
  163. def test_no_plugins_are_loaded_if_the_configuration_has_an_empty_plugin_list
  164. only_load_the_following_plugins! []
  165. @initializer.load_plugins
  166. assert_equal [], @initializer.loaded_plugins
  167. end
  168. def test_only_the_specified_plugins_are_located_in_the_order_listed
  169. plugin_names = [:plugin_with_no_lib_dir, :acts_as_chunky_bacon]
  170. only_load_the_following_plugins! plugin_names
  171. load_plugins!
  172. assert_plugins plugin_names, @initializer.loaded_plugins
  173. end
  174. def test_all_plugins_are_loaded_when_registered_plugin_list_is_untouched
  175. failure_tip = "It's likely someone has added a new plugin fixture without updating this list"
  176. load_plugins!
  177. assert_plugins [:a, :acts_as_chunky_bacon, :gemlike, :plugin_with_no_lib_dir, :stubby], @initializer.loaded_plugins, failure_tip
  178. end
  179. def test_all_plugins_loaded_when_all_is_used
  180. plugin_names = [:stubby, :acts_as_chunky_bacon, :all]
  181. only_load_the_following_plugins! plugin_names
  182. load_plugins!
  183. failure_tip = "It's likely someone has added a new plugin fixture without updating this list"
  184. assert_plugins [:stubby, :acts_as_chunky_bacon, :a, :gemlike, :plugin_with_no_lib_dir], @initializer.loaded_plugins, failure_tip
  185. end
  186. def test_all_plugins_loaded_after_all
  187. plugin_names = [:stubby, :all, :acts_as_chunky_bacon]
  188. only_load_the_following_plugins! plugin_names
  189. load_plugins!
  190. failure_tip = "It's likely someone has added a new plugin fixture without updating this list"
  191. assert_plugins [:stubby, :a, :gemlike, :plugin_with_no_lib_dir, :acts_as_chunky_bacon], @initializer.loaded_plugins, failure_tip
  192. end
  193. def test_plugin_names_may_be_strings
  194. plugin_names = ['stubby', 'acts_as_chunky_bacon', :a, :plugin_with_no_lib_dir]
  195. only_load_the_following_plugins! plugin_names
  196. load_plugins!
  197. failure_tip = "It's likely someone has added a new plugin fixture without updating this list"
  198. assert_plugins plugin_names, @initializer.loaded_plugins, failure_tip
  199. end
  200. def test_registering_a_plugin_name_that_does_not_exist_raises_a_load_error
  201. only_load_the_following_plugins! [:stubby, :acts_as_a_non_existant_plugin]
  202. assert_raises(LoadError) do
  203. load_plugins!
  204. end
  205. end
  206. def test_should_ensure_all_loaded_plugins_load_paths_are_added_to_the_load_path
  207. only_load_the_following_plugins! [:stubby, :acts_as_chunky_bacon]
  208. @initializer.add_plugin_load_paths
  209. assert $LOAD_PATH.include?(File.join(plugin_fixture_path('default/stubby'), 'lib'))
  210. assert $LOAD_PATH.include?(File.join(plugin_fixture_path('default/acts/acts_as_chunky_bacon'), 'lib'))
  211. end
  212. private
  213. def load_plugins!
  214. @initializer.add_plugin_load_paths
  215. @initializer.load_plugins
  216. end
  217. end
  218. end