mirror of
https://github.com/discourse/discourse.git
synced 2025-01-24 13:38:47 +08:00
3e50313fdc
Since rspec-rails 3, the default installation creates two helper files: * `spec_helper.rb` * `rails_helper.rb` `spec_helper.rb` is intended as a way of running specs that do not require Rails, whereas `rails_helper.rb` loads Rails (as Discourse's current `spec_helper.rb` does). For more information: https://www.relishapp.com/rspec/rspec-rails/docs/upgrade#default-helper-files In this commit, I've simply replaced all instances of `spec_helper` with `rails_helper`, and renamed the original `spec_helper.rb`. This brings the Discourse project closer to the standard usage of RSpec in a Rails app. At present, every spec relies on loading Rails, but there are likely many that don't need to. In a future pull request, I hope to introduce a separate, minimal `spec_helper.rb` which can be used in tests which don't rely on Rails.
60 lines
2.1 KiB
Ruby
60 lines
2.1 KiB
Ruby
# encoding: UTF-8
|
|
|
|
require 'rails_helper'
|
|
|
|
describe SpamRulesEnforcer do
|
|
|
|
Given(:ip_address) { '182.189.119.174' }
|
|
Given!(:spammer1) { Fabricate(:user, ip_address: ip_address) }
|
|
Given!(:spammer2) { Fabricate(:user, ip_address: ip_address) }
|
|
Given(:spammer3) { Fabricate(:user, ip_address: ip_address) }
|
|
|
|
context 'flag_sockpuppets is disabled' do
|
|
Given { SiteSetting.stubs(:flag_sockpuppets).returns(false) }
|
|
Given!(:first_post) { create_post(user: spammer1) }
|
|
Given!(:second_post) { create_post(user: spammer2, topic: first_post.topic) }
|
|
|
|
Then { expect(first_post.reload.spam_count).to eq(0) }
|
|
And { expect(second_post.reload.spam_count).to eq(0) }
|
|
end
|
|
|
|
context 'flag_sockpuppets is enabled' do
|
|
Given { SiteSetting.stubs(:flag_sockpuppets).returns(true) }
|
|
|
|
context 'first spammer starts a topic' do
|
|
Given!(:first_post) { create_post(user: spammer1) }
|
|
|
|
context 'second spammer replies' do
|
|
Given!(:second_post) { create_post(user: spammer2, topic: first_post.topic) }
|
|
|
|
Then { expect(first_post.reload.spam_count).to eq(1) }
|
|
And { expect(second_post.reload.spam_count).to eq(1) }
|
|
|
|
context 'third spam post' do
|
|
Given!(:third_post) { create_post(user: spammer3, topic: first_post.topic) }
|
|
|
|
Then { expect(first_post.reload.spam_count).to eq(1) }
|
|
And { expect(second_post.reload.spam_count).to eq(1) }
|
|
And { expect(third_post.reload.spam_count).to eq(1) }
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'first user is not new' do
|
|
Given!(:old_user) { Fabricate(:user, ip_address: ip_address, created_at: 2.days.ago, trust_level: TrustLevel[1]) }
|
|
|
|
context 'first user starts a topic' do
|
|
Given!(:first_post) { create_post(user: old_user) }
|
|
|
|
context 'a reply by a new user at the same IP address' do
|
|
Given!(:second_post) { create_post(user: spammer2, topic: first_post.topic) }
|
|
|
|
Then { expect(first_post.reload.spam_count).to eq(0) }
|
|
And { expect(second_post.reload.spam_count).to eq(1) }
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
end
|