diff options
Diffstat (limited to 'actionpack/lib/action_dispatch/testing')
7 files changed, 42 insertions, 46 deletions
| diff --git a/actionpack/lib/action_dispatch/testing/assertions.rb b/actionpack/lib/action_dispatch/testing/assertions.rb index 21b3b89d22..715d94d406 100644 --- a/actionpack/lib/action_dispatch/testing/assertions.rb +++ b/actionpack/lib/action_dispatch/testing/assertions.rb @@ -12,7 +12,7 @@ module ActionDispatch      include Rails::Dom::Testing::Assertions      def html_document -      @html_document ||= if @response.content_type === Mime::XML +      @html_document ||= if @response.content_type.to_s =~ /xml$/          Nokogiri::XML::Document.parse(@response.body)        else          Nokogiri::HTML::Document.parse(@response.body) diff --git a/actionpack/lib/action_dispatch/testing/assertions/response.rb b/actionpack/lib/action_dispatch/testing/assertions/response.rb index 13a72220b3..b6e21b0d28 100644 --- a/actionpack/lib/action_dispatch/testing/assertions/response.rb +++ b/actionpack/lib/action_dispatch/testing/assertions/response.rb @@ -3,6 +3,13 @@ module ActionDispatch    module Assertions      # A small suite of assertions that test responses from \Rails applications.      module ResponseAssertions +      RESPONSE_PREDICATES = { # :nodoc: +        success:  :successful?, +        missing:  :not_found?, +        redirect: :redirection?, +        error:    :server_error?, +      } +        # Asserts that the response is one of the following types:        #        # * <tt>:success</tt>   - Status code was in the 200-299 range @@ -20,11 +27,9 @@ module ActionDispatch        #   # assert that the response code was status code 401 (unauthorized)        #   assert_response 401        def assert_response(type, message = nil) -        message ||= "Expected response to be a <#{type}>, but was <#{@response.response_code}>" -          if Symbol === type            if [:success, :missing, :redirect, :error].include?(type) -            assert @response.send("#{type}?"), message +            assert_predicate @response, RESPONSE_PREDICATES[type], message            else              code = Rack::Utils::SYMBOL_TO_STATUS_CODE[type]              if code.nil? diff --git a/actionpack/lib/action_dispatch/testing/assertions/routing.rb b/actionpack/lib/action_dispatch/testing/assertions/routing.rb index c94eea9134..54e24ed6bf 100644 --- a/actionpack/lib/action_dispatch/testing/assertions/routing.rb +++ b/actionpack/lib/action_dispatch/testing/assertions/routing.rb @@ -86,8 +86,8 @@ module ActionDispatch          end          # Load routes.rb if it hasn't been loaded. -        generated_path, extra_keys = @routes.generate_extras(options, defaults) -        found_extras = options.reject { |k, _| ! extra_keys.include? k } +        generated_path, query_string_keys = @routes.generate_extras(options, defaults) +        found_extras = options.reject { |k, _| ! query_string_keys.include? k }          msg = message || sprintf("found extras <%s>, not <%s>", found_extras, extras)          assert_equal(extras, found_extras, msg) @@ -165,7 +165,7 @@ module ActionDispatch        # ROUTES TODO: These assertions should really work in an integration context        def method_missing(selector, *args, &block) -        if defined?(@controller) && @controller && @routes && @routes.named_routes.route_defined?(selector) +        if defined?(@controller) && @controller && defined?(@routes) && @routes && @routes.named_routes.route_defined?(selector)            @controller.send(selector, *args, &block)          else            super @@ -183,7 +183,7 @@ module ActionDispatch            end            # Assume given controller -          request = ActionController::TestRequest.new +          request = ActionController::TestRequest.create            if path =~ %r{://}              fail_on(URI::InvalidURIError, msg) do diff --git a/actionpack/lib/action_dispatch/testing/integration.rb b/actionpack/lib/action_dispatch/testing/integration.rb index b1bd6ae6d5..7e59bb68cf 100644 --- a/actionpack/lib/action_dispatch/testing/integration.rb +++ b/actionpack/lib/action_dispatch/testing/integration.rb @@ -294,7 +294,7 @@ module ActionDispatch            if kwarg_request?(args)              process(http_method, path, *args)            else -            non_kwarg_request_warning if args.present? +            non_kwarg_request_warning if args.any?              process(http_method, path, { params: args[0], headers: args[1] })            end          end @@ -325,7 +325,11 @@ module ActionDispatch            if path =~ %r{://}              location = URI.parse(path)              https! URI::HTTPS === location if location.scheme -            host! "#{location.host}:#{location.port}" if location.host +            if url_host = location.host +              default = Rack::Request::DEFAULT_PORTS[location.scheme] +              url_host += ":#{location.port}" if default != location.port +              host! url_host +            end              path = location.query ? "#{location.path}?#{location.query}" : location.path            end @@ -350,15 +354,15 @@ module ActionDispatch            if xhr              headers ||= {}              headers['HTTP_X_REQUESTED_WITH'] = 'XMLHttpRequest' -            headers['HTTP_ACCEPT'] ||= [Mime::JS, Mime::HTML, Mime::XML, 'text/xml', Mime::ALL].join(', ') +            headers['HTTP_ACCEPT'] ||= [Mime[:js], Mime[:html], Mime[:xml], 'text/xml', '*/*'].join(', ')            end            # this modifies the passed request_env directly            if headers.present? -            Http::Headers.new(request_env).merge!(headers) +            Http::Headers.from_hash(request_env).merge!(headers)            end            if env.present? -            Http::Headers.new(request_env).merge!(env) +            Http::Headers.from_hash(request_env).merge!(env)            end            session = Rack::Test::Session.new(_mock_session) @@ -374,7 +378,7 @@ module ActionDispatch            @html_document = nil            @url_options = nil -          @controller = session.last_request.env['action_controller.instance'] +          @controller = @request.controller_instance            response.status          end @@ -391,7 +395,7 @@ module ActionDispatch        attr_reader :app -      def before_setup +      def before_setup # :nodoc:          @app = nil          @integration_session = nil          super @@ -429,7 +433,6 @@ module ActionDispatch            # reset the html_document variable, except for cookies/assigns calls            unless method == 'cookies' || method == 'assigns'              @html_document = nil -            reset_template_assertion            end            integration_session.__send__(method, *args).tap do @@ -584,7 +587,7 @@ module ActionDispatch    #       https!(false)    #       get "/articles/all"    #       assert_response :success -  #       assert assigns(:articles) +  #       assert_select 'h1', 'Articles'    #     end    #   end    # @@ -623,7 +626,7 @@ module ActionDispatch    #         def browses_site    #           get "/products/all"    #           assert_response :success -  #           assert assigns(:products) +  #           assert_select 'h1', 'Products'    #         end    #       end    # diff --git a/actionpack/lib/action_dispatch/testing/test_process.rb b/actionpack/lib/action_dispatch/testing/test_process.rb index 630e6a9b78..c28d701b48 100644 --- a/actionpack/lib/action_dispatch/testing/test_process.rb +++ b/actionpack/lib/action_dispatch/testing/test_process.rb @@ -5,9 +5,9 @@ require 'active_support/core_ext/hash/indifferent_access'  module ActionDispatch    module TestProcess      def assigns(key = nil) -      assigns = {}.with_indifferent_access -      @controller.view_assigns.each { |k, v| assigns.regular_writer(k, v) } -      key.nil? ? assigns : assigns[key] +      raise NoMethodError, +        "assigns has been extracted to a gem. To continue using it, +        add `gem 'rails-controller-testing'` to your Gemfile."      end      def session @@ -19,7 +19,7 @@ module ActionDispatch      end      def cookies -      @request.cookie_jar +      @cookie_jar ||= Cookies::CookieJar.build(@request, @request.cookies)      end      def redirect_to_url diff --git a/actionpack/lib/action_dispatch/testing/test_request.rb b/actionpack/lib/action_dispatch/testing/test_request.rb index 4b9a088265..ad1a7f7109 100644 --- a/actionpack/lib/action_dispatch/testing/test_request.rb +++ b/actionpack/lib/action_dispatch/testing/test_request.rb @@ -4,19 +4,22 @@ require 'rack/utils'  module ActionDispatch    class TestRequest < Request      DEFAULT_ENV = Rack::MockRequest.env_for('/', -      'HTTP_HOST'       => 'test.host', -      'REMOTE_ADDR'     => '0.0.0.0', -      'HTTP_USER_AGENT' => 'Rails Testing' +      'HTTP_HOST'                => 'test.host', +      'REMOTE_ADDR'              => '0.0.0.0', +      'HTTP_USER_AGENT'          => 'Rails Testing',      ) -    def self.new(env = {}) -      super +    # Create a new test request with default `env` values +    def self.create(env = {}) +      env = Rails.application.env_config.merge(env) if defined?(Rails.application) && Rails.application +      env["rack.request.cookie_hash"] ||= {}.with_indifferent_access +      new(default_env.merge(env))      end -    def initialize(env = {}) -      env = Rails.application.env_config.merge(env) if defined?(Rails.application) && Rails.application -      super(default_env.merge(env)) +    def self.default_env +      DEFAULT_ENV      end +    private_class_method :default_env      def request_method=(method)        @env['REQUEST_METHOD'] = method.to_s.upcase @@ -62,17 +65,5 @@ module ActionDispatch        @env.delete('action_dispatch.request.accepts')        @env['HTTP_ACCEPT'] = Array(mime_types).collect(&:to_s).join(",")      end - -    alias :rack_cookies :cookies - -    def cookies -      @cookies ||= {}.with_indifferent_access -    end - -    private - -    def default_env -      DEFAULT_ENV -    end    end  end diff --git a/actionpack/lib/action_dispatch/testing/test_response.rb b/actionpack/lib/action_dispatch/testing/test_response.rb index a9b88ac5fd..4b79a90242 100644 --- a/actionpack/lib/action_dispatch/testing/test_response.rb +++ b/actionpack/lib/action_dispatch/testing/test_response.rb @@ -7,7 +7,7 @@ module ActionDispatch    # See Response for more information on controller response objects.    class TestResponse < Response      def self.from_response(response) -      new response.status, response.headers, response.body, default_headers: nil +      new response.status, response.headers, response.body      end      # Was the response successful? @@ -16,9 +16,6 @@ module ActionDispatch      # Was the URL not found?      alias_method :missing?, :not_found? -    # Were we redirected? -    alias_method :redirect?, :redirection? -      # Was there a server-side error?      alias_method :error?, :server_error?    end | 
