mirror of
https://github.com/mastodon/mastodon.git
synced 2024-12-22 17:35:40 +01:00
Fix list error messages (#33082)
This commit is contained in:
parent
fa3577e04b
commit
48f3ed738f
3 changed files with 12 additions and 8 deletions
|
@ -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?
|
||||||
|
|
|
@ -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:
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue