Class: ActiveRecord::Migration::Compatibility::V5_0

Inherits:
V5_1
  • Object
show all
Defined in:
lib/active_record/migration/compatibility.rb

Direct Known Subclasses

V4_2

Defined Under Namespace

Modules: TableDefinition

Instance Method Summary collapse

Methods inherited from V5_1

#change_column

Instance Method Details

#add_column(table_name, column_name, type, options = {}) ⇒ Object



103
104
105
106
107
108
109
# File 'lib/active_record/migration/compatibility.rb', line 103

def add_column(table_name, column_name, type, options = {})
  if type == :primary_key
    type = :integer
    options[:primary_key] = true
  end
  super
end

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



111
112
113
# File 'lib/active_record/migration/compatibility.rb', line 111

def add_reference(table_name, ref_name, **options)
  super(table_name, ref_name, type: :integer, **options)
end

#change_table(table_name, options = {}) ⇒ Object



81
82
83
84
85
86
87
88
89
# File 'lib/active_record/migration/compatibility.rb', line 81

def change_table(table_name, options = {})
  if block_given?
    super do |t|
      yield compatible_table_definition(t)
    end
  else
    super
  end
end

#create_join_table(table_1, table_2, column_options: {}, **options) ⇒ Object



91
92
93
94
95
96
97
98
99
100
101
# File 'lib/active_record/migration/compatibility.rb', line 91

def create_join_table(table_1, table_2, column_options: {}, **options)
  column_options.reverse_merge!(type: :integer)

  if block_given?
    super do |t|
      yield compatible_table_definition(t)
    end
  else
    super
  end
end

#create_table(table_name, options = {}) ⇒ Object



52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# File 'lib/active_record/migration/compatibility.rb', line 52

def create_table(table_name, options = {})
  if connection.adapter_name == "PostgreSQL"
    if options[:id] == :uuid && !options.key?(:default)
      options[:default] = "uuid_generate_v4()"
    end
  end

  unless connection.adapter_name == "Mysql2" && options[:id] == :bigint
    if [:integer, :bigint].include?(options[:id]) && !options.key?(:default)
      options[:default] = nil
    end
  end

  # Since 5.1 PostgreSQL adapter uses bigserial type for primary
  # keys by default and MySQL uses bigint. This compat layer makes old migrations utilize
  # serial/int type instead -- the way it used to work before 5.1.
  unless options.key?(:id)
    options[:id] = :integer
  end

  if block_given?
    super do |t|
      yield compatible_table_definition(t)
    end
  else
    super
  end
end