initializer_test.rb 16.5 KB
Newer Older
1
require 'abstract_unit'
2
require 'initializer'
3
require 'generators'
4

5
require 'action_view'
6
require 'action_mailer'
7 8
require 'active_record'

9 10 11 12 13
# Mocks out the configuration
module Rails
  def self.configuration
    Rails::Configuration.new
  end
14 15 16 17 18 19 20 21 22 23

  module Generators
    def self.clear_aliases!
      @aliases = nil
    end

    def self.clear_options!
      @@options = nil
    end
  end
24 25
end

26

27 28
class ConfigurationMock < Rails::Configuration
  attr_reader :environment_path
29

30 31 32
  def initialize(envpath)
    super()
    @environment_path = envpath
33
  end
34 35 36
end

class Initializer_load_environment_Test < Test::Unit::TestCase
37 38
  def test_load_environment_with_constant
    config = ConfigurationMock.new("#{File.dirname(__FILE__)}/fixtures/environment_with_constant.rb")
39
    assert_nil $initialize_test_set_from_env
40
    Rails::Initializer.run(:load_environment, config)
41
    assert_equal "success", $initialize_test_set_from_env
42
  ensure
43
    $initialize_test_set_from_env = nil
44
  end
45 46
end

47 48 49 50 51 52
class Initializer_eager_loading_Test < Test::Unit::TestCase
  def setup
    @config = ConfigurationMock.new("")
    @config.cache_classes = true
    @config.load_paths = [File.expand_path(File.dirname(__FILE__) + "/fixtures/eager")]
    @config.eager_load_paths = [File.expand_path(File.dirname(__FILE__) + "/fixtures/eager")]
53 54 55 56
    @initializer = Rails::Initializer.default
    @initializer.config = @config
    @initializer.run(:set_load_path)
    @initializer.run(:set_autoload_paths)
57 58 59 60
  end

  def test_eager_loading_loads_parent_classes_before_children
    assert_nothing_raised do
61
      @initializer.run(:load_application_classes)
62 63 64 65
    end
  end
end

66 67 68 69 70
class Initializer_after_initialize_with_blocks_environment_Test < Test::Unit::TestCase
  def setup
    config = ConfigurationMock.new("")
    config.after_initialize do
      $test_after_initialize_block1 = "success"
71
    end
72 73
    config.after_initialize do
      $test_after_initialize_block2 = "congratulations"
74
    end
75 76
    assert_nil $test_after_initialize_block1
    assert_nil $test_after_initialize_block2
77

78
    config.expects(:gems_dependencies_loaded).returns(true)
79 80
    Rails::Initializer.run(:after_initialize, config)
  end
81

82 83 84
  def teardown
    $test_after_initialize_block1 = nil
    $test_after_initialize_block2 = nil
85 86
  end

87 88 89
  def test_should_have_called_the_first_after_initialize_block
    assert_equal "success", $test_after_initialize_block1
  end
90

91 92 93 94
  def test_should_have_called_the_second_after_initialize_block
    assert_equal "congratulations", $test_after_initialize_block2
  end
end
95

96 97 98 99 100
class Initializer_after_initialize_with_no_block_environment_Test < Test::Unit::TestCase
  def setup
    config = ConfigurationMock.new("")
    config.after_initialize do
      $test_after_initialize_block1 = "success"
101
    end
102 103 104
    config.after_initialize # don't pass a block, this is what we're testing!
    config.after_initialize do
      $test_after_initialize_block2 = "congratulations"
105
    end
106
    assert_nil $test_after_initialize_block1
107

108
    config.expects(:gems_dependencies_loaded).returns(true)
109
    Rails::Initializer.run(:after_initialize, config)
110
  end
111

112 113 114 115
  def teardown
    $test_after_initialize_block1 = nil
    $test_after_initialize_block2 = nil
  end
116

117 118 119
  def test_should_have_called_the_first_after_initialize_block
    assert_equal "success", $test_after_initialize_block1, "should still get set"
  end
120

121 122
  def test_should_have_called_the_second_after_initialize_block
    assert_equal "congratulations", $test_after_initialize_block2
123
  end
124
end
125

126 127 128 129
class ConfigurationFrameworkPathsTests < Test::Unit::TestCase
  def setup
    @config = Rails::Configuration.new
    @config.frameworks.clear
130 131
    @initializer = Rails::Initializer.default
    @initializer.config = @config
132

133
    File.stubs(:directory?).returns(true)
134
    Rails::Initializer.run(:set_root_path, @config)
135
  end
136

137
  def test_minimal
138 139
    expected = %w(railties railties/lib activesupport/lib)
    assert_equal expected.map {|e| "#{@config.framework_root_path}/#{e}"}, @config.framework_paths
140
  end
141

