users: fix name changes not being validated.
Fix names not being validated when a user changes their name. Regression in 5ce724f1e.
This commit is contained in:
@@ -6,7 +6,7 @@ class UserNameChangeRequest < ApplicationRecord
|
|||||||
|
|
||||||
validate :not_limited, on: :create
|
validate :not_limited, on: :create
|
||||||
validates :original_name, presence: true
|
validates :original_name, presence: true
|
||||||
validates :desired_name, presence: true
|
validates :desired_name, user_name: true, presence: true, on: :create
|
||||||
|
|
||||||
after_create :update_name!
|
after_create :update_name!
|
||||||
|
|
||||||
|
|||||||
@@ -28,6 +28,14 @@ class UserNameChangeRequestsControllerTest < ActionDispatch::IntegrationTest
|
|||||||
assert_redirected_to profile_path
|
assert_redirected_to profile_path
|
||||||
assert_equal("zun", @user.reload.name)
|
assert_equal("zun", @user.reload.name)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
should "fail if the new name is invalid" do
|
||||||
|
assert_no_changes(-> { @user.reload.name }) do
|
||||||
|
post_auth user_name_change_requests_path, @user, params: { user_name_change_request: { desired_name: "foo__bar" }}
|
||||||
|
|
||||||
|
assert_response :success
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context "show action" do
|
context "show action" do
|
||||||
|
|||||||
@@ -15,11 +15,9 @@ class UserNameChangeRequestTest < ActiveSupport::TestCase
|
|||||||
|
|
||||||
should "not validate if the desired name already exists" do
|
should "not validate if the desired name already exists" do
|
||||||
assert_difference("UserNameChangeRequest.count", 0) do
|
assert_difference("UserNameChangeRequest.count", 0) do
|
||||||
req = UserNameChangeRequest.create(
|
req = build(:user_name_change_request, user: @requester, original_name: @requester.name, desired_name: @requester.name)
|
||||||
:user_id => @requester.id,
|
req.valid?
|
||||||
:original_name => @requester.name,
|
|
||||||
:desired_name => @requester.name
|
|
||||||
)
|
|
||||||
assert_equal(["Desired name already exists"], req.errors.full_messages)
|
assert_equal(["Desired name already exists"], req.errors.full_messages)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user