Class: ActiveRecord::Migration::Compatibility::V7_0

Inherits:
V7_1 show all
Includes:
LegacyIndexName
Defined in:
activerecord/lib/active_record/migration/compatibility.rb

Direct Known Subclasses

V6_1

Defined Under Namespace

Modules: LegacyIndexName, TableDefinition

Instance Method Summary collapse

Methods included from ActiveRecord::Migration::Compatibility::V8_0::RemoveForeignKeyColumnMatch

#remove_foreign_key

Instance Method Details

#add_column(table_name, column_name, type, **options) ⇒ Object



124
125
126
127
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 124

def add_column(table_name, column_name, type, **options)
  options[:_skip_validate_options] = true
  super
end

#add_foreign_key(from_table, to_table, **options) ⇒ Object



172
173
174
175
176
177
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 172

def add_foreign_key(from_table, to_table, **options)
  if connection.adapter_name == "PostgreSQL" && options[:deferrable] == true
    options[:deferrable] = :immediate
  end
  super
end

#add_index(table_name, column_name, **options) ⇒ Object



129
130
131
132
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 129

def add_index(table_name, column_name, **options)
  options[:name] = legacy_index_name(table_name, column_name) if options[:name].nil?
  super
end

#add_reference(table_name, ref_name, **options) ⇒ Object Also known as: add_belongs_to



134
135
136
137
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 134

def add_reference(table_name, ref_name, **options)
  options[:_skip_validate_options] = true
  super
end

#change_column(table_name, column_name, type, **options) ⇒ Object



153
154
155
156
157
158
159
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 153

def change_column(table_name, column_name, type, **options)
  options[:_skip_validate_options] = true
  if connection.adapter_name == "Mysql2" || connection.adapter_name == "Trilogy"
    options[:collation] ||= :no_collation
  end
  super
end

#change_column_null(table_name, column_name, null, default = nil) ⇒ Object



161
162
163
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 161

def change_column_null(table_name, column_name, null, default = nil)
  super(table_name, column_name, !!null, default)
end

#create_table(table_name, **options) ⇒ Object



140
141
142
143
144
145
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 140

def create_table(table_name, **options)
  options[:_uses_legacy_table_name] = true
  options[:_skip_validate_options] = true

  super
end

#disable_extension(name, **options) ⇒ Object



165
166
167
168
169
170
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 165

def disable_extension(name, **options)
  if connection.adapter_name == "PostgreSQL"
    options[:force] = :cascade
  end
  super
end

#rename_table(table_name, new_name, **options) ⇒ Object



147
148
149
150
151
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 147

def rename_table(table_name, new_name, **options)
  options[:_uses_legacy_table_name] = true
  options[:_uses_legacy_index_name] = true
  super
end