142 143
  def test_actioncontroller_or_actionview_add_actionpack
    @config.frameworks << :action_controller
144
    assert_framework_path "actionpack/lib"
145

146
    @config.frameworks = [:action_view]
147
    assert_framework_path 'actionpack/lib'
148
  end
149

150 151 152
  def test_paths_for_ar_ares_and_mailer
    [:active_record, :action_mailer, :active_resource, :action_web_service].each do |framework|
      @config.frameworks = [framework]
153
      assert_framework_path "#{framework.to_s.gsub('_', '')}/lib"
154
    end
155
  end
156

157 158
  def test_unknown_framework_raises_error
    @config.frameworks << :action_foo
159 160

    Class.any_instance.expects(:require).raises(LoadError)
161

162
    assert_raise RuntimeError do
163
      @initializer.run(:require_frameworks)
164
    end
165
  end
166

167 168
  def test_action_mailer_load_paths_set_only_if_action_mailer_in_use
    @config.frameworks = [:action_controller]
169 170
    @initializer.config = @config
    @initializer.run :require_frameworks
171

172
    assert_nothing_raised NameError do
173
      @initializer.run :load_view_paths
174
    end
175 176
  end

177 178
  def test_action_controller_load_paths_set_only_if_action_controller_in_use
    @config.frameworks = []
179
    @initializer.run :require_frameworks
180

181
    assert_nothing_raised NameError do
182
      @initializer.run :load_view_paths
183
    end
184
  end
185

186 187
  protected
    def assert_framework_path(path)
188
      assert @config.framework_paths.include?("#{@config.framework_root_path}/#{path}"),
189
        "<#{path.inspect}> not found among <#{@config.framework_paths.inspect}>"
190
    end
191
end
192

193
require 'plugin_test_helper'
194

195 196 197
class InitializerPluginLoadingTests < Test::Unit::TestCase
  def setup
    @configuration     = Rails::Configuration.new
198
    @configuration.frameworks -= [:action_mailer]
199
    @configuration.plugin_paths << plugin_fixture_root_path
200 201
    @initializer       = Rails::Initializer.default
    @initializer.config = @configuration
202 203 204
    @valid_plugin_path = plugin_fixture_path('default/stubby')
    @empty_plugin_path = plugin_fixture_path('default/empty')
  end
205

206 207
  def test_no_plugins_are_loaded_if_the_configuration_has_an_empty_plugin_list
    only_load_the_following_plugins! []
208
    @initializer.run :load_plugins
209
    assert_equal [], @configuration.loaded_plugins
210
  end
211

212 213 214 215
  def test_only_the_specified_plugins_are_located_in_the_order_listed
    plugin_names = [:plugin_with_no_lib_dir, :acts_as_chunky_bacon]
    only_load_the_following_plugins! plugin_names
    load_plugins!
216
    assert_plugins plugin_names, @configuration.loaded_plugins
217
  end
218

219 220 221
  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!
222
    assert_plugins [:a, :acts_as_chunky_bacon, :engine, :gemlike, :plugin_with_no_lib_dir, :stubby], @configuration.loaded_plugins, failure_tip
223
  end
224

