diff options
Diffstat (limited to 'actionpack')
-rwxr-xr-x | actionpack/lib/action_controller/base.rb | 2 | ||||
-rw-r--r-- | actionpack/lib/action_controller/helpers.rb | 4 | ||||
-rw-r--r-- | actionpack/test/controller/base_test.rb | 73 | ||||
-rw-r--r-- | actionpack/test/controller/benchmark_test.rb | 19 |
4 files changed, 41 insertions, 57 deletions
diff --git a/actionpack/lib/action_controller/base.rb b/actionpack/lib/action_controller/base.rb index 4551dd9f74..da27edd68c 100755 --- a/actionpack/lib/action_controller/base.rb +++ b/actionpack/lib/action_controller/base.rb @@ -324,8 +324,6 @@ module ActionController #:nodoc: unless @controller_path components = self.name.to_s.split('::') components[-1] = $1 if /^(.*)Controller$/ =~ components.last - # Accomodate the root Controllers module. - components.shift if components.first == 'Controllers' @controller_path = components.map { |name| name.underscore }.join('/') end diff --git a/actionpack/lib/action_controller/helpers.rb b/actionpack/lib/action_controller/helpers.rb index 19675605d4..e2d97b8fa0 100644 --- a/actionpack/lib/action_controller/helpers.rb +++ b/actionpack/lib/action_controller/helpers.rb @@ -109,7 +109,7 @@ module ActionController #:nodoc: private def default_helper_module! - module_name = name.sub(/^Controllers::/, '').sub(/Controller$|$/, 'Helper') + module_name = name.sub(/Controller$|$/, 'Helper') module_path = module_name.split('::').map { |m| m.underscore }.join('/') require_dependency module_path helper module_name.constantize @@ -128,7 +128,7 @@ module ActionController #:nodoc: rescue MissingSourceFile => e raise unless e.is_missing?("helpers/#{child.controller_path}_helper") end - end + end end end end diff --git a/actionpack/test/controller/base_test.rb b/actionpack/test/controller/base_test.rb index 9687aa2748..10a3e0ce35 100644 --- a/actionpack/test/controller/base_test.rb +++ b/actionpack/test/controller/base_test.rb @@ -2,68 +2,57 @@ require File.dirname(__FILE__) + '/../abstract_unit' require 'test/unit' require 'pp' # require 'pp' early to prevent hidden_methods from not picking up the pretty-print methods until too late -# This file currently contains a few controller UTs -# I couldn't find where the current base tests are, so I created this file. -# If there aren't any base-specific UTs, then this file should grow as they -# are written. If there are, or there is a better place for these, then I will -# move them to the correct location. -# -# Nicholas Seckar aka. Ulysses - -# Provide a static version of the Controllers module instead of the auto-loading version. -# We don't want these tests to fail when dependencies are to blame. -module Controllers - module Submodule - class ContainedEmptyController < ActionController::Base - end - class ContainedNonEmptyController < ActionController::Base - def public_action - end - - hide_action :hidden_action - def hidden_action - end - - def another_hidden_action - end - hide_action :another_hidden_action - end - class SubclassedController < ContainedNonEmptyController - hide_action :public_action # Hiding it here should not affect the superclass. - end - end - class EmptyController < ActionController::Base - include ActionController::Caching +# Provide some controller to run the tests on. +module Submodule + class ContainedEmptyController < ActionController::Base end - class NonEmptyController < ActionController::Base + class ContainedNonEmptyController < ActionController::Base def public_action end hide_action :hidden_action def hidden_action end + + def another_hidden_action + end + hide_action :another_hidden_action + end + class SubclassedController < ContainedNonEmptyController + hide_action :public_action # Hiding it here should not affect the superclass. + end +end +class EmptyController < ActionController::Base + include ActionController::Caching +end +class NonEmptyController < ActionController::Base + def public_action + end + + hide_action :hidden_action + def hidden_action end end class ControllerClassTests < Test::Unit::TestCase def test_controller_path - assert_equal 'empty', Controllers::EmptyController.controller_path - assert_equal 'submodule/contained_empty', Controllers::Submodule::ContainedEmptyController.controller_path + assert_equal 'empty', EmptyController.controller_path + assert_equal 'submodule/contained_empty', Submodule::ContainedEmptyController.controller_path end def test_controller_name - assert_equal 'empty', Controllers::EmptyController.controller_name - assert_equal 'contained_empty', Controllers::Submodule::ContainedEmptyController.controller_name + assert_equal 'empty', EmptyController.controller_name + assert_equal 'contained_empty', Submodule::ContainedEmptyController.controller_name end end class ControllerInstanceTests < Test::Unit::TestCase def setup - @empty = Controllers::EmptyController.new - @contained = Controllers::Submodule::ContainedEmptyController.new - @empty_controllers = [@empty, @contained, Controllers::Submodule::SubclassedController.new] + @empty = EmptyController.new + @contained = Submodule::ContainedEmptyController.new + @empty_controllers = [@empty, @contained, Submodule::SubclassedController.new] - @non_empty_controllers = [Controllers::NonEmptyController.new, - Controllers::Submodule::ContainedNonEmptyController.new] + @non_empty_controllers = [NonEmptyController.new, + Submodule::ContainedNonEmptyController.new] end def test_action_methods diff --git a/actionpack/test/controller/benchmark_test.rb b/actionpack/test/controller/benchmark_test.rb index 7e19376101..f346e575e3 100644 --- a/actionpack/test/controller/benchmark_test.rb +++ b/actionpack/test/controller/benchmark_test.rb @@ -1,17 +1,14 @@ require File.dirname(__FILE__) + '/../abstract_unit' require 'test/unit' -# Provide a static version of the Controllers module instead of the auto-loading version. -# We don't want these tests to fail when dependencies are to blame. -module Controllers - class BenchmarkedController < ActionController::Base - def public_action - render :nothing => true - end +# Provide some static controllers. +class BenchmarkedController < ActionController::Base + def public_action + render :nothing => true + end - def rescue_action(e) - raise e - end + def rescue_action(e) + raise e end end @@ -22,7 +19,7 @@ class BenchmarkTest < Test::Unit::TestCase end def setup - @controller = Controllers::BenchmarkedController.new + @controller = BenchmarkedController.new # benchmark doesn't do anything unless a logger is set @controller.logger = MockLogger.new @request, @response = ActionController::TestRequest.new, ActionController::TestResponse.new |