diff options
Diffstat (limited to 'actionpack/lib/action_controller')
-rw-r--r-- | actionpack/lib/action_controller/metal/testing.rb | 4 | ||||
-rw-r--r-- | actionpack/lib/action_controller/test_case.rb | 11 |
2 files changed, 10 insertions, 5 deletions
diff --git a/actionpack/lib/action_controller/metal/testing.rb b/actionpack/lib/action_controller/metal/testing.rb index d1813ee745..a4718376aa 100644 --- a/actionpack/lib/action_controller/metal/testing.rb +++ b/actionpack/lib/action_controller/metal/testing.rb @@ -8,12 +8,8 @@ module ActionController @_url_options = nil end - # TODO: Clean this up def process_with_new_base_test(request, response) - @_request = request - @_response = response - @_response.request = request ret = process(request.parameters[:action]) if cookies = @_request.env['action_dispatch.cookies'] cookies.write(@_response) diff --git a/actionpack/lib/action_controller/test_case.rb b/actionpack/lib/action_controller/test_case.rb index a1f29ea1bc..9c73aba22a 100644 --- a/actionpack/lib/action_controller/test_case.rb +++ b/actionpack/lib/action_controller/test_case.rb @@ -490,9 +490,18 @@ module ActionController @request.session.update(session) if session @request.session["flash"] = @request.flash.update(flash || {}) - @controller.request = @request + @response.request = @request + @controller.request = @request + @controller.response = @response + build_request_uri(action, parameters) @controller.class.class_eval { include Testing } + + @controller.extend(Module.new { + def set_response!(request) + end + }) + @controller.recycle! @controller.process_with_new_base_test(@request, @response) @assigns = @controller.respond_to?(:view_assigns) ? @controller.view_assigns : {} |