discourse/spec/jobs/create_user_reviewable_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

54 lines
1.7 KiB
Ruby

# frozen_string_literal: true
describe Jobs::CreateUserReviewable do
let(:user) { Fabricate(:user) }
it "creates the reviewable" do
SiteSetting.must_approve_users = true
described_class.new.execute(user_id: user.id)
reviewable = Reviewable.find_by(target: user)
expect(reviewable).to be_present
expect(reviewable.pending?).to eq(true)
expect(reviewable.payload['username']).to eq(user.username)
expect(reviewable.payload['name']).to eq(user.name)
expect(reviewable.payload['email']).to eq(user.email)
end
it "should not raise an error if there is a reviewable already" do
SiteSetting.must_approve_users = true
described_class.new.execute(user_id: user.id)
described_class.new.execute(user_id: user.id)
reviewable = Reviewable.find_by(target: user)
expect(reviewable.reviewable_scores.size).to eq(1)
end
describe "reasons" do
it "does nothing if there's no reason" do
described_class.new.execute(user_id: user.id)
expect(Reviewable.find_by(target: user)).to be_blank
end
it "adds must_approve_users if enabled" do
SiteSetting.must_approve_users = true
described_class.new.execute(user_id: user.id)
reviewable = Reviewable.find_by(target: user)
score = reviewable.reviewable_scores.first
expect(score).to be_present
expect(score.reason).to eq('must_approve_users')
end
it "adds invite_only if enabled" do
SiteSetting.invite_only = true
described_class.new.execute(user_id: user.id)
reviewable = Reviewable.find_by(target: user)
score = reviewable.reviewable_scores.first
expect(score).to be_present
expect(score.reason).to eq('invite_only')
end
end
end