1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/railties/test/commands/dbconsole_test.rb

186 lines
5.5 KiB
Ruby
Raw Normal View History

2012-04-27 03:28:53 -04:00
require 'abstract_unit'
require 'rails/commands/dbconsole'
class Rails::DBConsoleTest < ActiveSupport::TestCase
def teardown
2012-05-04 10:40:32 -04:00
%w[PGUSER PGHOST PGPORT PGPASSWORD].each{|key| ENV.delete(key)}
2012-04-27 03:28:53 -04:00
end
2012-05-04 10:40:32 -04:00
def test_config
Rails::DBConsole.const_set(:APP_PATH, "erb")
app_config({})
capture_abort { Rails::DBConsole.new.config }
2012-04-27 03:28:53 -04:00
assert aborted
2012-05-30 05:08:56 -04:00
assert_match(/No database is configured for the environment '\w+'/, output)
2012-05-04 10:40:32 -04:00
2012-05-07 00:38:34 -04:00
app_config(test: "with_init")
assert_equal Rails::DBConsole.new.config, "with_init"
2012-05-04 10:40:32 -04:00
2012-05-07 00:38:34 -04:00
app_db_file("test:\n without_init")
assert_equal Rails::DBConsole.new.config, "without_init"
2012-05-04 10:40:32 -04:00
2012-05-07 00:38:34 -04:00
app_db_file("test:\n <%= Rails.something_app_specific %>")
assert_equal Rails::DBConsole.new.config, "with_init"
2012-05-04 10:40:32 -04:00
2012-05-07 00:38:34 -04:00
app_db_file("test:\n\ninvalid")
assert_equal Rails::DBConsole.new.config, "with_init"
2012-05-04 10:40:32 -04:00
end
def test_env
assert_equal Rails::DBConsole.new.environment, "test"
ENV['RAILS_ENV'] = nil
ENV['RACK_ENV'] = nil
2012-05-04 10:40:32 -04:00
Rails.stubs(:respond_to?).with(:env).returns(false)
assert_equal Rails::DBConsole.new.environment, "development"
2012-05-04 10:40:32 -04:00
ENV['RACK_ENV'] = "rack_env"
assert_equal Rails::DBConsole.new.environment, "rack_env"
2012-05-04 10:40:32 -04:00
ENV['RAILS_ENV'] = "rails_env"
assert_equal Rails::DBConsole.new.environment, "rails_env"
2012-05-07 00:38:34 -04:00
ensure
ENV['RAILS_ENV'] = "test"
2012-04-27 03:28:53 -04:00
end
def test_mysql
dbconsole.expects(:find_cmd_and_exec).with(%w[mysql mysql5], 'db')
2012-05-04 10:40:32 -04:00
start(adapter: 'mysql', database: 'db')
2012-04-27 03:28:53 -04:00
assert !aborted
end
def test_mysql_full
dbconsole.expects(:find_cmd_and_exec).with(%w[mysql mysql5], '--host=locahost', '--port=1234', '--socket=socket', '--user=user', '--default-character-set=UTF-8', '-p', 'db')
2012-05-04 10:40:32 -04:00
start(adapter: 'mysql', database: 'db', host: 'locahost', port: 1234, socket: 'socket', username: 'user', password: 'qwerty', encoding: 'UTF-8')
2012-04-27 03:28:53 -04:00
assert !aborted
end
def test_mysql_include_password
dbconsole.expects(:find_cmd_and_exec).with(%w[mysql mysql5], '--user=user', '--password=qwerty', 'db')
2012-05-04 10:40:32 -04:00
start({adapter: 'mysql', database: 'db', username: 'user', password: 'qwerty'}, ['-p'])
2012-04-27 03:28:53 -04:00
assert !aborted
end
def test_postgresql
dbconsole.expects(:find_cmd_and_exec).with('psql', 'db')
2012-05-04 10:40:32 -04:00
start(adapter: 'postgresql', database: 'db')
2012-04-27 03:28:53 -04:00
assert !aborted
end
def test_postgresql_full
dbconsole.expects(:find_cmd_and_exec).with('psql', 'db')
2012-05-04 10:40:32 -04:00
start(adapter: 'postgresql', database: 'db', username: 'user', password: 'q1w2e3', host: 'host', port: 5432)
2012-04-27 03:28:53 -04:00
assert !aborted
assert_equal 'user', ENV['PGUSER']
assert_equal 'host', ENV['PGHOST']
assert_equal '5432', ENV['PGPORT']
assert_not_equal 'q1w2e3', ENV['PGPASSWORD']
end
def test_postgresql_include_password
dbconsole.expects(:find_cmd_and_exec).with('psql', 'db')
2012-05-04 10:40:32 -04:00
start({adapter: 'postgresql', database: 'db', username: 'user', password: 'q1w2e3'}, ['-p'])
2012-04-27 03:28:53 -04:00
assert !aborted
assert_equal 'user', ENV['PGUSER']
assert_equal 'q1w2e3', ENV['PGPASSWORD']
end
def test_sqlite
dbconsole.expects(:find_cmd_and_exec).with('sqlite', 'db')
2012-05-04 10:40:32 -04:00
start(adapter: 'sqlite', database: 'db')
2012-04-27 03:28:53 -04:00
assert !aborted
end
def test_sqlite3
dbconsole.expects(:find_cmd_and_exec).with('sqlite3', Rails.root.join('db.sqlite3').to_s)
start(adapter: 'sqlite3', database: 'db.sqlite3')
2012-04-27 03:28:53 -04:00
assert !aborted
end
def test_sqlite3_mode
dbconsole.expects(:find_cmd_and_exec).with('sqlite3', '-html', Rails.root.join('db.sqlite3').to_s)
start({adapter: 'sqlite3', database: 'db.sqlite3'}, ['--mode', 'html'])
2012-04-27 03:28:53 -04:00
assert !aborted
end
def test_sqlite3_header
dbconsole.expects(:find_cmd_and_exec).with('sqlite3', '-header', Rails.root.join('db.sqlite3').to_s)
start({adapter: 'sqlite3', database: 'db.sqlite3'}, ['--header'])
end
def test_sqlite3_db_absolute_path
dbconsole.expects(:find_cmd_and_exec).with('sqlite3', '/tmp/db.sqlite3')
start(adapter: 'sqlite3', database: '/tmp/db.sqlite3')
2012-04-27 03:28:53 -04:00
assert !aborted
end
def test_oracle
dbconsole.expects(:find_cmd_and_exec).with('sqlplus', 'user@db')
2012-05-04 10:40:32 -04:00
start(adapter: 'oracle', database: 'db', username: 'user', password: 'secret')
2012-04-27 03:28:53 -04:00
assert !aborted
end
def test_oracle_include_password
dbconsole.expects(:find_cmd_and_exec).with('sqlplus', 'user/secret@db')
2012-05-04 10:40:32 -04:00
start({adapter: 'oracle', database: 'db', username: 'user', password: 'secret'}, ['-p'])
2012-04-27 03:28:53 -04:00
assert !aborted
end
def test_unknown_command_line_client
2012-05-04 10:40:32 -04:00
start(adapter: 'unknown', database: 'db')
2012-04-27 03:28:53 -04:00
assert aborted
2012-05-30 05:08:56 -04:00
assert_match(/Unknown command-line client for db/, output)
2012-04-27 03:28:53 -04:00
end
def test_print_help_short
stdout = capture(:stdout) do
start({}, ['-h'])
end
assert aborted
assert_equal '', output
2012-05-30 05:08:56 -04:00
assert_match(/Usage:.*dbconsole/, stdout)
end
def test_print_help_long
stdout = capture(:stdout) do
start({}, ['--help'])
end
assert aborted
assert_equal '', output
2012-05-30 05:08:56 -04:00
assert_match(/Usage:.*dbconsole/, stdout)
end
2012-04-27 03:28:53 -04:00
private
attr_reader :aborted, :output
def dbconsole
2012-05-04 10:40:32 -04:00
@dbconsole ||= Rails::DBConsole.new(nil)
2012-04-27 03:28:53 -04:00
end
2012-05-04 10:40:32 -04:00
def start(config = {}, argv = [])
dbconsole.stubs(config: config.stringify_keys, arguments: argv)
capture_abort { dbconsole.start }
end
2012-04-27 03:28:53 -04:00
2012-05-04 10:40:32 -04:00
def capture_abort
2012-04-27 03:28:53 -04:00
@aborted = false
2012-05-07 00:38:34 -04:00
@output = capture(:stderr) do
2012-04-27 03:28:53 -04:00
begin
2012-05-04 10:40:32 -04:00
yield
2012-04-27 03:28:53 -04:00
rescue SystemExit
@aborted = true
end
end
end
2012-05-04 10:40:32 -04:00
def app_db_file(result)
IO.stubs(:read).with("config/database.yml").returns(result)
end
def app_config(result)
Rails.application.config.stubs(:database_configuration).returns(result.stringify_keys)
2012-04-27 03:28:53 -04:00
end
end