我有一个带有Rake任务的Rakefile
我通常会从命令行调用:
rake blog:post Title
我想编写一个多次调用Rake任务的Ruby脚本,但我看到的唯一解决方案是使用``(反引号)或system
进行查找。
这样做的正确方法是什么?
答案 0 :(得分:43)
require 'rake'
require 'rake/rdoctask'
require 'rake/testtask'
require 'tasks/rails'
def capture_stdout
s = StringIO.new
oldstdout = $stdout
$stdout = s
yield
s.string
ensure
$stdout = oldstdout
end
Rake.application.rake_require '../../lib/tasks/metric_fetcher'
results = capture_stdout {Rake.application['metric_fetcher'].invoke}
答案 1 :(得分:17)
这适用于Rake版本10.0.3:
require 'rake'
app = Rake.application
app.init
# do this as many times as needed
app.add_import 'some/other/file.rake'
# this loads the Rakefile and other imports
app.load_rakefile
app['sometask'].invoke
正如knut所说,如果你想多次调用,请使用reenable
。
答案 2 :(得分:13)
您可以使用invoke
和reenable
再次执行任务。
您的示例调用rake blog:post Title
似乎有一个参数。此参数可用作invoke
:
示例:
require 'rake'
task 'mytask', :title do |tsk, args|
p "called #{tsk} (#{args[:title]})"
end
Rake.application['mytask'].invoke('one')
Rake.application['mytask'].reenable
Rake.application['mytask'].invoke('two')
请将mytask
替换为blog:post
,而是将任务定义替换为您的rakefile {/ 1}}。
此解决方案会将结果写入stdout - 但您没有提及,您想要抑制输出。
有趣的实验:
您也可以在任务定义中调用require
。这允许任务重新启用自己。
示例:
reenable
结果(用rake 10.4.2测试):
require 'rake'
task 'mytask', :title do |tsk, args|
p "called #{tsk} (#{args[:title]})"
tsk.reenable #<-- HERE
end
Rake.application['mytask'].invoke('one')
Rake.application['mytask'].invoke('two')
答案 3 :(得分:1)
在加载了Rails的脚本中(例如describe
)
rails runner script.rb