Mam aplikację szyny, która łączy się z wieloma bazami danych. Pisałem niestandardowe zadanie nachylenia, który wygląda tak:Dlaczego zadanie Rake w pętli wykonuje się tylko raz?
task :migrate_accounts_schema => [:environment] do |t|
users = User.find :all, :conditions => ["state = 2"], :order => "id asc"
users.each do |user|
if user.state == 2
ActiveRecord::Base.establish_connection(
:adapter => "postgresql",
:host => user.database_host,
:port => user.database_port,
:username => user.subdomain,
:password => "#{user.database_password}",
:database => user.database_name
)
Rake::Task["db:migrate"].invoke
end
end
end
Problem polega na tym, że zadaniem który zaciągnął db: migrować tylko dla użytkowników [0] użytkownika (pierwszego użytkownika w kolekcji) i nie ma błędów, po prostu stoppes cicho .. .
Oto wyjście z prowizji --trace
** Invoke app:migrate_accounts_schema (first_time)
** Invoke environment (first_time)
** Execute environment
** Execute app:migrate_accounts_schema
** Invoke db:migrate (first_time)
** Invoke environment
** Execute db:migrate
** Invoke db:schema:dump (first_time)
** Invoke environment
** Execute db:schema:dump
** Invoke db:migrate
nie mam pojęcia, dlaczego reszta użytkowników nie dostać migracji.
sprawdzić źródło [tutaj] (http://rake.rubyforge.org/classes/Rake/Task.html) – lebreeze
to zadziałało :) Dziękuję :) –
na ten wydaje się bardzo intuicyjne do mnie. Jakieś pomysły, dlaczego tak to zrobili? – marcovtwout