0

I am trying to execute multiple rake tasks in a single task. All of the rake tasks are used to update the columns of respective tables. For example if health_post_id >100000 Delete that record

Now i need to pass 100000 as an argument through the command line .But I am not able to figure that out Here is the code

if Rails.env.development? or Rails.env.test?
 namespace :clear_data do


  desc 'clear time slots'
  task :clear_time_slots => :environment do
    TimeSlot.where('health_post_id > ?', p).each do |time_slots|
      time_slots.destroy
    end
  end

  desc "Clean the Practices table"
  task :clear_practice_records => :environment do
      Practice.where('health_post_id > ?', p).each do |practices|
        practices.destroy
      end
  end


  desc "clean database"
  task :clear_database => :environment do |p|
    Rake::Task['clear_data:clear_practice_records'].execute
    Rake::Task['clear_data:clear_time_slots'].execute


    end



 end
 end

1 Answers1

1

I'm not so sure, but I guess you should be able to do:

if Rails.env.development? or Rails.env.test?
 namespace :clear_data do
  desc 'clear time slots'
  task :clear_time_slots, [:post_id] => :environment do |_, args|
    TimeSlot.where('health_post_id > ?', args[:post_id]).destroy_all
  end

  desc "Clean the Practices table"
  task :clear_practice_records, [:post_id] => :environment do |_, args|
    Practice.where('health_post_id > ?', args[:post_id]).destroy_all
  end


  desc "clean database"
  task :clear_database, [:post_id] => :environment do |_, args|
    max = args[:post_id]
    Rake::Task['clear_data:clear_practice_records'].execute(post_id: max)
    Rake::Task['clear_data:clear_time_slots'].execute(post_id: max)

    #OR

    #Rake::Task['clear_data:clear_practice_records'].invoke(max)
    #Rake::Task['clear_data:clear_time_slots'].invoke(max)
  end
 end
end
oreoluwa
  • 5,553
  • 2
  • 20
  • 27