aboutsummaryrefslogtreecommitdiffstats
path: root/railties/lib/rails/console_app.rb
diff options
context:
space:
mode:
authorPratik Naik <pratiknaik@gmail.com>2009-09-30 22:27:02 +0100
committerPratik Naik <pratiknaik@gmail.com>2009-09-30 22:27:02 +0100
commitdd2779e1b83b4d867d47dd286ec0c919f5df12a9 (patch)
tree6e52ea0a329c24429f4d1d41b065e082f0ed6baa /railties/lib/rails/console_app.rb
parent329b14aa8fdd291a00d17ba12c2e0ab4c3a157cc (diff)
parent420004e030e96f2ace6e27fd622c90ee9e986677 (diff)
downloadrails-dd2779e1b83b4d867d47dd286ec0c919f5df12a9.tar.gz
rails-dd2779e1b83b4d867d47dd286ec0c919f5df12a9.tar.bz2
rails-dd2779e1b83b4d867d47dd286ec0c919f5df12a9.zip
Merge commit 'mainstream/master'
Diffstat (limited to 'railties/lib/rails/console_app.rb')
-rw-r--r--railties/lib/rails/console_app.rb32
1 files changed, 32 insertions, 0 deletions
diff --git a/railties/lib/rails/console_app.rb b/railties/lib/rails/console_app.rb
new file mode 100644
index 0000000000..1ad62e5058
--- /dev/null
+++ b/railties/lib/rails/console_app.rb
@@ -0,0 +1,32 @@
+require 'active_support/all'
+require 'active_support/test_case'
+require 'action_controller'
+
+# work around the at_exit hook in test/unit, which kills IRB
+Test::Unit.run = true if Test::Unit.respond_to?(:run=)
+
+# reference the global "app" instance, created on demand. To recreate the
+# instance, pass a non-false value as the parameter.
+def app(create=false)
+ @app_integration_instance = nil if create
+ @app_integration_instance ||= new_session do |sess|
+ sess.host! "www.example.com"
+ end
+end
+
+# create a new session. If a block is given, the new session will be yielded
+# to the block before being returned.
+def new_session
+ app = ActionController::Dispatcher.new
+ session = ActionController::Integration::Session.new(app)
+ yield session if block_given?
+ session
+end
+
+#reloads the environment
+def reload!
+ puts "Reloading..."
+ ActionDispatch::Callbacks.new(lambda {}, true)
+ ActionController::Routing::Routes.reload
+ true
+end