2019-04-29 20:27:42 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-02-08 12:47:35 -05:00
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
describe Jobs::CleanUpEmailLogs do
|
2019-05-06 23:12:20 -04:00
|
|
|
fab!(:email_log) { Fabricate(:email_log, created_at: 2.years.ago) }
|
|
|
|
fab!(:email_log2) { Fabricate(:email_log, created_at: 2.weeks.ago) }
|
|
|
|
fab!(:email_log3) { Fabricate(:email_log, created_at: 2.days.ago) }
|
2016-02-08 12:47:35 -05:00
|
|
|
|
2018-10-07 23:11:00 -04:00
|
|
|
let!(:skipped_email_log) do
|
2018-07-24 00:55:43 -04:00
|
|
|
Fabricate(:skipped_email_log, created_at: 2.years.ago)
|
2016-02-08 12:47:35 -05:00
|
|
|
end
|
|
|
|
|
2019-05-06 23:12:20 -04:00
|
|
|
fab!(:skipped_email_log2) { Fabricate(:skipped_email_log) }
|
2018-10-07 23:11:00 -04:00
|
|
|
|
2018-07-27 00:32:07 -04:00
|
|
|
it "removes old email logs" do
|
2016-02-08 12:47:35 -05:00
|
|
|
Jobs::CleanUpEmailLogs.new.execute({})
|
2018-10-07 23:11:00 -04:00
|
|
|
expect(EmailLog.all).to contain_exactly(email_log2, email_log3)
|
|
|
|
expect(SkippedEmailLog.all).to contain_exactly(skipped_email_log2)
|
2016-02-08 12:47:35 -05:00
|
|
|
end
|
|
|
|
|
2016-02-08 16:18:52 -05:00
|
|
|
it "does not remove old email logs when delete_email_logs_after_days is 0" do
|
|
|
|
SiteSetting.delete_email_logs_after_days = 0
|
2016-02-08 12:47:35 -05:00
|
|
|
Jobs::CleanUpEmailLogs.new.execute({})
|
2018-10-07 23:11:00 -04:00
|
|
|
|
|
|
|
expect(EmailLog.all).to contain_exactly(email_log, email_log2, email_log3)
|
|
|
|
|
|
|
|
expect(SkippedEmailLog.all).to contain_exactly(
|
|
|
|
skipped_email_log,
|
|
|
|
skipped_email_log2
|
|
|
|
)
|
2016-02-08 12:47:35 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|