FEATURE: Add scheduled job to purge expired ignored users (#7211)

This commit is contained in:
Tarek Khalil 2019-03-20 10:01:43 +00:00 committed by Régis Hanol
parent eed1c9e0e3
commit fed2dd9148
2 changed files with 52 additions and 0 deletions

View File

@ -0,0 +1,9 @@
module Jobs
class PurgeExpiredIgnoredUsers < Jobs::Scheduled
every 1.day
def execute(args)
IgnoredUser.where("created_at <= ?", 4.months.ago).delete_all
end
end
end

View File

@ -0,0 +1,43 @@
require 'rails_helper'
require_dependency 'jobs/scheduled/purge_expired_ignored_users'
describe Jobs::PurgeExpiredIgnoredUsers do
subject { Jobs::PurgeExpiredIgnoredUsers.new.execute({}) }
context "with no ignored users" do
it "does nothing" do
expect { subject }.to_not change { IgnoredUser.count }
end
end
context "when some ignored users exist" do
let(:tarek) { Fabricate(:user, username: "tarek") }
let(:matt) { Fabricate(:user, username: "matt") }
let(:john) { Fabricate(:user, username: "john") }
before do
Fabricate(:ignored_user, user: tarek, ignored_user: matt)
Fabricate(:ignored_user, user: tarek, ignored_user: john)
end
context "when no expired ignored users" do
it "does nothing" do
expect { subject }.to_not change { IgnoredUser.count }
end
end
context "when there are expired ignored users" do
let(:fred) { Fabricate(:user, username: "fred") }
it "purges expired ignored users" do
freeze_time(5.months.ago) do
Fabricate(:ignored_user, user: tarek, ignored_user: fred)
end
subject
expect(IgnoredUser.find_by(ignored_user: fred)).to be_nil
end
end
end
end