Run rake task in controller
I agree with ddfreynee, but in case you know what you need code can look like:
require 'rake'Rake::Task.clear # necessary to avoid tasks being loaded several times in dev modeSample::Application.load_tasks # providing your application name is 'sample'class RakeController < ApplicationController def run Rake::Task[params[:task]].reenable # in case you're going to invoke the same task second time. Rake::Task[params[:task]].invoke endend
You can require 'rake' and .load_tasks in an initializer instead.
I don't find it good style to call a rake task in code. I recommend putting the code for the task that you want to execute somewhere outside a rake task, and have the rake task call this code.
This not only has the advantage of being easy to call outside rake (which is what you want), but it also makes it much easier to test the rake task.
Instead of trying to call a rake task in a controller, call a service objects that contains whatever logic you are trying to execute.
class SomeController < ApplicationController def whatever SomeServiceObject.call endend
...and then, assuming you are talking about a custom rake task, have it call the service object as well:
namespace :example do desc 'important task' task :important_task do SomeServiceObject.call endend
In case you are not familiar with service objects, they are just plain old ruby classes that do a specific job. If you are trying to call some of the default rake tasks (ie: db:migrate) I would highly recommend not doing that sort of thing from a controller.