aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJamis Buck <jamis@37signals.com>2006-03-12 00:08:26 +0000
committerJamis Buck <jamis@37signals.com>2006-03-12 00:08:26 +0000
commit8e8b6b9e403cdeb57d0ba373bff6498dc7f9f5df (patch)
treef0190044bd9fa8bf1db031871e2102b03dd561ee
parent77e2f00c2875b598f5a09f20751cc65c9c5ff4bd (diff)
downloadrails-8e8b6b9e403cdeb57d0ba373bff6498dc7f9f5df.tar.gz
rails-8e8b6b9e403cdeb57d0ba373bff6498dc7f9f5df.tar.bz2
rails-8e8b6b9e403cdeb57d0ba373bff6498dc7f9f5df.zip
More integration testing tweaks
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@3840 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
-rw-r--r--actionpack/lib/action_controller/integration_test.rb29
1 files changed, 22 insertions, 7 deletions
diff --git a/actionpack/lib/action_controller/integration_test.rb b/actionpack/lib/action_controller/integration_test.rb
index d16d8b00b5..4569ee6ebd 100644
--- a/actionpack/lib/action_controller/integration_test.rb
+++ b/actionpack/lib/action_controller/integration_test.rb
@@ -461,7 +461,10 @@ module ActionController
%w(get post cookies assigns).each do |method|
define_method(method) do |*args|
- @integration_session.send(method, *args)
+ reset! unless @integration_session
+ returning @integration_session.send(method, *args) do
+ copy_session_variables!
+ end
end
end
@@ -479,26 +482,38 @@ module ActionController
session = Integration::Session.new
# delegate the fixture accessors back to the test instance
- klass = class<<session; self; end
- tests = self
-
+ extras = Module.new { attr_accessor :delegate, :test_result }
self.class.fixture_table_names.each do |table_name|
name = table_name.tr(".", "_")
next unless respond_to?(name)
- klass.send(:define_method, name) { |*args| tests.send(name, *args) }
+ extras.send(:define_method, name) { |*args| delegate.send(name, *args) }
end
# delegate add_assertion to the test case
- klass.send(:define_method, :add_assertion) { tests.add_assertion }
+ extras.send(:define_method, :add_assertion) { test_result.add_assertion }
+ session.extend(extras)
+ session.delegate = self
+ session.test_result = @_result
yield session if block_given?
session
end
+ # Copy the instance variables from the current session instance into the
+ # test instance.
+ def copy_session_variables! #:nodoc:
+ return unless @integration_session
+ %w(controller response request).each do |var|
+ instance_variable_set("@#{var}", @integration_session.send(var))
+ end
+ end
+
# Delegate unhandled messages to the current session instance.
def method_missing(sym, *args, &block)
reset! unless @integration_session
- @integration_session.send(sym, *args, &block)
+ returning @integration_session.send(sym, *args, &block) do
+ copy_session_variables!
+ end
end
end
end