module ActiveRecord::Tasks::DatabaseTasks
def charset(*arguments)
def charset(*arguments) configuration = arguments.first class_for_adapter(configuration['adapter']).new(*arguments).charset end
def charset_current(environment = env)
def charset_current(environment = env) charset ActiveRecord::Base.configurations[environment] end
def check_schema_file(filename)
def check_schema_file(filename) unless File.exist?(filename) message = %{#{filename} doesn't exist yet. Run `rake db:migrate` to create it, then try again.} message << %{ If you do not intend to use a database, you should instead alter #{Rails.root}/config/application.rb to limit the frameworks that will be loaded.} if defined?(::Rails) Kernel.abort message end end
def class_for_adapter(adapter)
def class_for_adapter(adapter) key = @tasks.keys.detect { |pattern| adapter[pattern] } unless key raise DatabaseNotSupported, "Rake tasks not supported by '#{adapter}' adapter" end @tasks[key] end
def collation(*arguments)
def collation(*arguments) configuration = arguments.first class_for_adapter(configuration['adapter']).new(*arguments).collation end
def collation_current(environment = env)
def collation_current(environment = env) collation ActiveRecord::Base.configurations[environment] end
def create(*arguments)
def create(*arguments) configuration = arguments.first class_for_adapter(configuration['adapter']).new(*arguments).create rescue DatabaseAlreadyExists $stderr.puts "#{configuration['database']} already exists" rescue Exception => error $stderr.puts error, *(error.backtrace) $stderr.puts "Couldn't create database for #{configuration.inspect}" end
def create_all
def create_all each_local_configuration { |configuration| create configuration } end
def create_current(environment = env)
def create_current(environment = env) each_current_configuration(environment) { |configuration| create configuration } ActiveRecord::Base.establish_connection(environment.to_sym) end
def current_config(options = {})
def current_config(options = {}) options.reverse_merge! :env => env if options.has_key?(:config) @current_config = options[:config] else @current_config ||= ActiveRecord::Base.configurations[options[:env]] end end
def db_dir
def db_dir @db_dir ||= Rails.application.config.paths["db"].first end
def drop(*arguments)
def drop(*arguments) configuration = arguments.first class_for_adapter(configuration['adapter']).new(*arguments).drop rescue Exception => error $stderr.puts error, *(error.backtrace) $stderr.puts "Couldn't drop #{configuration['database']}" end
def drop_all
def drop_all each_local_configuration { |configuration| drop configuration } end
def drop_current(environment = env)
def drop_current(environment = env) each_current_configuration(environment) { |configuration| drop configuration } end
def each_current_configuration(environment)
def each_current_configuration(environment) environments = [environment] # add test environment only if no RAILS_ENV was specified. environments << 'test' if environment == 'development' && ENV['RAILS_ENV'].nil? configurations = ActiveRecord::Base.configurations.values_at(*environments) configurations.compact.each do |configuration| yield configuration unless configuration['database'].blank? end end
def each_local_configuration
def each_local_configuration ActiveRecord::Base.configurations.each_value do |configuration| next unless configuration['database'] if local_database?(configuration) yield configuration else $stderr.puts "This task only modifies local databases. #{configuration['database']} is on a remote host." end end end
def env
def env @env ||= Rails.env end
def fixtures_path
def fixtures_path @fixtures_path ||= File.join(root, 'test', 'fixtures') end
def load_schema(format = ActiveRecord::Base.schema_format, file = nil)
def load_schema(format = ActiveRecord::Base.schema_format, file = nil) case format when :ruby file ||= File.join(db_dir, "schema.rb") check_schema_file(file) load(file) when :sql file ||= File.join(db_dir, "structure.sql") check_schema_file(file) structure_load(current_config, file) else raise ArgumentError, "unknown format #{format.inspect}" end end
def load_seed
def load_seed if seed_loader seed_loader.load_seed else raise "You tried to load seed data, but no seed loader is specified. Please specify seed " + "loader with ActiveRecord::Tasks::DatabaseTasks.seed_loader = your_seed_loader\n" + "Seed loader should respond to load_seed method" end end
def local_database?(configuration)
def local_database?(configuration) configuration['host'].blank? || LOCAL_HOSTS.include?(configuration['host']) end
def migrations_paths
def migrations_paths @migrations_paths ||= Rails.application.paths['db/migrate'].to_a end
def purge(configuration)
def purge(configuration) class_for_adapter(configuration['adapter']).new(configuration).purge end
def register_task(pattern, task)
def register_task(pattern, task) @tasks ||= {} @tasks[pattern] = task end
def root
def root @root ||= Rails.root end
def seed_loader
def seed_loader @seed_loader ||= Rails.application end
def structure_dump(*arguments)
def structure_dump(*arguments) configuration = arguments.first filename = arguments.delete_at 1 class_for_adapter(configuration['adapter']).new(*arguments).structure_dump(filename) end
def structure_load(*arguments)
def structure_load(*arguments) configuration = arguments.first filename = arguments.delete_at 1 class_for_adapter(configuration['adapter']).new(*arguments).structure_load(filename) end