forked from fedi/mastodon
Fix error when following locked accounts (#4896)
This commit is contained in:
parent
a6a206ef85
commit
0ef9d45d05
|
@ -15,16 +15,9 @@ class Api::V1::AccountsController < Api::BaseController
|
||||||
def follow
|
def follow
|
||||||
FollowService.new.call(current_user.account, @account.acct)
|
FollowService.new.call(current_user.account, @account.acct)
|
||||||
|
|
||||||
unless @account.locked?
|
options = @account.locked? ? {} : { following_map: { @account.id => true }, requested_map: { @account.id => false } }
|
||||||
relationships = AccountRelationshipsPresenter.new(
|
|
||||||
[@account.id],
|
|
||||||
current_user.account_id,
|
|
||||||
following_map: { @account.id => true },
|
|
||||||
requested_map: { @account.id => false }
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
render json: @account, serializer: REST::RelationshipSerializer, relationships: relationships
|
render json: @account, serializer: REST::RelationshipSerializer, relationships: relationships(options)
|
||||||
end
|
end
|
||||||
|
|
||||||
def block
|
def block
|
||||||
|
@ -58,7 +51,7 @@ class Api::V1::AccountsController < Api::BaseController
|
||||||
@account = Account.find(params[:id])
|
@account = Account.find(params[:id])
|
||||||
end
|
end
|
||||||
|
|
||||||
def relationships
|
def relationships(options = {})
|
||||||
AccountRelationshipsPresenter.new([@account.id], current_user.account_id)
|
AccountRelationshipsPresenter.new([@account.id], current_user.account_id, options)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -18,25 +18,48 @@ RSpec.describe Api::V1::AccountsController, type: :controller do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'POST #follow' do
|
describe 'POST #follow' do
|
||||||
let(:other_account) { Fabricate(:user, email: 'bob@example.com', account: Fabricate(:account, username: 'bob')).account }
|
let(:other_account) { Fabricate(:user, email: 'bob@example.com', account: Fabricate(:account, username: 'bob', locked: locked)).account }
|
||||||
|
|
||||||
before do
|
before do
|
||||||
post :follow, params: { id: other_account.id }
|
post :follow, params: { id: other_account.id }
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'returns http success' do
|
context 'with unlocked account' do
|
||||||
expect(response).to have_http_status(:success)
|
let(:locked) { false }
|
||||||
|
|
||||||
|
it 'returns http success' do
|
||||||
|
expect(response).to have_http_status(:success)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns JSON with following=true and requested=false' do
|
||||||
|
json = body_as_json
|
||||||
|
|
||||||
|
expect(json[:following]).to be true
|
||||||
|
expect(json[:requested]).to be false
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'creates a following relation between user and target user' do
|
||||||
|
expect(user.account.following?(other_account)).to be true
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'returns JSON with following=true and requested=false' do
|
context 'with locked account' do
|
||||||
json = body_as_json
|
let(:locked) { true }
|
||||||
|
|
||||||
expect(json[:following]).to be true
|
it 'returns http success' do
|
||||||
expect(json[:requested]).to be false
|
expect(response).to have_http_status(:success)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'creates a following relation between user and target user' do
|
it 'returns JSON with following=false and requested=true' do
|
||||||
expect(user.account.following?(other_account)).to be true
|
json = body_as_json
|
||||||
|
|
||||||
|
expect(json[:following]).to be false
|
||||||
|
expect(json[:requested]).to be true
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'creates a follow request relation between user and target user' do
|
||||||
|
expect(user.account.requested?(other_account)).to be true
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue