An instance of this class represents a set of requests and responses performed sequentially by a test process. Because you can instantiate multiple sessions and run them side-by-side, you can also mimic (to some limited extent) multiple simultaneous users interacting with your system.
Typically, you will instantiate a new session using Runner#open_session, rather than instantiating a Session directly.
- Minitest::Assertions
- ActionDispatch::Routing::UrlFor
Constants
| DEFAULT_HOST | = | "www.example.com" |
Attributes
| [RW] | accept | The Accept header to send. |
| [R] | controller | A reference to the controller instance used by the last request. |
| [W] | host | |
| [W] | host! | |
| [RW] | remote_addr | The |
| [R] | request | A reference to the request instance used by the last request. |
| [RW] | request_count | A running counter of the number of requests processed. |
| [R] | response | A reference to the response instance used by the last request. |
Class Public methods
Instance Public methods
cookies() Link
A map of the cookies returned by the last response, and which will be sent with the next request.
host() Link
The hostname used in the last request.
https!(flag = true) Link
Specify whether or not the session should mimic a secure HTTPS request.
session.https! session.https!(false)
https?() Link
Returns true if the session is mimicking a secure HTTPS request.
if session.https? # ... end
process(method, path, params: nil, headers: nil, env: nil, xhr: false, as: nil, query: nil, body: nil) Link
Performs the actual request.
-
method: The HTTP method (GET, POST, PATCH, PUT, DELETE, HEAD, OPTIONS) as a symbol. -
path: The URI (as aString) on which you want to perform the request. -
params: The HTTP parameters that you want to pass. This may benil, aHash, or aStringthat is appropriately encoded (application/x-www-form-urlencodedormultipart/form-data). For GET requests, params are sent as query string. For other methods, params are sent as the request body. Usequery:orbody:for explicit control. -
headers: Additional headers to pass, as aHash. The headers will be merged into the Rack env hash. -
env: Additional env to pass, as aHash. The headers will be merged into the Rack env hash. -
xhr: Set totrueif you want to make an Ajax request. Adds request headers characteristic ofXMLHttpRequest, e.g.HTTP_X_REQUESTED_WITH. The headers will be merged into the Rack env hash. -
as: Used for encoding the request with different content type. Supports:jsonby default and will set the appropriate request headers. The headers will be merged into the Rack env hash. -
query: Parameters to always send as URL query string, regardless of HTTP method. Accepts aHashor pre-encodedString. -
body: Parameters to always send as the request body, encoded peras:. Can be combined withquery:to send both query string and body params.
This method is rarely used directly. Use RequestHelpers#get, RequestHelpers#post, or other standard HTTP methods in integration tests. process is only required when using a request method that doesn’t have a method defined in the integration tests.
This method returns the response status, after performing the request. Furthermore, if this method was called from an ActionDispatch::IntegrationTest object, then that object’s @response instance variable will point to a ActionDispatch::TestResponse object which one can use to inspect the details of the response.
Example:
process :get, '/author', params: { since: 201501011400 } process :get, '/author', query: { since: 201501011400 }, as: :json process :post, '/search', query: { page: 1 }, body: { q: "rails" }, as: :json
# File actionpack/lib/action_dispatch/testing/integration.rb, line 235 def process(method, path, params: nil, headers: nil, env: nil, xhr: false, as: nil, query: nil, body: nil) request_encoder = RequestEncoder.encoder(as) headers ||= {} if query query_string = query.is_a?(String) ? query : Rack::Utils.build_nested_query(query) path = path.include?("?") ? "#{path}&#{query_string}" : "#{path}?#{query_string}" end if path.include?("://") path = build_expanded_path(path) do |location| https! URI::HTTPS === location if location.scheme if url_host = location.host default = Rack::Request::DEFAULT_PORTS[location.scheme] url_host += ":#{location.port}" if default != location.port host! url_host end end end hostname, port = host.split(":") body_params = body || (method != :get ? params : nil) query_params = body ? nil : (method == :get ? params : nil) request_env = { :method => method, :params => body_params ? request_encoder.encode_params(body_params) : query_params, "SERVER_NAME" => hostname, "SERVER_PORT" => port || (https? ? "443" : "80"), "HTTPS" => https? ? "on" : "off", "rack.url_scheme" => https? ? "https" : "http", "REQUEST_URI" => path, "HTTP_HOST" => host, "REMOTE_ADDR" => remote_addr, "HTTP_ACCEPT" => request_encoder.accept_header || accept } if body_params && request_encoder.content_type request_env["CONTENT_TYPE"] = request_encoder.content_type end wrapped_headers = Http::Headers.from_hash({}) wrapped_headers.merge!(headers) if headers if xhr wrapped_headers["HTTP_X_REQUESTED_WITH"] = "XMLHttpRequest" wrapped_headers["HTTP_ACCEPT"] ||= [Mime[:js], Mime[:html], Mime[:xml], "text/xml", "*/*"].join(", ") end # This modifies the passed request_env directly. if wrapped_headers.present? Http::Headers.from_hash(request_env).merge!(wrapped_headers) end if env.present? Http::Headers.from_hash(request_env).merge!(env) end session = Rack::Test::Session.new(_mock_session) # NOTE: rack-test v0.5 doesn't build a default uri correctly Make sure requested # path is always a full URI. uri = build_full_uri(path, request_env) if method == :get && String === request_env[:params] # rack-test will needlessly parse and rebuild a :params # querystring, using Rack's query parser. At best that's a # waste of time; at worst it can change the value. uri << "?" << request_env.delete(:params) end session.request(uri, request_env) @request_count += 1 @request = ActionDispatch::Request.new(session.last_request.env) response = _mock_session.last_response @response = ActionDispatch::TestResponse.from_response(response) @response.request = @request @html_document = nil @url_options = nil @controller = @request.controller_instance response.status end
reset!() Link
Resets the instance. This can be used to reset the state information in an existing session instance, so it can be used from a clean-slate condition.
session.reset!
# File actionpack/lib/action_dispatch/testing/integration.rb, line 156 def reset! @https = false @controller = @request = @response = nil @_mock_session = nil @request_count = 0 @url_options = nil self.host = DEFAULT_HOST self.remote_addr = "127.0.0.1" self.accept = "text/xml,application/xml,application/xhtml+xml," \ "text/html;q=0.9,text/plain;q=0.8,image/png," \ "*/*;q=0.5" unless defined? @named_routes_configured # the helpers are made protected by default--we make them public for easier # access during testing and troubleshooting. @named_routes_configured = true end end
url_options() Link
# File actionpack/lib/action_dispatch/testing/integration.rb, line 140 def url_options @url_options ||= default_url_options.dup.tap do |url_options| url_options.reverse_merge!(controller.url_options) if controller.respond_to?(:url_options) if @app.respond_to?(:routes) url_options.reverse_merge!(@app.routes.default_url_options) end url_options.reverse_merge!(host: host, protocol: https? ? "https" : "http") end end