aboutsummaryrefslogtreecommitdiffstats
path: root/railties
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2008-04-01 05:01:33 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2008-04-01 05:01:33 +0000
commit25eeea719768e1c1ce47742057f0fb042a139edc (patch)
treeabefb0738bc49f2a5ca51ac80b56b6a9ffb3144e /railties
parente4e3df8ef8b198416fedc80743caf37c5aaff9fb (diff)
downloadrails-25eeea719768e1c1ce47742057f0fb042a139edc.tar.gz
rails-25eeea719768e1c1ce47742057f0fb042a139edc.tar.bz2
rails-25eeea719768e1c1ce47742057f0fb042a139edc.zip
PostgreSQL: use create_ and drop_database for rake tasks. Closes #9045 [ez, nicksieger]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@9183 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'railties')
-rw-r--r--railties/lib/tasks/databases.rake44
1 files changed, 26 insertions, 18 deletions
diff --git a/railties/lib/tasks/databases.rake b/railties/lib/tasks/databases.rake
index f6a1f73731..e39f9ca197 100644
--- a/railties/lib/tasks/databases.rake
+++ b/railties/lib/tasks/databases.rake
@@ -5,13 +5,13 @@ namespace :db do
ActiveRecord::Base.configurations.each_value do |config|
# Skip entries that don't have a database key, such as the first entry here:
#
- # defaults: &defaults
- # adapter: mysql
+ # defaults: &defaults
+ # adapter: mysql
# username: root
- # password:
+ # password:
# host: localhost
- #
- # development:
+ #
+ # development:
# database: blog_development
# <<: *defaults
next unless config['database']
@@ -36,21 +36,29 @@ namespace :db do
@charset = ENV['CHARSET'] || 'utf8'
@collation = ENV['COLLATION'] || 'utf8_general_ci'
begin
- ActiveRecord::Base.establish_connection(config.merge({'database' => nil}))
- ActiveRecord::Base.connection.create_database(config['database'], {:charset => (config['charset'] || @charset), :collation => (config['collation'] || @collation)})
+ ActiveRecord::Base.establish_connection(config.merge('database' => nil))
+ ActiveRecord::Base.connection.create_database(config['database'], :charset => (config['charset'] || @charset), :collation => (config['collation'] || @collation))
ActiveRecord::Base.establish_connection(config)
rescue
$stderr.puts "Couldn't create database for #{config.inspect}, charset: #{config['charset'] || @charset}, collation: #{config['collation'] || @collation} (if you set the charset manually, make sure you have a matching collation)"
end
when 'postgresql'
- `createdb "#{config['database']}" -E utf8`
+ @encoding = config[:encoding] || ENV['CHARSET'] || 'utf8'
+ begin
+ ActiveRecord::Base.establish_connection(config.merge('database' => nil))
+ ActiveRecord::Base.connection.create_database(config['database'], :encoding => @encoding)
+ ActiveRecord::Base.establish_connection(config)
+ rescue
+ $stderr.puts $!, *($!.backtrace)
+ $stderr.puts "Couldn't create database for #{config.inspect}"
+ end
when 'sqlite'
`sqlite "#{config['database']}"`
when 'sqlite3'
`sqlite3 "#{config['database']}"`
end
else
- p "#{config['database']} already exists"
+ $stderr.puts "#{config['database']} already exists"
end
end
@@ -98,7 +106,7 @@ namespace :db do
desc 'Resets your database using your migrations for the current environment'
task :reset => ["db:drop", "db:create", "db:migrate"]
-
+
desc 'Runs the "up" for a given migration VERSION.'
task :up => :environment do
version = ENV["VERSION"] ? ENV["VERSION"].to_i : nil
@@ -113,7 +121,7 @@ namespace :db do
raise "VERSION is required" unless version
ActiveRecord::Migrator.run(:down, "db/migrate/", version)
Rake::Task["db:schema:dump"].invoke if ActiveRecord::Base.schema_format == :ruby
- end
+ end
end
desc 'Rolls the schema back to the previous version. Specify the number of steps with STEP=n'
@@ -179,21 +187,21 @@ namespace :db do
Fixtures.create_fixtures('test/fixtures', File.basename(fixture_file, '.*'))
end
end
-
+
desc "Search for a fixture given a LABEL or ID."
task :identify => :environment do
require "active_record/fixtures"
label, id = ENV["LABEL"], ENV["ID"]
raise "LABEL or ID required" if label.blank? && id.blank?
-
+
puts %Q(The fixture ID for "#{label}" is #{Fixtures.identify(label)}.) if label
-
+
Dir["#{RAILS_ROOT}/test/fixtures/**/*.yml"].each do |file|
if data = YAML::load(ERB.new(IO.read(file)).result)
data.keys.each do |key|
key_id = Fixtures.identify(key)
-
+
if key == label || key_id == id.to_i
puts "#{file}: #{key} (#{key_id})"
end
@@ -365,8 +373,8 @@ def drop_database(config)
when /^sqlite/
FileUtils.rm(File.join(RAILS_ROOT, config['database']))
when 'postgresql'
- ActiveRecord::Base.clear_active_connections!
- `dropdb "#{config['database']}"`
+ ActiveRecord::Base.establish_connection(config.merge('database' => nil))
+ ActiveRecord::Base.connection.drop_database config['database']
end
end
@@ -381,4 +389,4 @@ end
def firebird_db_string(config)
FireRuby::Database.db_string_for(config.symbolize_keys)
-end \ No newline at end of file
+end