Skip to content

Commit

Permalink
Fix list error messages (mastodon#33082)
Browse files Browse the repository at this point in the history
  • Loading branch information
Gargron authored Nov 28, 2024
1 parent fa3577e commit 48f3ed7
Show file tree
Hide file tree
Showing 3 changed files with 12 additions and 8 deletions.
13 changes: 6 additions & 7 deletions app/models/list_account.rb
Original file line number Diff line number Diff line change
Expand Up @@ -25,17 +25,16 @@ class ListAccount < ApplicationRecord
private

def set_follow
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)
self.follow = Follow.find_by(account_id: list.account_id, target_account_id: account.id)
self.follow_request = FollowRequest.find_by(account_id: list.account_id, target_account_id: account.id) if follow.nil?
end

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(:follow, 'mismatched accounts') 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(:account_id, :must_be_following) if follow_id.nil? && follow_request_id.nil?
errors.add(:follow, :invalid) if follow_id.present? && follow.target_account_id != account_id
errors.add(:follow_request, :invalid) if follow_request_id.present? && follow_request.target_account_id != account_id
end

def list_owner_account_is_account?
Expand Down
5 changes: 5 additions & 0 deletions config/locales/activerecord.en.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,11 @@ en:
attributes:
data:
malformed: is malformed
list_account:
attributes:
account_id:
taken: is already on the list
must_be_following: must be a followed account
status:
attributes:
reblog:
Expand Down
2 changes: 1 addition & 1 deletion spec/requests/api/v1/lists/accounts_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,7 @@
it 'does not add the account to the list', :aggregate_failures do
subject

expect(response).to have_http_status(404)
expect(response).to have_http_status(422)
expect(response.content_type)
.to start_with('application/json')
expect(list.accounts).to_not include(bob)
Expand Down

0 comments on commit 48f3ed7

Please sign in to comment.