aboutsummaryrefslogtreecommitdiffstats
path: root/railties/lib/rails/console_app.rb
diff options
context:
space:
mode:
authorYehuda Katz + Carl Lerche <ykatz+clerche@engineyard.com>2009-09-24 14:01:31 -0700
committerYehuda Katz + Carl Lerche <ykatz+clerche@engineyard.com>2009-09-24 16:11:41 -0700
commitf0dd77c6be6a86fe384bb0015151e0a497973d39 (patch)
treead81bb4c807c39edeaa37035882a16d9d95ebaa9 /railties/lib/rails/console_app.rb
parent610b81beca461a6fa4f00c7023e0e4315eb2b8be (diff)
downloadrails-f0dd77c6be6a86fe384bb0015151e0a497973d39.tar.gz
rails-f0dd77c6be6a86fe384bb0015151e0a497973d39.tar.bz2
rails-f0dd77c6be6a86fe384bb0015151e0a497973d39.zip
Move railties/lib/* into railties/lib/*
Diffstat (limited to 'railties/lib/rails/console_app.rb')
-rw-r--r--railties/lib/rails/console_app.rb31
1 files changed, 31 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..75e6f11ea3
--- /dev/null
+++ b/railties/lib/rails/console_app.rb
@@ -0,0 +1,31 @@
+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
+ session = ActionController::Integration::Session.new
+ yield session if block_given?
+ session
+end
+
+#reloads the environment
+def reload!
+ puts "Reloading..."
+ ActionController::Dispatcher.new
+ ActionController::Dispatcher.router.reload
+ true
+end