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 IntegrationTest#open_session, rather than instantiating Integration::Session directly.
Methods
Included Modules
- 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
new(app)
Create and initialize a new Session instance.
π Source code
# File actionpack/lib/action_dispatch/testing/integration.rb, line 126
      def initialize(app)
        super()
        @app = app
        reset!
      endInstance Public methods
cookies()
A map of the cookies returned by the last response, and which will be sent with the next request.
π Source code
# File actionpack/lib/action_dispatch/testing/integration.rb, line 107
      def cookies
        _mock_session.cookie_jar
      endhost()
The hostname used in the last request.
π Source code
# File actionpack/lib/action_dispatch/testing/integration.rb, line 94
      def host
        @host || DEFAULT_HOST
      endhttps!(flag = true)
Specify whether or not the session should mimic a secure HTTPS request.
session.https!
session.https!(false)
π Source code
# File actionpack/lib/action_dispatch/testing/integration.rb, line 174
      def https!(flag = true)
        @https = flag
      endhttps?()
Returns true if the session is mimicking a secure HTTPS request.
if session.https?
  ...
end
π Source code
# File actionpack/lib/action_dispatch/testing/integration.rb, line 183
      def https?
        @https
      endprocess(method, path, params: nil, headers: nil, env: nil, xhr: false, as: nil)
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).
- 
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 of XMLHttpRequest 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.
This method is rarely used directly. Use #get, #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 Response object which one can use to inspect the details of the response.
Example:
process :get, '/author', params: { since: 201501011400 }
π Source code
# File actionpack/lib/action_dispatch/testing/integration.rb, line 220
      def process(method, path, params: nil, headers: nil, env: nil, xhr: false, as: nil)
        request_encoder = RequestEncoder.encoder(as)
        headers ||= {}
        if method == :get && as == :json && params
          headers["X-Http-Method-Override"] = "GET"
          method = :post
        end
        if %r{://}.match?(path)
          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(":")
        request_env = {
          :method => method,
          :params => request_encoder.encode_params(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,
          "CONTENT_TYPE"   => request_encoder.content_type,
          "HTTP_ACCEPT"    => request_encoder.accept_header || accept
        }
        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.
        session.request(build_full_uri(path, request_env), 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
      endreset!()
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!
π Source code
# File actionpack/lib/action_dispatch/testing/integration.rb, line 150
      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
      endurl_options()
π Source code
# File actionpack/lib/action_dispatch/testing/integration.rb, line 133
      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