require 'spec_helper' require Rails.root.join('db', 'post_migrate', '20171207150343_remove_soft_removed_objects.rb') describe RemoveSoftRemovedObjects, :migration do describe '#up' do it 'removes various soft removed objects' do 5.times do create_with_deleted_at(:issue) end regular_issue = create(:issue) run_migration expect(Issue.count).to eq(1) expect(Issue.first).to eq(regular_issue) end it 'removes the temporary indexes once soft removed data has been removed' do migration = described_class.new run_migration disable_migrations_output do expect(migration.temporary_index_exists?(Issue)).to eq(false) end end it 'removes routes of soft removed personal namespaces' do namespace = create_with_deleted_at(:namespace) group = create(:group) expect(Route.where(source: namespace).exists?).to eq(true) expect(Route.where(source: group).exists?).to eq(true) run_migration expect(Route.where(source: namespace).exists?).to eq(false) expect(Route.where(source: group).exists?).to eq(true) end it 'schedules the removal of soft removed groups' do group = create_with_deleted_at(:group) admin = create(:user, admin: true) expect_any_instance_of(GroupDestroyWorker) .to receive(:perform) .with(group.id, admin.id) run_migration end it 'does not remove soft removed groups when no admin user could be found' do create_with_deleted_at(:group) expect_any_instance_of(GroupDestroyWorker) .not_to receive(:perform) run_migration end end def run_migration disable_migrations_output do migrate! end end def create_with_deleted_at(*args) row = create(*args) # We set "deleted_at" this way so we don't run into any column cache issues. row.class.where(id: row.id).update_all(deleted_at: 1.year.ago) row end end