podemos-info/participa2

View on GitHub
db/migrate/20190622161259_make_authors_polymorphic.decidim.rb

Summary

Maintainability
A
0 mins
Test Coverage
# frozen_string_literal: true

# This migration comes from decidim (originally 20181016091601)

class MakeAuthorsPolymorphic < ActiveRecord::Migration[5.2]
  class Coauthorship < ApplicationRecord
    self.table_name = :decidim_coauthorships
  end

  def change
    remove_index :decidim_coauthorships, :decidim_author_id

    add_column :decidim_coauthorships, :decidim_author_type, :string

    reversible do |direction|
      direction.up do
        execute <<~SQL.squish
          UPDATE decidim_coauthorships
          SET decidim_author_type = 'Decidim::UserBaseEntity'
        SQL
      end
    end

    add_index :decidim_coauthorships,
              [:decidim_author_id, :decidim_author_type],
              name: "index_decidim_coauthorships_on_decidim_author"

    change_column_null :decidim_coauthorships, :decidim_author_id, false
    change_column_null :decidim_coauthorships, :decidim_author_type, false

    Coauthorship.reset_column_information
  end
end