2019-04-30 10:27:42 +10:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2022-07-28 05:27:38 +03:00
|
|
|
RSpec.describe Jobs::CleanUpEmailLogs do
|
2019-05-07 03:12:20 +00: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 18:47:35 +01:00
|
|
|
|
2018-07-24 12:55:43 +08:00
|
|
|
let!(:skipped_email_log) { Fabricate(:skipped_email_log, created_at: 2.years.ago) }
|
2016-02-08 18:47:35 +01:00
|
|
|
|
2019-05-07 03:12:20 +00:00
|
|
|
fab!(:skipped_email_log2) { Fabricate(:skipped_email_log) }
|
2018-10-08 11:11:00 +08:00
|
|
|
|
2018-07-27 12:32:07 +08:00
|
|
|
it "removes old email logs" do
|
2016-02-08 18:47:35 +01:00
|
|
|
Jobs::CleanUpEmailLogs.new.execute({})
|
2018-10-08 11:11:00 +08:00
|
|
|
expect(EmailLog.all).to contain_exactly(email_log2, email_log3)
|
|
|
|
expect(SkippedEmailLog.all).to contain_exactly(skipped_email_log2)
|
2016-02-08 18:47:35 +01:00
|
|
|
end
|
|
|
|
|
2016-02-08 22:18:52 +01: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 18:47:35 +01:00
|
|
|
Jobs::CleanUpEmailLogs.new.execute({})
|
2018-10-08 11:11:00 +08: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 18:47:35 +01:00
|
|
|
end
|
|
|
|
end
|