2011-06-06 14:17:44 -04:00
|
|
|
require "cases/helper"
|
2010-11-18 18:52:13 -05:00
|
|
|
|
|
|
|
module ActiveRecord
|
2010-11-19 13:55:57 -05:00
|
|
|
class InvertibleMigrationTest < ActiveRecord::TestCase
|
2010-11-19 13:42:33 -05:00
|
|
|
class SilentMigration < ActiveRecord::Migration
|
|
|
|
def write(text = '')
|
|
|
|
# sssshhhhh!!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-11-19 13:55:57 -05:00
|
|
|
class InvertibleMigration < SilentMigration
|
2010-11-18 18:52:13 -05:00
|
|
|
def change
|
|
|
|
create_table("horses") do |t|
|
|
|
|
t.column :content, :text
|
|
|
|
t.column :remind_at, :datetime
|
|
|
|
end
|
|
|
|
end
|
2010-11-19 13:42:33 -05:00
|
|
|
end
|
2010-11-18 18:52:13 -05:00
|
|
|
|
2012-08-06 20:44:05 -04:00
|
|
|
class InvertibleRevertMigration < SilentMigration
|
|
|
|
def change
|
|
|
|
revert do
|
|
|
|
create_table("horses") do |t|
|
|
|
|
t.column :content, :text
|
|
|
|
t.column :remind_at, :datetime
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-11-11 14:43:57 -05:00
|
|
|
class InvertibleByPartsMigration < SilentMigration
|
|
|
|
attr_writer :test
|
|
|
|
def change
|
|
|
|
create_table("new_horses") do |t|
|
|
|
|
t.column :breed, :string
|
|
|
|
end
|
|
|
|
reversible do |dir|
|
|
|
|
@test.yield :both
|
|
|
|
dir.up { @test.yield :up }
|
|
|
|
dir.down { @test.yield :down }
|
|
|
|
end
|
|
|
|
revert do
|
|
|
|
create_table("horses") do |t|
|
|
|
|
t.column :content, :text
|
|
|
|
t.column :remind_at, :datetime
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-11-19 13:55:57 -05:00
|
|
|
class NonInvertibleMigration < SilentMigration
|
2010-11-19 13:42:33 -05:00
|
|
|
def change
|
|
|
|
create_table("horses") do |t|
|
|
|
|
t.column :content, :text
|
|
|
|
t.column :remind_at, :datetime
|
|
|
|
end
|
|
|
|
remove_column "horses", :content
|
2010-11-18 18:52:13 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-07-29 21:26:21 -04:00
|
|
|
class LegacyMigration < ActiveRecord::Migration
|
|
|
|
def self.up
|
|
|
|
create_table("horses") do |t|
|
|
|
|
t.column :content, :text
|
|
|
|
t.column :remind_at, :datetime
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.down
|
|
|
|
drop_table("horses")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-08-06 22:25:01 -04:00
|
|
|
class RevertWholeMigration < SilentMigration
|
|
|
|
def initialize(name = self.class.name, version = nil, migration)
|
|
|
|
@migration = migration
|
|
|
|
super(name, version)
|
|
|
|
end
|
|
|
|
|
|
|
|
def change
|
|
|
|
revert @migration
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
class NestedRevertWholeMigration < RevertWholeMigration
|
|
|
|
def change
|
|
|
|
revert { super }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-11-19 14:42:58 -05:00
|
|
|
def teardown
|
2012-12-22 12:10:40 -05:00
|
|
|
%w[horses new_horses].each do |table|
|
|
|
|
if ActiveRecord::Base.connection.table_exists?(table)
|
|
|
|
ActiveRecord::Base.connection.drop_table(table)
|
|
|
|
end
|
2010-11-18 18:52:13 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-11-19 13:42:33 -05:00
|
|
|
def test_no_reverse
|
2010-11-19 13:55:57 -05:00
|
|
|
migration = NonInvertibleMigration.new
|
2010-11-19 13:42:33 -05:00
|
|
|
migration.migrate(:up)
|
|
|
|
assert_raises(IrreversibleMigration) do
|
|
|
|
migration.migrate(:down)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-07-29 23:17:12 -04:00
|
|
|
def test_migrate_up
|
2010-11-19 13:55:57 -05:00
|
|
|
migration = InvertibleMigration.new
|
2010-11-18 18:52:13 -05:00
|
|
|
migration.migrate(:up)
|
|
|
|
assert migration.connection.table_exists?("horses"), "horses should exist"
|
|
|
|
end
|
|
|
|
|
2011-07-29 23:17:12 -04:00
|
|
|
def test_migrate_down
|
2010-11-19 13:55:57 -05:00
|
|
|
migration = InvertibleMigration.new
|
2010-11-18 18:52:13 -05:00
|
|
|
migration.migrate :up
|
|
|
|
migration.migrate :down
|
|
|
|
assert !migration.connection.table_exists?("horses")
|
|
|
|
end
|
2011-07-29 21:26:21 -04:00
|
|
|
|
2012-08-06 20:44:05 -04:00
|
|
|
def test_migrate_revert
|
|
|
|
migration = InvertibleMigration.new
|
|
|
|
revert = InvertibleRevertMigration.new
|
|
|
|
migration.migrate :up
|
|
|
|
revert.migrate :up
|
|
|
|
assert !migration.connection.table_exists?("horses")
|
|
|
|
revert.migrate :down
|
|
|
|
assert migration.connection.table_exists?("horses")
|
|
|
|
migration.migrate :down
|
|
|
|
assert !migration.connection.table_exists?("horses")
|
|
|
|
end
|
|
|
|
|
2012-11-11 14:43:57 -05:00
|
|
|
def test_migrate_revert_by_part
|
|
|
|
InvertibleMigration.new.migrate :up
|
|
|
|
received = []
|
|
|
|
migration = InvertibleByPartsMigration.new
|
|
|
|
migration.test = ->(dir){
|
|
|
|
assert migration.connection.table_exists?("horses")
|
|
|
|
assert migration.connection.table_exists?("new_horses")
|
|
|
|
received << dir
|
|
|
|
}
|
|
|
|
migration.migrate :up
|
|
|
|
assert_equal [:both, :up], received
|
|
|
|
assert !migration.connection.table_exists?("horses")
|
|
|
|
assert migration.connection.table_exists?("new_horses")
|
|
|
|
migration.migrate :down
|
|
|
|
assert_equal [:both, :up, :both, :down], received
|
|
|
|
assert migration.connection.table_exists?("horses")
|
|
|
|
assert !migration.connection.table_exists?("new_horses")
|
|
|
|
end
|
|
|
|
|
2012-08-06 22:25:01 -04:00
|
|
|
def test_migrate_revert_whole_migration
|
|
|
|
migration = InvertibleMigration.new
|
|
|
|
[LegacyMigration, InvertibleMigration].each do |klass|
|
|
|
|
revert = RevertWholeMigration.new(klass)
|
|
|
|
migration.migrate :up
|
|
|
|
revert.migrate :up
|
|
|
|
assert !migration.connection.table_exists?("horses")
|
|
|
|
revert.migrate :down
|
|
|
|
assert migration.connection.table_exists?("horses")
|
|
|
|
migration.migrate :down
|
|
|
|
assert !migration.connection.table_exists?("horses")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_migrate_nested_revert_whole_migration
|
|
|
|
revert = NestedRevertWholeMigration.new(InvertibleRevertMigration)
|
|
|
|
revert.migrate :down
|
|
|
|
assert revert.connection.table_exists?("horses")
|
|
|
|
revert.migrate :up
|
|
|
|
assert !revert.connection.table_exists?("horses")
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_revert_order
|
|
|
|
block = Proc.new{|t| t.string :name }
|
|
|
|
recorder = ActiveRecord::Migration::CommandRecorder.new(ActiveRecord::Base.connection)
|
|
|
|
recorder.instance_eval do
|
|
|
|
create_table("apples", &block)
|
|
|
|
revert do
|
|
|
|
create_table("bananas", &block)
|
|
|
|
revert do
|
|
|
|
create_table("clementines")
|
|
|
|
create_table("dates")
|
|
|
|
end
|
|
|
|
create_table("elderberries")
|
|
|
|
end
|
|
|
|
revert do
|
|
|
|
create_table("figs")
|
|
|
|
create_table("grapes")
|
|
|
|
end
|
|
|
|
end
|
2012-11-19 01:12:36 -05:00
|
|
|
assert_equal [[:create_table, ["apples"], block], [:drop_table, ["elderberries"], nil],
|
2012-08-06 22:25:01 -04:00
|
|
|
[:create_table, ["clementines"], nil], [:create_table, ["dates"], nil],
|
2012-11-19 01:12:36 -05:00
|
|
|
[:drop_table, ["bananas"], block], [:drop_table, ["grapes"], nil],
|
|
|
|
[:drop_table, ["figs"], nil]], recorder.commands
|
2012-08-06 22:25:01 -04:00
|
|
|
end
|
|
|
|
|
2011-07-29 21:26:21 -04:00
|
|
|
def test_legacy_up
|
|
|
|
LegacyMigration.migrate :up
|
|
|
|
assert ActiveRecord::Base.connection.table_exists?("horses"), "horses should exist"
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_legacy_down
|
|
|
|
LegacyMigration.migrate :up
|
|
|
|
LegacyMigration.migrate :down
|
|
|
|
assert !ActiveRecord::Base.connection.table_exists?("horses"), "horses should not exist"
|
|
|
|
end
|
2011-07-29 23:17:12 -04:00
|
|
|
|
|
|
|
def test_up
|
|
|
|
LegacyMigration.up
|
|
|
|
assert ActiveRecord::Base.connection.table_exists?("horses"), "horses should exist"
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_down
|
|
|
|
LegacyMigration.up
|
|
|
|
LegacyMigration.down
|
|
|
|
assert !ActiveRecord::Base.connection.table_exists?("horses"), "horses should not exist"
|
|
|
|
end
|
2012-01-10 08:49:44 -05:00
|
|
|
|
|
|
|
def test_migrate_down_with_table_name_prefix
|
|
|
|
ActiveRecord::Base.table_name_prefix = 'p_'
|
|
|
|
ActiveRecord::Base.table_name_suffix = '_s'
|
|
|
|
migration = InvertibleMigration.new
|
|
|
|
migration.migrate(:up)
|
|
|
|
assert_nothing_raised { migration.migrate(:down) }
|
|
|
|
assert !ActiveRecord::Base.connection.table_exists?("p_horses_s"), "p_horses_s should not exist"
|
|
|
|
ensure
|
|
|
|
ActiveRecord::Base.table_name_prefix = ActiveRecord::Base.table_name_suffix = ''
|
|
|
|
end
|
|
|
|
|
2010-11-18 18:52:13 -05:00
|
|
|
end
|
|
|
|
end
|