diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2012-07-02 14:29:19 -0700 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2012-07-03 14:59:31 -0700 |
commit | 9eef9333bdc9631e1b0149fee86a491b603858b3 (patch) | |
tree | d552f029f9d03b59301957d9813c40fc28edc6c0 /actionpack/lib/action_controller | |
parent | 46eba6c30ff05b5f7e8e6015e33ddf0a385fce6f (diff) | |
download | rails-9eef9333bdc9631e1b0149fee86a491b603858b3.tar.gz rails-9eef9333bdc9631e1b0149fee86a491b603858b3.tar.bz2 rails-9eef9333bdc9631e1b0149fee86a491b603858b3.zip |
push req / res setting to the test runner
Try to avoid making the controller mutate itself so that we can
eventually make the response async
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 : {} |