aboutsummaryrefslogtreecommitdiffstats
path: root/railties
diff options
context:
space:
mode:
authorTerence Lee <hone02@gmail.com>2012-04-03 21:50:18 -0500
committerTerence Lee <hone02@gmail.com>2012-04-03 21:50:18 -0500
commit93f25ac6fc4493600c1648c1a60b12cc83790ad0 (patch)
tree502b5e7c76868cee83599516ff61df3dafe1b68d /railties
parent8e315b0e0a551fcb09e73b2b704492923d4806f3 (diff)
downloadrails-93f25ac6fc4493600c1648c1a60b12cc83790ad0.tar.gz
rails-93f25ac6fc4493600c1648c1a60b12cc83790ad0.tar.bz2
rails-93f25ac6fc4493600c1648c1a60b12cc83790ad0.zip
test initializer logic for DATABASE_URL env var
Diffstat (limited to 'railties')
-rw-r--r--railties/test/application/initializers/active_record_test.rb43
1 files changed, 43 insertions, 0 deletions
diff --git a/railties/test/application/initializers/active_record_test.rb b/railties/test/application/initializers/active_record_test.rb
new file mode 100644
index 0000000000..4a0b8fd56a
--- /dev/null
+++ b/railties/test/application/initializers/active_record_test.rb
@@ -0,0 +1,43 @@
+require "isolation/abstract_unit"
+require "rack/test"
+
+module ApplicationTests
+ class ActiveRecordTest < Test::Unit::TestCase
+ include ActiveSupport::Testing::Isolation
+ include Rack::Test::Methods
+
+ def setup
+ @database_url = ENV['DATABASE_URL']
+ ENV.delete('DATABASE_URL')
+ build_app
+ boot_rails
+ end
+
+ def teardown
+ teardown_app
+ ENV['DATABASE_URL'] = @database_url
+ end
+
+ test "blows up when no DATABASE_URL env var or database.yml" do
+ FileUtils.rm_rf("#{app_path}/config/database.yml")
+ boot_rails
+ simple_controller
+
+ get '/foo'
+ assert last_response.body.include?("We're sorry, but something went wrong (500)")
+ end
+
+ test "uses DATABASE_URL env var when config/database.yml doesn't exist" do
+ database_path = "/db/foo.sqlite3"
+ FileUtils.rm_rf("#{app_path}/config/database.yml")
+ ENV['DATABASE_URL'] = "sqlite3://#{database_path}"
+ simple_controller
+
+ get '/foo'
+ assert_equal 'foo', last_response.body
+
+ # clean up
+ FileUtils.rm("#{app_path}/#{database_path}")
+ end
+ end
+end