Class: ActiveRecord::MigrationContext
Relationships & Source Files | |
Inherits: | Object |
Defined in: | activerecord/lib/active_record/migration.rb |
Overview
Migration Context
MigrationContext
sets the context in which a migration is run.
A migration context requires the path to the migrations is set in the #migrations_paths parameter. Optionally a #schema_migration class can be provided. Multiple database applications will instantiate a SchemaMigration
object per database. From the Rake tasks, Rails will handle this for you.
Class Method Summary
Instance Attribute Summary
- #internal_metadata readonly
- #migrations_paths readonly
- #schema_migration readonly
- #validate_timestamp? ⇒ Boolean readonly private
- #needs_migration? ⇒ Boolean readonly Internal use only
- #protected_environment? ⇒ Boolean readonly Internal use only
Instance Method Summary
-
#migrate(target_version = nil, &block)
Runs the migrations in the
migrations_path
. - #connection private
- #connection_pool private
- #migration_files private
- #move(direction, steps) private
- #parse_migration_filename(filename) private
- #valid_migration_timestamp?(version) ⇒ Boolean private
- #current_environment Internal use only
- #current_version Internal use only
- #down(target_version = nil, &block) Internal use only
- #forward(steps = 1) Internal use only
- #get_all_versions Internal use only
- #last_stored_environment Internal use only
- #migrations Internal use only
- #migrations_status Internal use only
- #open Internal use only
- #pending_migration_versions Internal use only
- #rollback(steps = 1) Internal use only
- #run(direction, target_version) Internal use only
- #up(target_version = nil, &block) Internal use only
Constructor Details
.new(migrations_paths, schema_migration = nil, internal_metadata = nil) ⇒ MigrationContext
# File 'activerecord/lib/active_record/migration.rb', line 1215
def initialize(migrations_paths, schema_migration = nil, = nil) @migrations_paths = migrations_paths @schema_migration = schema_migration || SchemaMigration.new(connection_pool) @internal_metadata = || InternalMetadata.new(connection_pool) end
Instance Attribute Details
#internal_metadata (readonly)
[ GitHub ]# File 'activerecord/lib/active_record/migration.rb', line 1213
attr_reader :migrations_paths, :schema_migration, :
#migrations_paths (readonly)
[ GitHub ]# File 'activerecord/lib/active_record/migration.rb', line 1213
attr_reader :migrations_paths, :schema_migration, :
#needs_migration? ⇒ Boolean
(readonly)
# File 'activerecord/lib/active_record/migration.rb', line 1296
def needs_migration? # :nodoc: pending_migration_versions.size > 0 end
#protected_environment? ⇒ Boolean
(readonly)
# File 'activerecord/lib/active_record/migration.rb', line 1345
def protected_environment? # :nodoc: ActiveRecord::Base.protected_environments.include?(last_stored_environment) if last_stored_environment end
#schema_migration (readonly)
[ GitHub ]# File 'activerecord/lib/active_record/migration.rb', line 1213
attr_reader :migrations_paths, :schema_migration, :
#validate_timestamp? ⇒ Boolean
(readonly, private)
[ GitHub ]
# File 'activerecord/lib/active_record/migration.rb', line 1378
def ActiveRecord. && ActiveRecord. end
Instance Method Details
#connection (private)
[ GitHub ]# File 'activerecord/lib/active_record/migration.rb', line 1361
def connection ActiveRecord::Tasks::DatabaseTasks.migration_connection end
#connection_pool (private)
[ GitHub ]# File 'activerecord/lib/active_record/migration.rb', line 1365
def connection_pool ActiveRecord::Tasks::DatabaseTasks.migration_connection_pool end
#current_environment
# File 'activerecord/lib/active_record/migration.rb', line 1341
def current_environment # :nodoc: ActiveRecord::ConnectionHandling::DEFAULT_ENV.call end
#current_version
# File 'activerecord/lib/active_record/migration.rb', line 1291
def current_version # :nodoc: get_all_versions.max || 0 rescue ActiveRecord::NoDatabaseError end
#down(target_version = nil, &block)
# File 'activerecord/lib/active_record/migration.rb', line 1265
def down(target_version = nil, &block) # :nodoc: selected_migrations = if block_given? migrations.select(&block) else migrations end Migrator.new(:down, selected_migrations, schema_migration, , target_version).migrate end
#forward(steps = 1)
#get_all_versions
# File 'activerecord/lib/active_record/migration.rb', line 1283
def get_all_versions # :nodoc: if schema_migration.table_exists? schema_migration.integer_versions else [] end end
#last_stored_environment
# File 'activerecord/lib/active_record/migration.rb', line 1349
def last_stored_environment # :nodoc: = connection_pool. return nil unless .enabled? return nil if current_version == 0 raise NoEnvironmentInSchemaError unless .table_exists? environment = [:environment] raise NoEnvironmentInSchemaError unless environment environment end
#migrate(target_version = nil, &block)
Runs the migrations in the migrations_path
.
If target_version
is nil
, migrate
will run #up.
If the #current_version and target_version
are both 0 then an empty array will be returned and no migrations will be run.
If the #current_version in the schema is greater than the target_version
, then #down will be run.
If none of the conditions are met, #up will be run with the target_version
.
# File 'activerecord/lib/active_record/migration.rb', line 1234
def migrate(target_version = nil, &block) case when target_version.nil? up(target_version, &block) when current_version == 0 && target_version == 0 [] when current_version > target_version down(target_version, &block) else up(target_version, &block) end end
#migration_files (private)
[ GitHub ]# File 'activerecord/lib/active_record/migration.rb', line 1369
def migration_files paths = Array(migrations_paths) Dir[*paths.flat_map { |path| "#{path}/**/[0-9]*_*.rb" }] end
#migrations
# File 'activerecord/lib/active_record/migration.rb', line 1304
def migrations # :nodoc: migrations = migration_files.map do |file| version, name, scope = parse_migration_filename(file) raise IllegalMigrationNameError.new(file) unless version if && ! (version) raise InvalidMigrationTimestampError.new(version, name) end version = version.to_i name = name.camelize MigrationProxy.new(name, version, file, scope) end migrations.sort_by(&:version) end
#migrations_status
# File 'activerecord/lib/active_record/migration.rb', line 1320
def migrations_status # :nodoc: db_list = schema_migration.normalized_versions file_list = migration_files.filter_map do |file| version, name, scope = parse_migration_filename(file) raise IllegalMigrationNameError.new(file) unless version if && ! (version) raise InvalidMigrationTimestampError.new(version, name) end version = schema_migration.normalize_migration_number(version) status = db_list.delete(version) ? "up" : "down" [status, version, (name + scope).humanize] end db_list.map! do |version| ["up", version, "********** NO FILE **********"] end (db_list + file_list).sort_by { |_, version, _| version.to_i } end
#move(direction, steps) (private)
[ GitHub ]# File 'activerecord/lib/active_record/migration.rb', line 1386
def move(direction, steps) migrator = Migrator.new(direction, migrations, schema_migration, ) if current_version != 0 && !migrator.current_migration raise UnknownMigrationVersionError.new(current_version) end start_index = if current_version == 0 0 else migrator.migrations.index(migrator.current_migration) end finish = migrator.migrations[start_index + steps] version = finish ? finish.version : 0 public_send(direction, version) end
#open
# File 'activerecord/lib/active_record/migration.rb', line 1279
def open # :nodoc: Migrator.new(:up, migrations, schema_migration, ) end
#parse_migration_filename(filename) (private)
[ GitHub ]# File 'activerecord/lib/active_record/migration.rb', line 1374
def parse_migration_filename(filename) File.basename(filename).scan(Migration::MigrationFilenameRegexp).first end
#pending_migration_versions
# File 'activerecord/lib/active_record/migration.rb', line 1300
def pending_migration_versions # :nodoc: migrations.collect(&:version) - get_all_versions end
#rollback(steps = 1)
#run(direction, target_version)
# File 'activerecord/lib/active_record/migration.rb', line 1275
def run(direction, target_version) # :nodoc: Migrator.new(direction, migrations, schema_migration, , target_version).run end
#up(target_version = nil, &block)
# File 'activerecord/lib/active_record/migration.rb', line 1255
def up(target_version = nil, &block) # :nodoc: selected_migrations = if block_given? migrations.select(&block) else migrations end Migrator.new(:up, selected_migrations, schema_migration, , target_version).migrate end