@ -46,10 +46,17 @@ RSpec.describe Exports::CaseLogExportService do
end
end
context " and case logs are available for export " do
context " and case logs are available for export " do
let ( :time_now ) { Time . zone . now }
before do
before do
Timecop . freeze ( time_now )
case_log
case_log
end
end
after do
LogsExport . destroy_all
end
it " generates an XML export file with the expected filename " do
it " generates an XML export file with the expected filename " do
expect ( storage_service ) . to receive ( :write_file ) . with ( expected_data_filename , any_args )
expect ( storage_service ) . to receive ( :write_file ) . with ( expected_data_filename , any_args )
export_service . export_case_logs
export_service . export_case_logs
@ -63,6 +70,30 @@ RSpec.describe Exports::CaseLogExportService do
export_service . export_case_logs
export_service . export_case_logs
expect ( actual_content ) . to eq ( expected_content )
expect ( actual_content ) . to eq ( expected_content )
end
end
it " creates a logs export record in a database with correct time " do
export_service . export_case_logs
records_from_db = ActiveRecord :: Base . connection . execute ( " select started_at, id from logs_exports " ) . to_a
expect ( records_from_db [ 0 ] [ " started_at " ] ) . to eq ( time_now )
expect ( records_from_db . count ) . to eq ( 1 )
end
it " gets the logs for correct timeframe " do
start_time = Time . zone . local ( 2022 , 4 , 13 , 2 , 2 , 2 )
export = LogsExport . new ( started_at : start_time , daily_run_number : 1 )
export . save!
params = { from : start_time , to : time_now }
allow ( CaseLog ) . to receive ( :where ) . with ( " updated_at >= :from and updated_at <= :to " , params ) . once . and_return ( [ ] )
export_service . export_case_logs
end
context " when this is the first export " do
it " gets the logs for the timeframe up until the current time " do
params = { to : time_now }
allow ( CaseLog ) . to receive ( :where ) . with ( " updated_at <= :to " , params ) . once . and_return ( [ ] )
export_service . export_case_logs
end
end
end
end
context " and a previous export has run the same day " do
context " and a previous export has run the same day " do
@ -75,5 +106,15 @@ RSpec.describe Exports::CaseLogExportService do
export_service . export_case_logs
export_service . export_case_logs
end
end
end
end
context " when export has an error " do
it " does not save a record in the database " do
allow ( storage_service ) . to receive ( :write_file ) . and_raise ( StandardError . new ( " This is an exception " ) )
export = LogsExport . new
allow ( LogsExport ) . to receive ( :new ) . and_return ( export )
expect ( export ) . not_to receive ( :save! )
expect { export_service . export_case_logs } . to raise_error ( StandardError )
end
end
end
end
end
end