Fix list error messages (#33082)

This commit is contained in:
Eugen Rochko 2024-11-28 11:13:06 +01:00 committed by GitHub
parent fa3577e04b
commit 48f3ed738f
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 12 additions and 8 deletions

View file

@ -25,17 +25,16 @@ class ListAccount < ApplicationRecord
private private
def set_follow def set_follow
self.follow = Follow.find_by!(account_id: list.account_id, target_account_id: account.id) self.follow = Follow.find_by(account_id: list.account_id, target_account_id: account.id)
rescue ActiveRecord::RecordNotFound self.follow_request = FollowRequest.find_by(account_id: list.account_id, target_account_id: account.id) if follow.nil?
self.follow_request = FollowRequest.find_by!(account_id: list.account_id, target_account_id: account.id)
end end
def validate_relationship def validate_relationship
return if list.account_id == account_id return if list_owner_account_is_account?
errors.add(:account_id, 'follow relationship missing') if follow_id.nil? && follow_request_id.nil? errors.add(:account_id, :must_be_following) if follow_id.nil? && follow_request_id.nil?
errors.add(:follow, 'mismatched accounts') if follow_id.present? && follow.target_account_id != account_id errors.add(:follow, :invalid) if follow_id.present? && follow.target_account_id != account_id
errors.add(:follow_request, 'mismatched accounts') if follow_request_id.present? && follow_request.target_account_id != account_id errors.add(:follow_request, :invalid) if follow_request_id.present? && follow_request.target_account_id != account_id
end end
def list_owner_account_is_account? def list_owner_account_is_account?

View file

@ -39,6 +39,11 @@ en:
attributes: attributes:
data: data:
malformed: is malformed malformed: is malformed
list_account:
attributes:
account_id:
taken: is already on the list
must_be_following: must be a followed account
status: status:
attributes: attributes:
reblog: reblog:

View file

@ -95,7 +95,7 @@ RSpec.describe 'Accounts' do
it 'does not add the account to the list', :aggregate_failures do it 'does not add the account to the list', :aggregate_failures do
subject subject
expect(response).to have_http_status(404) expect(response).to have_http_status(422)
expect(response.content_type) expect(response.content_type)
.to start_with('application/json') .to start_with('application/json')
expect(list.accounts).to_not include(bob) expect(list.accounts).to_not include(bob)