From b1a4505e94bfb51f9aa6db4faff1552fba67b51b Mon Sep 17 00:00:00 2001 From: Karel Picman Date: Wed, 15 Mar 2017 10:56:29 +0100 Subject: [PATCH] Error migrate plugin v1.5.9 #692 --- db/migrate/20160217133001_status_deleted.rb | 45 ++++++++++++++------- 1 file changed, 31 insertions(+), 14 deletions(-) diff --git a/db/migrate/20160217133001_status_deleted.rb b/db/migrate/20160217133001_status_deleted.rb index 99301acb..c3a8cdde 100644 --- a/db/migrate/20160217133001_status_deleted.rb +++ b/db/migrate/20160217133001_status_deleted.rb @@ -20,25 +20,42 @@ class StatusDeleted < ActiveRecord::Migration - def self.cast_integer(colname) - adapter_name = ActiveRecord::Base.connection.adapter_name.downcase - case adapter_name + def self.up + case ActiveRecord::Base.connection.adapter_name.downcase when /postgresql/ - 'INTEGER USING CASE WHEN TRUE THEN 1 ELSE 0 END' + execute 'ALTER TABLE dmsf_folders ALTER deleted DROP DEFAULT;' + change_column :dmsf_folders, :deleted, 'INTEGER USING CASE WHEN TRUE THEN 1 ELSE 0 END', :null => false, :default => DmsfFolder::STATUS_ACTIVE + execute 'ALTER TABLE dmsf_files ALTER deleted DROP DEFAULT;' + change_column :dmsf_files, :deleted, 'INTEGER USING CASE WHEN TRUE THEN 1 ELSE 0 END', :null => false, :default => DmsfFile::STATUS_ACTIVE + execute 'ALTER TABLE dmsf_file_revisions ALTER deleted DROP DEFAULT;' + change_column :dmsf_file_revisions, :deleted, 'INTEGER USING CASE WHEN TRUE THEN 1 ELSE 0 END', :null => false, :default => DmsfFileRevision::STATUS_ACTIVE + execute 'ALTER TABLE dmsf_links ALTER deleted DROP DEFAULT;' + change_column :dmsf_links, :deleted, 'INTEGER USING CASE WHEN TRUE THEN 1 ELSE 0 END', :null => false, :default => DmsfLink::STATUS_ACTIVE else - 'integer' + change_column :dmsf_folders, :deleted, :integer, :default => DmsfFolder::STATUS_ACTIVE + change_column :dmsf_files, :deleted, :integer, :default => DmsfFile::STATUS_ACTIVE + change_column :dmsf_file_revisions, :integer, :boolean, :default => DmsfFile::STATUS_ACTIVE + change_column :dmsf_links, :deleted, :integer, :default => DmsfFile::STATUS_ACTIVE end end - def self.up - execute 'ALTER TABLE dmsf_folders ALTER deleted DROP DEFAULT;' - change_column :dmsf_folders, :deleted, cast_integer(:deleted), :null => false, :default => DmsfFolder::STATUS_ACTIVE - execute 'ALTER TABLE dmsf_files ALTER deleted DROP DEFAULT;' - change_column :dmsf_files, :deleted, cast_integer(:deleted), :null => false, :default => DmsfFile::STATUS_ACTIVE - execute 'ALTER TABLE dmsf_file_revisions ALTER deleted DROP DEFAULT;' - change_column :dmsf_file_revisions, :deleted, cast_integer(:deleted), :null => false, :default => DmsfFileRevision::STATUS_ACTIVE - execute 'ALTER TABLE dmsf_links ALTER deleted DROP DEFAULT;' - change_column :dmsf_links, :deleted, cast_integer(:deleted), :null => false, :default => DmsfLink::STATUS_ACTIVE + def self.down + case ActiveRecord::Base.connection.adapter_name.downcase + when /postgresql/ + execute 'ALTER TABLE dmsf_folders ALTER deleted DROP DEFAULT;' + change_column :dmsf_folders, :deleted, 'BOOLEAN USING CASE WHEN 1 THEN TRUE ELSE FALSE END', :null => false, :default => DmsfFolder::STATUS_ACTIVE + execute 'ALTER TABLE dmsf_files ALTER deleted DROP DEFAULT;' + change_column :dmsf_files, :deleted, 'BOOLEAN USING CASE WHEN 1 THEN TRUE ELSE FALSE END', :null => false, :default => DmsfFile::STATUS_ACTIVE + execute 'ALTER TABLE dmsf_file_revisions ALTER deleted DROP DEFAULT;' + change_column :dmsf_file_revisions, :deleted, 'BOOLEAN USING CASE WHEN 1 THEN TRUE ELSE FALSE END', :null => false, :default => DmsfFileRevision::STATUS_ACTIVE + execute 'ALTER TABLE dmsf_links ALTER deleted DROP DEFAULT;' + change_column :dmsf_links, :deleted, 'BOOLEAN USING CASE WHEN 1 THEN TRUE ELSE FALSE END', :null => false, :default => DmsfLink::STATUS_ACTIVE + else + change_column :dmsf_folders, :deleted, :boolean, :null => false, :default => false + change_column :dmsf_files, :deleted, :boolean, :null => false, :default => false + change_column :dmsf_file_revisions, :boolean, :null => false, :default => false + change_column :dmsf_links, :deleted, :boolean, :null => false, :default => false + end end end \ No newline at end of file