Some tasks don't have to run on every tenant. The task to calculate the TSV is only done for records which were present before we added the TSV column, and that isn't going to happen in any tenants because we added the TSV column before adding the tenants table. Similarly, the migration needed for existing polls isn't necessary because there weren't any tenants before we allowed to set the starting/ending time to polls. We aren't adding any tests for these tasks because tests for rake tasks are slow and tests creating tenants are also slow, making the combination of the two even slower, particularly if we add tests for every single task we're changing. We're adding tests for the `.run_on_each` method instead.
33 lines
901 B
Ruby
33 lines
901 B
Ruby
namespace :stats do
|
|
desc "Generates stats which are not cached yet"
|
|
task generate: :environment do
|
|
ApplicationLogger.new.info "Updating budget and poll stats"
|
|
|
|
Tenant.run_on_each do
|
|
admin_ability = Ability.new(Administrator.first.user)
|
|
|
|
Budget.accessible_by(admin_ability, :read_stats).find_each do |budget|
|
|
Budget::Stats.new(budget).generate
|
|
print "."
|
|
end
|
|
|
|
Poll.accessible_by(admin_ability, :stats).find_each do |poll|
|
|
Poll::Stats.new(poll).generate
|
|
print "."
|
|
end
|
|
end
|
|
end
|
|
|
|
desc "Expires stats cache"
|
|
task expire_cache: :environment do
|
|
Tenant.run_on_each do
|
|
[Budget, Poll].each do |model_class|
|
|
model_class.find_each { |record| record.find_or_create_stats_version.touch }
|
|
end
|
|
end
|
|
end
|
|
|
|
desc "Deletes stats cache and generates it again"
|
|
task regenerate: [:expire_cache, :generate]
|
|
end
|