225 226 227 228 229
  def test_all_plugins_loaded_when_all_is_used
    plugin_names = [:stubby, :acts_as_chunky_bacon, :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"
230
    assert_plugins [:stubby, :acts_as_chunky_bacon, :a, :engine, :gemlike, :plugin_with_no_lib_dir], @configuration.loaded_plugins, failure_tip
231
  end
232

233 234 235 236 237
  def test_all_plugins_loaded_after_all
    plugin_names = [:stubby, :all, :acts_as_chunky_bacon]
    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"
238
    assert_plugins [:stubby, :a, :engine, :gemlike, :plugin_with_no_lib_dir, :acts_as_chunky_bacon], @configuration.loaded_plugins, failure_tip
239
  end
240

241 242 243 244 245
  def test_plugin_names_may_be_strings
    plugin_names = ['stubby', 'acts_as_chunky_bacon', :a, :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"
246
    assert_plugins plugin_names, @configuration.loaded_plugins, failure_tip
247
  end
248

249 250
  def test_registering_a_plugin_name_that_does_not_exist_raises_a_load_error
    only_load_the_following_plugins! [:stubby, :acts_as_a_non_existant_plugin]
251
    assert_raise(LoadError) do
252 253
      load_plugins!
    end
254
  end
255

256 257 258 259 260 261 262 263 264
  def test_load_error_messages_mention_missing_plugins_and_no_others
    valid_plugin_names = [:stubby, :acts_as_chunky_bacon]
    invalid_plugin_names = [:non_existant_plugin1, :non_existant_plugin2]
    only_load_the_following_plugins!( valid_plugin_names + invalid_plugin_names )
    begin
      load_plugins!
      flunk "Expected a LoadError but did not get one"
    rescue LoadError => e
      failure_tip = "It's likely someone renamed or deleted plugin fixtures without updating this test"
265
      assert_plugins valid_plugin_names, @configuration.loaded_plugins, failure_tip
266 267 268 269 270
      invalid_plugin_names.each do |plugin|
        assert_match(/#{plugin.to_s}/, e.message, "LoadError message should mention plugin '#{plugin}'")
      end
      valid_plugin_names.each do |plugin|
        assert_no_match(/#{plugin.to_s}/, e.message, "LoadError message should not mention '#{plugin}'")
271
      end
272

273
    end
274
  end
275

276 277
  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]
278

279
    @initializer.run(:add_plugin_load_paths)
280

281 282
    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'))
283
  end
284

285 286 287
  private

    def load_plugins!
288 289
      @initializer.run(:add_plugin_load_paths)
      @initializer.run(:load_plugins)
290
    end
291
end
292

293
class InitializerGeneratorsTests < Test::Unit::TestCase
294 295 296 297 298 299 300 301 302 303 304

  def setup
    @configuration = Rails::Configuration.new
    @initializer   = Rails::Initializer.default
    @initializer.config = @configuration
  end

  def test_generators_default_values
    assert_equal(true, @configuration.generators.colorize_logging)
    assert_equal({}, @configuration.generators.aliases)
    assert_equal({}, @configuration.generators.options)
305 306 307
  end

  def test_generators_set_options
308 309 310
    @configuration.generators.orm = :datamapper
    @configuration.generators.test_framework = :rspec
    assert_equal({ :orm => :datamapper, :test_framework => :rspec }, @configuration.generators.options)
311 312 313
  end

  def test_generators_set_aliases
314 315
    @configuration.generators.aliases = { :test_framework => "-w" }
    assert_equal({ :test_framework => "-w" }, @configuration.generators.aliases)
316 317 318
  end

  def test_generators_with_block
319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347
    @configuration.generators do |g|
      g.orm = :datamapper
      g.test_framework = :rspec
    end
    assert_equal({ :orm => :datamapper, :test_framework => :rspec }, @configuration.generators.options)
  end

  def test_generators_aliases_and_options_on_initialization
    @configuration.generators.aliases = { :test_framework => "-w" }
    @configuration.generators.orm = :datamapper
    @configuration.generators.test_framework = :rspec

    RAILS_ENV.replace "generators"
    @initializer.run(:initialize_generators)

    assert_equal :rspec, Rails::Generators.options[:test_framework]
    assert_equal "-w", Rails::Generators.aliases[:test_framework]
  end

  def test_generators_no_color_on_initialization
    @configuration.generators.colorize_logging = false
    RAILS_ENV.replace "generators"
    @initializer.run(:initialize_generators)
    assert_equal Thor::Base.shell, Thor::Shell::Basic
  end

  def test_generators_raise_no_method_error_non_setters
    assert_raise NoMethodError do
      @configuration.generators.foo
348 349
    end
  end
350 351 352 353 354 355 356

  protected

    def teardown
      Rails::Generators.clear_aliases!
      Rails::Generators.clear_options!
    end
357 358
end

359 360 361 362 363
class InitializerSetupI18nTests < Test::Unit::TestCase
  def test_no_config_locales_dir_present_should_return_empty_load_path
    File.stubs(:exist?).returns(false)
    assert_equal [], Rails::Configuration.new.i18n.load_path
  end
364

365 366 367 368 369
  def test_config_locales_dir_present_should_be_added_to_load_path
    File.stubs(:exist?).returns(true)
    Dir.stubs(:[]).returns([ "my/test/locale.yml" ])
    assert_equal [ "my/test/locale.yml" ], Rails::Configuration.new.i18n.load_path
  end
370

371 372 373
  def test_config_defaults_should_be_added_with_config_settings
    File.stubs(:exist?).returns(true)
    Dir.stubs(:[]).returns([ "my/test/locale.yml" ])
374

375 376 377 378 379
    config = Rails::Configuration.new
    config.i18n.load_path << "my/other/locale.yml"

    assert_equal [ "my/test/locale.yml", "my/other/locale.yml" ], config.i18n.load_path
  end
380

381 382 383 384 385 386 387 388
  def test_config_defaults_and_settings_should_be_added_to_i18n_defaults
    File.stubs(:exist?).returns(true)
    Dir.stubs(:[]).returns([ "my/test/locale.yml" ])

    config = Rails::Configuration.new
    config.i18n.load_path << "my/other/locale.yml"

    Rails::Initializer.run(:initialize_i18n, config)
389
    assert_equal [
390 391
     File.expand_path(File.dirname(__FILE__) + "/../../activesupport/lib/active_support/locale/en.yml"),
     File.expand_path(File.dirname(__FILE__) + "/../../actionpack/lib/action_view/locale/en.yml"),
J
Jeremy Kemper 已提交
392
     File.expand_path(File.dirname(__FILE__) + "/../../activemodel/lib/active_model/locale/en.yml"),
393
     File.expand_path(File.dirname(__FILE__) + "/../../activerecord/lib/active_record/locale/en.yml"),
394
     "my/test/locale.yml",
395
     "my/other/locale.yml" ], I18n.load_path.collect { |path| path =~ /\.\./ ? File.expand_path(path) : path }
396
  end
397

398 399 400 401 402
  def test_setting_another_default_locale
    config = Rails::Configuration.new
    config.i18n.default_locale = :de
    Rails::Initializer.run(:initialize_i18n, config)
    assert_equal :de, I18n.default_locale
403
  end
404
end
405

406 407 408 409 410
class InitializerDatabaseMiddlewareTest < Test::Unit::TestCase
  def setup
    @config = Rails::Configuration.new
    @config.frameworks = [:active_record, :action_controller, :action_view]
  end
411

412
  def test_initialize_database_middleware_doesnt_perform_anything_when_active_record_not_in_frameworks
413 414 415 416
    @config.frameworks.clear
    @config.expects(:middleware).never
    Rails::Initializer.run(:initialize_database_middleware, @config)
  end
417

418 419 420
  def test_database_middleware_initializes_when_session_store_is_active_record
    store = ActionController::Base.session_store
    ActionController::Base.session_store = ActiveRecord::SessionStore
421

422 423 424 425 426 427 428 429 430 431
    @config.middleware.expects(:insert_before).with(:"ActiveRecord::SessionStore", ActiveRecord::ConnectionAdapters::ConnectionManagement)
    @config.middleware.expects(:insert_before).with(:"ActiveRecord::SessionStore", ActiveRecord::QueryCache)

    Rails::Initializer.run(:initialize_database_middleware, @config)
  ensure
    ActionController::Base.session_store = store
  end

  def test_database_middleware_doesnt_initialize_when_session_store_is_not_active_record
    store = ActionController::Base.session_store
432
    ActionController::Base.session_store = ActionDispatch::Session::CookieStore
433 434 435 436 437 438 439 440 441

    # Define the class, so we don't have to actually make it load
    eval("class ActiveRecord::ConnectionAdapters::ConnectionManagement; end")

    @config.middleware.expects(:use).with(ActiveRecord::ConnectionAdapters::ConnectionManagement)
    @config.middleware.expects(:use).with(ActiveRecord::QueryCache)

    Rails::Initializer.run(:initialize_database_middleware, @config)
  ensure
442 443
    ActionController::Base.session_store = store
  end
444 445 446 447 448 449 450 451 452 453 454 455 456 457

  def test_ensure_database_middleware_doesnt_use_action_controller_on_initializing
    @config.frameworks -= [:action_controller]
    store = ActionController::Base.session_store
    ActionController::Base.session_store = ActiveRecord::SessionStore

    @config.middleware.expects(:use).with(ActiveRecord::ConnectionAdapters::ConnectionManagement)
    @config.middleware.expects(:use).with(ActiveRecord::QueryCache)

    Rails::Initializer.run(:initialize_database_middleware, @config)
  ensure
    ActionController::Base.session_store = store
    @config.frameworks += [:action_controller]
  end
458 459 460 461 462 463
end

class InitializerViewPathsTest  < Test::Unit::TestCase
  def setup
    @config = Rails::Configuration.new
    @config.frameworks = [:action_view, :action_controller, :action_mailer]
464

465 466 467
    ActionController::Base.stubs(:view_paths).returns(stub)
    ActionMailer::Base.stubs(:view_paths).returns(stub)
  end
468

469 470 471 472 473
  def test_load_view_paths_doesnt_perform_anything_when_action_view_not_in_frameworks
    @config.frameworks -= [:action_view]
    ActionController::Base.view_paths.expects(:load!).never
    ActionMailer::Base.view_paths.expects(:load!).never
    Rails::Initializer.run(:load_view_paths, @config)
474
  end
475
end
476 477 478

class RailsRootTest < Test::Unit::TestCase
  def test_rails_dot_root_equals_rails_root
J
Joshua Peek 已提交
479
    assert_equal RAILS_ROOT, Rails.root.to_s
480 481
  end

482
  def test_rails_dot_root_should_be_a_pathname
J
Joshua Peek 已提交
483
    assert_equal File.join(RAILS_ROOT, 'app', 'controllers'), Rails.root.join('app', 'controllers').to_s
484
  end
485 486
end