如何在运行rails迁移时显示默认消息?

时间:2013-03-18 08:25:18

标签: ruby ruby-on-rails-3 activerecord rails-migrations

我们正在将表数据移动到另一个数据库进行存档。因此,当用户在主数据库中添加迁移时,我希望显示一条默认消息,提醒他们对归档数据库中的表执行相同的迁移。如何在不必在迁移中手动添加消息的情况下执行此操作?

1 个答案:

答案 0 :(得分:1)

Prakash提出了一个优雅的解决方案。但是你最初的问题是关于覆盖默认任务以添加我认为的消息。

也许尝试这样的事情。礼貌:http://metaskills.net/2010/05/26/the-alias_method_chain-of-rake-override-rake-task/

Rake::TaskManager.class_eval do
  def alias_task(fq_name)
    new_name = "#{fq_name}:original"
    @tasks[new_name] = @tasks.delete(fq_name)
  end
end

def alias_task(fq_name)
  Rake.application.alias_task(fq_name)
end

def override_task(*args, &block)
  name, params, deps = Rake.application.resolve_args(args.dup)
  fq_name = Rake.application.instance_variable_get(:@scope).dup.push(name).join(':')
  alias_task(fq_name)
  Rake::Task.define_task(*args, &block)
end

现在你可以像这样覆盖rake db:migrate。

 namespace :db do
    override_task :migrate => :environment do
      # Your message here
      # To invoke the original task add ":original" to its name
      Rake::Task["db:migrate:original"].execute
      ...
    end
 end