module ActionDispatch::Integration::Runner
Constants
- APP_SESSIONS
Attributes
app[R]
Public Class Methods
# File actionpack/lib/action_dispatch/testing/integration.rb, line 314 def initialize(*args, &blk) super(*args, &blk) @integration_session = nil end
Calls superclass method
Public Instance Methods
# File actionpack/lib/action_dispatch/testing/integration.rb, line 334 def create_session(app) klass = APP_SESSIONS[app] ||= Class.new(Integration::Session) { # If the app is a Rails app, make url_helpers available on the session. # This makes app.url_for and app.foo_path available in the console. if app.respond_to?(:routes) && app.routes.is_a?(ActionDispatch::Routing::RouteSet) include app.routes.url_helpers include app.routes.mounted_helpers end } klass.new(app) end
# File actionpack/lib/action_dispatch/testing/integration.rb, line 388 def default_url_options integration_session.default_url_options end
# File actionpack/lib/action_dispatch/testing/integration.rb, line 392 def default_url_options=(options) integration_session.default_url_options = options end
# File actionpack/lib/action_dispatch/testing/integration.rb, line 324 def integration_session @integration_session ||= create_session(app) end
# File actionpack/lib/action_dispatch/testing/integration.rb, line 373 def open_session dup.tap do |session| session.reset! yield session if block_given? end end
Open a new session instance. If a block is given, the new session is yielded to the block before being returned.
session = open_session do |sess| sess.extend(CustomAssertions) end
By default, a single session is automatically created for you, but you can use this method to open multiple sessions that ought to be tested simultaneously.
# File actionpack/lib/action_dispatch/testing/integration.rb, line 330 def reset! @integration_session = create_session(app) end
Reset the current session. This is useful for testing multiple sessions in a single test case.
© 2004–2019 David Heinemeier Hansson
Licensed under the MIT License.