Add a log file to track deleted duplicate records

It might be interesting in some cases to check the information related
to those records.
This commit is contained in:
Javi Martín
2024-05-11 18:58:43 +02:00
parent b013a5b1b6
commit b327275d18
2 changed files with 29 additions and 4 deletions

View File

@@ -0,0 +1,21 @@
class DuplicateRecordsLogger
def info(message)
logger.info(message)
end
def logger
@logger ||= ActiveSupport::Logger.new(log_file).tap do |logger|
logger.formatter = Rails.application.config.log_formatter
end
end
private
def log_file
File.join(File.dirname(Rails.application.config.default_log_file), log_filename)
end
def log_filename
"duplicate_records.log"
end
end

View File

@@ -2,6 +2,8 @@ namespace :polls do
desc "Removes duplicate poll voters" desc "Removes duplicate poll voters"
task remove_duplicate_voters: :environment do task remove_duplicate_voters: :environment do
logger = ApplicationLogger.new logger = ApplicationLogger.new
duplicate_records_logger = DuplicateRecordsLogger.new
logger.info "Removing duplicate voters in polls" logger.info "Removing duplicate voters in polls"
Tenant.run_on_each do Tenant.run_on_each do
@@ -16,10 +18,12 @@ namespace :polls do
voter.delete voter.delete
tenant_info = " on tenant #{Tenant.current_schema}" unless Tenant.default? tenant_info = " on tenant #{Tenant.current_schema}" unless Tenant.default?
logger.info "Deleted duplicate record with ID #{voter.id} " \ log_message = "Deleted duplicate record with ID #{voter.id} " \
"from the #{Poll::Voter.table_name} table " \ "from the #{Poll::Voter.table_name} table " \
"with user_id #{user_id} " \ "with user_id #{user_id} " \
"and poll_id #{poll_id}" + tenant_info.to_s "and poll_id #{poll_id}" + tenant_info.to_s
logger.info(log_message)
duplicate_records_logger.info(log_message)
end end
end end
end end