From 31467731fa623dbeee05a956469a7f4dbbaefddb Mon Sep 17 00:00:00 2001 From: Jean-Philippe Lang Date: Fri, 5 Oct 2007 22:53:26 +0000 Subject: [PATCH] Fixed: Migration 71 broken if run with code >= r803 (Enumeration#before_save relies on an attribute added in migration 72). git-svn-id: http://redmine.rubyforge.org/svn/trunk@809 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- db/migrate/072_add_enumerations_position.rb | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/db/migrate/072_add_enumerations_position.rb b/db/migrate/072_add_enumerations_position.rb index 7def86772..6f2a93219 100644 --- a/db/migrate/072_add_enumerations_position.rb +++ b/db/migrate/072_add_enumerations_position.rb @@ -1,8 +1,11 @@ class AddEnumerationsPosition < ActiveRecord::Migration def self.up - add_column :enumerations, :position, :integer, :default => 1, :null => false + add_column(:enumerations, :position, :integer, :default => 1, :null => false) unless Enumeration.column_names.include?('position') Enumeration.find(:all).group_by(&:opt).each_value do |enums| - enums.each_with_index {|enum, i| enum.update_attribute(:position, i+1)} + enums.each_with_index do |enum, i| + # do not call model callbacks + Enumeration.update_all "position = #{i+1}", {:id => enum.id} + end end end