forked from e621ng/e621ng
[Tests] Fix user feedback tests
This commit is contained in:
parent
51e3d7d50d
commit
924e519b4c
@ -4,7 +4,7 @@ class UserFeedbacksControllerTest < ActionDispatch::IntegrationTest
|
||||
context "The user feedbacks controller" do
|
||||
setup do
|
||||
@user = create(:user)
|
||||
@critic = create(:privileged_user)
|
||||
@critic = create(:moderator_user)
|
||||
@mod = create(:moderator_user)
|
||||
end
|
||||
|
||||
|
@ -3,6 +3,9 @@ require 'test_helper'
|
||||
class UserFeedbackTest < ActiveSupport::TestCase
|
||||
context "A user's feedback" do
|
||||
setup do
|
||||
@user = create(:user)
|
||||
@mod = create(:moderator_user)
|
||||
CurrentUser.user = @mod
|
||||
CurrentUser.ip_addr = "127.0.0.1"
|
||||
end
|
||||
|
||||
@ -12,57 +15,43 @@ class UserFeedbackTest < ActiveSupport::TestCase
|
||||
end
|
||||
|
||||
should "create a dmail" do
|
||||
user = FactoryBot.create(:user)
|
||||
privileged = FactoryBot.create(:privileged_user)
|
||||
member = FactoryBot.create(:user)
|
||||
|
||||
dmail = <<~EOS.chomp
|
||||
@#{privileged.name} created a "positive record":/user_feedbacks?search[user_id]=#{user.id} for your account:
|
||||
@#{@mod.name} created a "positive record":/user_feedbacks?search[user_id]=#{@user.id} for your account:
|
||||
|
||||
good job!
|
||||
EOS
|
||||
|
||||
CurrentUser.user = privileged
|
||||
assert_difference("Dmail.count", 1) do
|
||||
FactoryBot.create(:user_feedback, :user => user, :body => "good job!")
|
||||
assert_equal(dmail, user.dmails.last.body)
|
||||
FactoryBot.create(:user_feedback, user: @user, body: "good job!")
|
||||
assert_equal(dmail, @user.dmails.last.body)
|
||||
end
|
||||
end
|
||||
|
||||
should "not validate if the creator is the user" do
|
||||
privileged_user = FactoryBot.create(:privileged_user)
|
||||
CurrentUser.user = privileged_user
|
||||
feedback = FactoryBot.build(:user_feedback, :user => privileged_user)
|
||||
feedback = FactoryBot.build(:user_feedback, user: @mod)
|
||||
feedback.save
|
||||
assert_equal(["You cannot submit feedback for yourself"], feedback.errors.full_messages)
|
||||
end
|
||||
|
||||
context "with a no_feedback user" do
|
||||
setup do
|
||||
@privileged_user = FactoryBot.create(:privileged_user, no_feedback: true)
|
||||
CurrentUser.user = @privileged_user
|
||||
@mod2 = FactoryBot.create(:moderator_user, no_feedback: true)
|
||||
CurrentUser.user = @mod2
|
||||
end
|
||||
|
||||
should "not validate" do
|
||||
feedback = FactoryBot.build(:user_feedback, :user => @privileged_user)
|
||||
feedback = FactoryBot.build(:user_feedback, user: @mod)
|
||||
feedback.save
|
||||
assert_equal(["You cannot submit feedback"], feedback.errors.full_messages.grep(/^You cannot submit feedback$/))
|
||||
end
|
||||
end
|
||||
|
||||
should "not validate if the creator is not gold" do
|
||||
user = FactoryBot.create(:user)
|
||||
should "not validate if the creator has no permissions" do
|
||||
privileged = FactoryBot.create(:privileged_user)
|
||||
member = FactoryBot.create(:user)
|
||||
|
||||
CurrentUser.user = privileged
|
||||
feedback = FactoryBot.create(:user_feedback, :user => user)
|
||||
assert(feedback.errors.empty?)
|
||||
|
||||
CurrentUser.user = member
|
||||
feedback = FactoryBot.build(:user_feedback, :user => user)
|
||||
feedback = FactoryBot.build(:user_feedback, user: @user)
|
||||
feedback.save
|
||||
assert_equal(["You must be gold"], feedback.errors.full_messages)
|
||||
assert_equal(["You must be moderator"], feedback.errors.full_messages)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
Loading…
Reference in New Issue
Block a user