2019-04-30 08:27:42 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2022-07-28 10:27:38 +08:00
|
|
|
RSpec.describe Jobs::CleanUpEmailLogs do
|
2019-05-07 11:12:20 +08: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-09 01:47:35 +08:00
|
|
|
|
2018-07-24 12:55:43 +08:00
|
|
|
let!(:skipped_email_log) { Fabricate(:skipped_email_log, created_at: 2.years.ago) }
|
2016-02-09 01:47:35 +08:00
|
|
|
|
2019-05-07 11:12:20 +08: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-09 01:47:35 +08: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-09 01:47:35 +08:00
|
|
|
end
|
|
|
|
|
2016-02-09 05:18:52 +08: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-09 01:47:35 +08: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-09 01:47:35 +08:00
|
|
|
end
|
|
|
|
end
|