Class: ActiveRecord::Migrator
- Inherits:
-
Object
- Object
- ActiveRecord::Migrator
- Defined in:
- lib/active_record/migration.rb
Overview
:nodoc:
Class Attribute Summary collapse
-
.migrations_paths ⇒ Object
Returns the value of attribute migrations_paths.
Class Method Summary collapse
-
.current_version ⇒ Object
For cases where a table doesn’t exist like loading from schema cache.
Instance Method Summary collapse
- #current_migration ⇒ Object (also: #current)
- #current_version ⇒ Object
-
#initialize(direction, migrations, schema_migration, internal_metadata, target_version = nil) ⇒ Migrator
constructor
A new instance of Migrator.
- #load_migrated ⇒ Object
- #migrate ⇒ Object
- #migrated ⇒ Object
- #migrations ⇒ Object
- #pending_migrations ⇒ Object
- #run ⇒ Object
- #runnable ⇒ Object
Constructor Details
#initialize(direction, migrations, schema_migration, internal_metadata, target_version = nil) ⇒ Migrator
Returns a new instance of Migrator.
1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 |
# File 'lib/active_record/migration.rb', line 1424 def initialize(direction, migrations, schema_migration, , target_version = nil) @direction = direction @target_version = target_version @migrated_versions = nil @migrations = migrations @schema_migration = schema_migration @internal_metadata = validate(@migrations) @schema_migration.create_table @internal_metadata.create_table end |
Class Attribute Details
.migrations_paths ⇒ Object
Returns the value of attribute migrations_paths.
1410 1411 1412 |
# File 'lib/active_record/migration.rb', line 1410 def migrations_paths @migrations_paths end |
Class Method Details
.current_version ⇒ Object
For cases where a table doesn’t exist like loading from schema cache
1413 1414 1415 1416 1417 1418 1419 |
# File 'lib/active_record/migration.rb', line 1413 def current_version connection_pool = ActiveRecord::Tasks::DatabaseTasks.migration_connection_pool schema_migration = SchemaMigration.new(connection_pool) = InternalMetadata.new(connection_pool) MigrationContext.new(migrations_paths, schema_migration, ).current_version end |
Instance Method Details
#current_migration ⇒ Object Also known as: current
1442 1443 1444 |
# File 'lib/active_record/migration.rb', line 1442 def current_migration migrations.detect { |m| m.version == current_version } end |
#current_version ⇒ Object
1438 1439 1440 |
# File 'lib/active_record/migration.rb', line 1438 def current_version migrated.max || 0 end |
#load_migrated ⇒ Object
1487 1488 1489 |
# File 'lib/active_record/migration.rb', line 1487 def load_migrated @migrated_versions = Set.new(@schema_migration.integer_versions) end |
#migrate ⇒ Object
1455 1456 1457 1458 1459 1460 1461 |
# File 'lib/active_record/migration.rb', line 1455 def migrate if use_advisory_lock? with_advisory_lock { migrate_without_lock } else migrate_without_lock end end |
#migrated ⇒ Object
1483 1484 1485 |
# File 'lib/active_record/migration.rb', line 1483 def migrated @migrated_versions || load_migrated end |
#migrations ⇒ Object
1474 1475 1476 |
# File 'lib/active_record/migration.rb', line 1474 def migrations down? ? @migrations.reverse : @migrations.sort_by(&:version) end |
#pending_migrations ⇒ Object
1478 1479 1480 1481 |
# File 'lib/active_record/migration.rb', line 1478 def pending_migrations already_migrated = migrated migrations.reject { |m| already_migrated.include?(m.version) } end |
#run ⇒ Object
1447 1448 1449 1450 1451 1452 1453 |
# File 'lib/active_record/migration.rb', line 1447 def run if use_advisory_lock? with_advisory_lock { run_without_lock } else run_without_lock end end |
#runnable ⇒ Object
1463 1464 1465 1466 1467 1468 1469 1470 1471 1472 |
# File 'lib/active_record/migration.rb', line 1463 def runnable runnable = migrations[start..finish] if up? runnable.reject { |m| ran?(m) } else # skip the last migration if we're headed down, but not ALL the way down runnable.pop if target runnable.find_all { |m| ran?(m) } end end |