def follow
FollowService.new.call(current_user.account, @account.acct)
- unless @account.locked?
- relationships = AccountRelationshipsPresenter.new(
- [@account.id],
- current_user.account_id,
- following_map: { @account.id => true },
- requested_map: { @account.id => false }
- )
- end
+ options = @account.locked? ? {} : { following_map: { @account.id => true }, requested_map: { @account.id => false } }
- render json: @account, serializer: REST::RelationshipSerializer, relationships: relationships
+ render json: @account, serializer: REST::RelationshipSerializer, relationships: relationships(options)
end
def block
@account = Account.find(params[:id])
end
- def relationships
- AccountRelationshipsPresenter.new([@account.id], current_user.account_id)
+ def relationships(options = {})
+ AccountRelationshipsPresenter.new([@account.id], current_user.account_id, options)
end
end
end
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
post :follow, params: { id: other_account.id }
end
- it 'returns http success' do
- expect(response).to have_http_status(:success)
- end
+ context 'with unlocked account' do
+ 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
- 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
- expect(json[:following]).to be true
- expect(json[:requested]).to be false
+ it 'creates a following relation between user and target user' do
+ expect(user.account.following?(other_account)).to be true
+ end
end
- it 'creates a following relation between user and target user' do
- expect(user.account.following?(other_account)).to be true
+ context 'with locked account' do
+ let(:locked) { true }
+
+ it 'returns http success' do
+ expect(response).to have_http_status(:success)
+ end
+
+ it 'returns JSON with following=false and requested=true' do
+ 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