Module: ActionDispatch::Integration::RequestHelpers
- Included in:
- Session
- Defined in:
- lib/action_dispatch/testing/integration.rb
Instance Method Summary collapse
-
#delete(path, **args) ⇒ Object
Performs a DELETE request with the given parameters.
-
#follow_redirect!(headers: {}, **args) ⇒ Object
Follow a single redirect response.
-
#get(path, **args) ⇒ Object
Performs a GET request with the given parameters.
-
#head(path, **args) ⇒ Object
Performs a HEAD request with the given parameters.
-
#options(path, **args) ⇒ Object
Performs an OPTIONS request with the given parameters.
-
#patch(path, **args) ⇒ Object
Performs a PATCH request with the given parameters.
-
#post(path, **args) ⇒ Object
Performs a POST request with the given parameters.
-
#put(path, **args) ⇒ Object
Performs a PUT request with the given parameters.
Instance Method Details
#delete(path, **args) ⇒ Object
Performs a DELETE request with the given parameters. See ActionDispatch::Integration::Session#process for more details.
42 43 44 |
# File 'lib/action_dispatch/testing/integration.rb', line 42 def delete(path, **args) process(:delete, path, **args) end |
#follow_redirect!(headers: {}, **args) ⇒ Object
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.
65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 |
# File 'lib/action_dispatch/testing/integration.rb', line 65 def follow_redirect!(headers: {}, **args) raise "not a redirect! #{status} #{}" 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 |
#get(path, **args) ⇒ Object
Performs a GET request with the given parameters. See ActionDispatch::Integration::Session#process for more details.
18 19 20 |
# File 'lib/action_dispatch/testing/integration.rb', line 18 def get(path, **args) process(:get, path, **args) end |
#head(path, **args) ⇒ Object
Performs a HEAD request with the given parameters. See ActionDispatch::Integration::Session#process for more details.
48 49 50 |
# File 'lib/action_dispatch/testing/integration.rb', line 48 def head(path, **args) process(:head, path, **args) end |
#options(path, **args) ⇒ Object
Performs an OPTIONS request with the given parameters. See ActionDispatch::Integration::Session#process for more details.
54 55 56 |
# File 'lib/action_dispatch/testing/integration.rb', line 54 def (path, **args) process(:options, path, **args) end |
#patch(path, **args) ⇒ Object
Performs a PATCH request with the given parameters. See ActionDispatch::Integration::Session#process for more details.
30 31 32 |
# File 'lib/action_dispatch/testing/integration.rb', line 30 def patch(path, **args) process(:patch, path, **args) end |
#post(path, **args) ⇒ Object
Performs a POST request with the given parameters. See ActionDispatch::Integration::Session#process for more details.
24 25 26 |
# File 'lib/action_dispatch/testing/integration.rb', line 24 def post(path, **args) process(:post, path, **args) end |
#put(path, **args) ⇒ Object
Performs a PUT request with the given parameters. See ActionDispatch::Integration::Session#process for more details.
36 37 38 |
# File 'lib/action_dispatch/testing/integration.rb', line 36 def put(path, **args) process(:put, path, **args) end |