diff options
author | Jay Hayes <ur@iamvery.com> | 2015-04-26 22:20:08 -0500 |
---|---|---|
committer | Jay Hayes <ur@iamvery.com> | 2015-10-20 19:17:58 -0500 |
commit | 2893e6c0a459a91a033d357cd15cc4d14e7acbc1 (patch) | |
tree | 4f12f6cbe0a21139db2948648f3e1b44b571d973 /railties/test/application/rake/dbs_test.rb | |
parent | 1cd35be3eb04da88d790493d3ce9807efeaeddba (diff) | |
download | rails-2893e6c0a459a91a033d357cd15cc4d14e7acbc1.tar.gz rails-2893e6c0a459a91a033d357cd15cc4d14e7acbc1.tar.bz2 rails-2893e6c0a459a91a033d357cd15cc4d14e7acbc1.zip |
Exit with non-zero status when db:create fails
* If the create task fails for a reason other than the database already
existing, processing should end. This is indicated by a non-zero exit
status.
* Since the backtrace is already printed to screen, we forgo printing it
again by using an explicit call to `exit`.
* :warning: This modifies the behavior of the db:create task slightly in
that the stack trace is no longer printed by default. If the `--trace`
option is used, it will print the trace _after_ the error message.
Diffstat (limited to 'railties/test/application/rake/dbs_test.rb')
-rw-r--r-- | railties/test/application/rake/dbs_test.rb | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/railties/test/application/rake/dbs_test.rb b/railties/test/application/rake/dbs_test.rb index 9b62764db2..bd885b520e 100644 --- a/railties/test/application/rake/dbs_test.rb +++ b/railties/test/application/rake/dbs_test.rb @@ -66,6 +66,23 @@ module ApplicationTests end end + def with_bad_permissions + Dir.chdir(app_path) do + set_database_url + FileUtils.chmod("-w", "db") + yield + FileUtils.chmod("+w", "db") + end + end + + test 'db:create failure because bad permissions' do + with_bad_permissions do + output = `bin/rake db:create 2>&1` + assert_match /Couldn't create database/, output + assert_equal 1, $?.exitstatus + end + end + test 'db:drop failure because database does not exist' do Dir.chdir(app_path) do output = `bin/rake db:drop 2>&1` |