diff options
author | Jeremy Kemper <jeremy@bitsweat.net> | 2008-04-01 05:01:33 +0000 |
---|---|---|
committer | Jeremy Kemper <jeremy@bitsweat.net> | 2008-04-01 05:01:33 +0000 |
commit | 25eeea719768e1c1ce47742057f0fb042a139edc (patch) | |
tree | abefb0738bc49f2a5ca51ac80b56b6a9ffb3144e /railties | |
parent | e4e3df8ef8b198416fedc80743caf37c5aaff9fb (diff) | |
download | rails-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.rake | 44 |
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 |