diff options
| author | Ryan Bigg <radarlistener@gmail.com> | 2008-10-06 11:57:12 +1030 | 
|---|---|---|
| committer | Ryan Bigg <radarlistener@gmail.com> | 2008-10-06 11:57:12 +1030 | 
| commit | a21d8f632fe8aa3bf4c1b83accc7a2dd230c28e7 (patch) | |
| tree | bb0b0e9423d4e259de6041e661bba119f7871faa /actionpack/lib/action_controller | |
| parent | b340337aaff5b59fdf2110207fec3e1c43f1380a (diff) | |
| parent | 6090513cfb8acb5554a6653a6f2cb87648585d41 (diff) | |
| download | rails-a21d8f632fe8aa3bf4c1b83accc7a2dd230c28e7.tar.gz rails-a21d8f632fe8aa3bf4c1b83accc7a2dd230c28e7.tar.bz2 rails-a21d8f632fe8aa3bf4c1b83accc7a2dd230c28e7.zip | |
Merge branch 'master' of git@github.com:lifo/docrails
Diffstat (limited to 'actionpack/lib/action_controller')
| -rw-r--r-- | actionpack/lib/action_controller/base.rb | 19 | ||||
| -rw-r--r-- | actionpack/lib/action_controller/dispatcher.rb | 30 | ||||
| -rw-r--r-- | actionpack/lib/action_controller/integration.rb | 2 | ||||
| -rwxr-xr-x | actionpack/lib/action_controller/request.rb | 5 | ||||
| -rw-r--r-- | actionpack/lib/action_controller/rescue.rb | 130 | ||||
| -rw-r--r-- | actionpack/lib/action_controller/test_case.rb | 2 | 
6 files changed, 57 insertions, 131 deletions
| diff --git a/actionpack/lib/action_controller/base.rb b/actionpack/lib/action_controller/base.rb index 91f531f12c..413f6d48e5 100644 --- a/actionpack/lib/action_controller/base.rb +++ b/actionpack/lib/action_controller/base.rb @@ -290,8 +290,6 @@ module ActionController #:nodoc:      @@allow_concurrency = false      cattr_accessor :allow_concurrency -    @@guard = Monitor.new -      # Modern REST web services often need to submit complex data to the web application.      # The <tt>@@param_parsers</tt> hash lets you register handlers which will process the HTTP body and add parameters to the      # <tt>params</tt> hash. These handlers are invoked for POST and PUT requests. @@ -532,12 +530,7 @@ module ActionController #:nodoc:          assign_names          log_processing - -        if @@allow_concurrency -          send(method, *arguments) -        else -          @@guard.synchronize { send(method, *arguments) } -        end +        send(method, *arguments)          send_response        ensure @@ -975,13 +968,15 @@ module ActionController #:nodoc:        # Sets the Last-Modified response header. Returns 304 Not Modified if the        # If-Modified-Since request header is <= last modified.        def last_modified!(utc_time) -        head(:not_modified) if response.last_modified!(utc_time) +        response.last_modified= utc_time +        head(:not_modified) if response.last_modified == request.if_modified_since        end        # Sets the ETag response header. Returns 304 Not Modified if the        # If-None-Match request header matches.        def etag!(etag) -        head(:not_modified) if response.etag!(etag) +        response.etag = etag +        head(:not_modified) if response.etag == request.if_none_match        end        # Clears the rendered results, allowing for another render to be performed. @@ -1256,7 +1251,7 @@ module ActionController #:nodoc:              action_name = strip_out_controller(action_name)            end          end -        "#{self.class.controller_path}/#{action_name}" +        "#{self.controller_path}/#{action_name}"        end        def strip_out_controller(path) @@ -1264,7 +1259,7 @@ module ActionController #:nodoc:        end        def template_path_includes_controller?(path) -        self.class.controller_path.split('/')[-1] == path.split('/')[0] +        self.controller_path.split('/')[-1] == path.split('/')[0]        end        def process_cleanup diff --git a/actionpack/lib/action_controller/dispatcher.rb b/actionpack/lib/action_controller/dispatcher.rb index bdae5f9d86..90c8400c11 100644 --- a/actionpack/lib/action_controller/dispatcher.rb +++ b/actionpack/lib/action_controller/dispatcher.rb @@ -2,6 +2,8 @@ module ActionController    # Dispatches requests to the appropriate controller and takes care of    # reloading the app after each request when Dependencies.load? is true.    class Dispatcher +    @@guard = Mutex.new +      class << self        def define_dispatcher_callbacks(cache_classes)          unless cache_classes @@ -20,6 +22,7 @@ module ActionController          end          if defined?(ActiveRecord) +          after_dispatch :checkin_connections            before_dispatch { ActiveRecord::Base.verify_active_connections! }            to_prepare(:activerecord_instantiate_observers) { ActiveRecord::Base.instantiate_observers }          end @@ -98,7 +101,7 @@ module ActionController        @output, @request, @response = output, request, response      end -    def dispatch +    def dispatch_unlocked        begin          run_callbacks :before_dispatch          handle_request @@ -109,6 +112,16 @@ module ActionController        end      end +    def dispatch +      if ActionController::Base.allow_concurrency +        dispatch_unlocked +      else +        @@guard.synchronize do +          dispatch_unlocked +        end +      end +    end +      def dispatch_cgi(cgi, session_options)        if cgi ||= self.class.failsafe_response(@output, '400 Bad Request') { CGI.new }          @request = CgiRequest.new(cgi, session_options) @@ -145,6 +158,21 @@ module ActionController        Base.logger.flush      end +    def mark_as_test_request! +      @test_request = true +      self +    end + +    def test_request? +      @test_request +    end + +    def checkin_connections +      # Don't return connection (and peform implicit rollback) if this request is a part of integration test +      return if test_request? +      ActiveRecord::Base.clear_active_connections! +    end +      protected        def handle_request          @controller = Routing::Routes.recognize(@request) diff --git a/actionpack/lib/action_controller/integration.rb b/actionpack/lib/action_controller/integration.rb index a98c1af7f9..fc473c269c 100644 --- a/actionpack/lib/action_controller/integration.rb +++ b/actionpack/lib/action_controller/integration.rb @@ -276,7 +276,7 @@ module ActionController            ActionController::Base.clear_last_instantiation!            env['rack.input'] = data.is_a?(IO) ? data : StringIO.new(data || '') -          @status, @headers, result_body = ActionController::Dispatcher.new.call(env) +          @status, @headers, result_body = ActionController::Dispatcher.new.mark_as_test_request!.call(env)            @request_count += 1            @controller = ActionController::Base.last_instantiation diff --git a/actionpack/lib/action_controller/request.rb b/actionpack/lib/action_controller/request.rb index 8e6cfb41dc..5e492e3ee1 100755 --- a/actionpack/lib/action_controller/request.rb +++ b/actionpack/lib/action_controller/request.rb @@ -167,7 +167,7 @@ module ActionController        parameter_format = parameters[:format]        if parameter_format -        parameter_format.to_sym +        parameter_format        elsif xhr?          :js        else @@ -176,8 +176,7 @@ module ActionController      end      def cache_format -      parameter_format = parameters[:format] -      parameter_format && parameter_format.to_sym +      parameters[:format]      end      # Returns true if the request's "X-Requested-With" header contains diff --git a/actionpack/lib/action_controller/rescue.rb b/actionpack/lib/action_controller/rescue.rb index 83c4218af4..ec8e9b92d5 100644 --- a/actionpack/lib/action_controller/rescue.rb +++ b/actionpack/lib/action_controller/rescue.rb @@ -41,10 +41,9 @@ module ActionController #:nodoc:        base.rescue_templates = Hash.new(DEFAULT_RESCUE_TEMPLATE)        base.rescue_templates.update DEFAULT_RESCUE_TEMPLATES -      base.class_inheritable_array :rescue_handlers -      base.rescue_handlers = [] -        base.extend(ClassMethods) +      base.send :include, ActiveSupport::Rescuable +        base.class_eval do          alias_method_chain :perform_action, :rescue        end @@ -54,82 +53,12 @@ module ActionController #:nodoc:        def process_with_exception(request, response, exception) #:nodoc:          new.process(request, response, :rescue_action, exception)        end - -      # Rescue exceptions raised in controller actions. -      # -      # <tt>rescue_from</tt> receives a series of exception classes or class -      # names, and a trailing <tt>:with</tt> option with the name of a method -      # or a Proc object to be called to handle them. Alternatively a block can -      # be given. -      # -      # Handlers that take one argument will be called with the exception, so -      # that the exception can be inspected when dealing with it. -      # -      # Handlers are inherited. They are searched from right to left, from -      # bottom to top, and up the hierarchy. The handler of the first class for -      # which <tt>exception.is_a?(klass)</tt> holds true is the one invoked, if -      # any. -      # -      #   class ApplicationController < ActionController::Base -      #     rescue_from User::NotAuthorized, :with => :deny_access # self defined exception -      #     rescue_from ActiveRecord::RecordInvalid, :with => :show_errors -      # -      #     rescue_from 'MyAppError::Base' do |exception| -      #       render :xml => exception, :status => 500 -      #     end -      # -      #     protected -      #       def deny_access -      #         ... -      #       end -      # -      #       def show_errors(exception) -      #         exception.record.new_record? ? ... -      #       end -      #   end -      def rescue_from(*klasses, &block) -        options = klasses.extract_options! -        unless options.has_key?(:with) -          block_given? ? options[:with] = block : raise(ArgumentError, "Need a handler. Supply an options hash that has a :with key as the last argument.") -        end - -        klasses.each do |klass| -          key = if klass.is_a?(Class) && klass <= Exception -            klass.name -          elsif klass.is_a?(String) -            klass -          else -            raise(ArgumentError, "#{klass} is neither an Exception nor a String") -          end - -          # Order is important, we put the pair at the end. When dealing with an -          # exception we will follow the documented order going from right to left. -          rescue_handlers << [key, options[:with]] -        end -      end      end      protected        # Exception handler called when the performance of an action raises an exception.        def rescue_action(exception) -        if handler_for_rescue(exception) -          rescue_action_with_handler(exception) -        else -          log_error(exception) if logger -          erase_results if performed? - -          # Let the exception alter the response if it wants. -          # For example, MethodNotAllowed sets the Allow header. -          if exception.respond_to?(:handle_response!) -            exception.handle_response!(response) -          end - -          if consider_all_requests_local || local_request? -            rescue_action_locally(exception) -          else -            rescue_action_in_public(exception) -          end -        end +        rescue_with_handler(exception) || rescue_action_without_handler(exception)        end        # Overwrite to implement custom logging of errors. By default logs as fatal. @@ -185,15 +114,20 @@ module ActionController #:nodoc:          render_for_file(rescues_path("layout"), response_code_for_rescue(exception))        end -      # Tries to rescue the exception by looking up and calling a registered handler. -      def rescue_action_with_handler(exception) -        if handler = handler_for_rescue(exception) -          if handler.arity != 0 -            handler.call(exception) -          else -            handler.call -          end -          true # don't rely on the return value of the handler +      def rescue_action_without_handler(exception) +        log_error(exception) if logger +        erase_results if performed? + +        # Let the exception alter the response if it wants. +        # For example, MethodNotAllowed sets the Allow header. +        if exception.respond_to?(:handle_response!) +          exception.handle_response!(response) +        end + +        if consider_all_requests_local || local_request? +          rescue_action_locally(exception) +        else +          rescue_action_in_public(exception)          end        end @@ -216,36 +150,6 @@ module ActionController #:nodoc:          rescue_responses[exception.class.name]        end -      def handler_for_rescue(exception) -        # We go from right to left because pairs are pushed onto rescue_handlers -        # as rescue_from declarations are found. -        _, handler = *rescue_handlers.reverse.detect do |klass_name, handler| -          # The purpose of allowing strings in rescue_from is to support the -          # declaration of handler associations for exception classes whose -          # definition is yet unknown. -          # -          # Since this loop needs the constants it would be inconsistent to -          # assume they should exist at this point. An early raised exception -          # could trigger some other handler and the array could include -          # precisely a string whose corresponding constant has not yet been -          # seen. This is why we are tolerant to unknown constants. -          # -          # Note that this tolerance only matters if the exception was given as -          # a string, otherwise a NameError will be raised by the interpreter -          # itself when rescue_from CONSTANT is executed. -          klass = self.class.const_get(klass_name) rescue nil -          klass ||= klass_name.constantize rescue nil -          exception.is_a?(klass) if klass -        end - -        case handler -        when Symbol -          method(handler) -        when Proc -          handler.bind(self) -        end -      end -        def clean_backtrace(exception)          if backtrace = exception.backtrace            if defined?(RAILS_ROOT) diff --git a/actionpack/lib/action_controller/test_case.rb b/actionpack/lib/action_controller/test_case.rb index 3e66947d5f..6a39039504 100644 --- a/actionpack/lib/action_controller/test_case.rb +++ b/actionpack/lib/action_controller/test_case.rb @@ -84,7 +84,7 @@ module ActionController      module RaiseActionExceptions        attr_accessor :exception -      def rescue_action(e) +      def rescue_action_without_handler(e)          self.exception = e          if request.remote_addr == "0.0.0.0" | 
