discourse/spec/jobs/ignored_users_summary_spec.rb
David Taylor c9dab6fd08
DEV: Automatically require 'rails_helper' in all specs (#16077)
It's very easy to forget to add `require 'rails_helper'` at the top of every core/plugin spec file, and omissions can cause some very confusing/sporadic errors.

By setting this flag in `.rspec`, we can remove the need for `require 'rails_helper'` entirely.
2022-03-01 17:50:50 +00:00

75 lines
2.1 KiB
Ruby

# frozen_string_literal: true
describe Jobs::IgnoredUsersSummary do
before do
SiteSetting.ignored_users_count_message_threshold = 1
SiteSetting.ignored_users_message_gap_days = 365
end
subject { Jobs::IgnoredUsersSummary.new.execute({}) }
context "with no ignored users" do
it "does nothing" do
subject
expect { subject }.to_not change { Post.count }
end
end
context "when some ignored users exist" do
fab!(:tarek) { Fabricate(:user, username: "tarek") }
fab!(:matt) { Fabricate(:user, username: "matt") }
fab!(:john) { Fabricate(:user, username: "john") }
before do
Fabricate(:ignored_user, user: tarek, ignored_user: matt)
Fabricate(:ignored_user, user_id: tarek.id, ignored_user_id: john.id)
end
context "when no system message exists for the ignored users" do
context "when threshold is not hit" do
before do
SiteSetting.ignored_users_count_message_threshold = 5
end
it "does nothing" do
subject
expect { subject }.to_not change { Post.count }
end
end
context "when threshold is hit" do
it "creates a system message" do
subject
posts = Post.joins(:topic).where(topics: {
archetype: Archetype.private_message,
subtype: TopicSubtype.system_message
})
expect(posts.count).to eq(2)
expect(posts.find { |post| post.raw.include?(matt.username) }).to be_present
expect(posts.find { |post| post.raw.include?(john.username) }).to be_present
end
end
end
context "when a system message already exists for the ignored users" do
context "when threshold is not hit" do
before do
SiteSetting.ignored_users_count_message_threshold = 5
end
it "does nothing" do
subject
expect { subject }.to_not change { Post.count }
end
end
context "when threshold is hit" do
it "does nothing" do
subject
expect { subject }.to_not change { Post.count }
end
end
end
end
end