instance method follow_redirect!

Ruby on Rails 8.1.2

Since v3.0.20

Available in: v3.0.20 v3.1.12 v3.2.22.5 v4.0.13 v4.1.16 v4.2.9 v5.2.8.1 v6.0.6 v6.1.7.10 v7.0.10 v7.1.6 v7.2.3 v8.0.4 v8.1.2

Signature

follow_redirect!(headers: {}, **args)

Follow a single redirect response. If the last response was not a redirect, an exception will be raised. Otherwise, the redirect is performed on the location header. If the redirection is a 307 or 308 redirect, the same HTTP verb will be used when redirecting, otherwise a GET request will be performed. Any arguments are passed to the underlying request.

The HTTP_REFERER header will be set to the previous url.

Parameters

headers key = {}
args keyrest
Source
# File actionpack/lib/action_dispatch/testing/integration.rb, line 65
      def follow_redirect!(headers: {}, **args)
        raise "not a redirect! #{status} #{status_message}" unless redirect?

        method =
          if [307, 308].include?(response.status)
            request.method.downcase
          else
            :get
          end

        if [ :HTTP_REFERER, "HTTP_REFERER" ].none? { |key| headers.key? key }
          headers["HTTP_REFERER"] = request.url
        end

        public_send(method, response.location, headers: headers, **args)
        status
      end

Defined in actionpack/lib/action_dispatch/testing/integration.rb line 65 · View on GitHub · Improve this page · Find usages on GitHub

Defined in ActionDispatch::Integration::RequestHelpers

Type at least 2 characters to search.

↑↓ navigate · open · esc close