From e46abc71cad590c2113247d41feca80d27a557b0 Mon Sep 17 00:00:00 2001 From: Eugen Rochko Date: Wed, 21 Sep 2016 22:07:18 +0200 Subject: Fix notifications in UI, added new API for fetching account relationships --- spec/controllers/api/accounts_controller_spec.rb | 42 ++++++++++++++++++++++++ spec/spec_helper.rb | 2 +- 2 files changed, 43 insertions(+), 1 deletion(-) (limited to 'spec') diff --git a/spec/controllers/api/accounts_controller_spec.rb b/spec/controllers/api/accounts_controller_spec.rb index 91e62837c..7fef8b9fe 100644 --- a/spec/controllers/api/accounts_controller_spec.rb +++ b/spec/controllers/api/accounts_controller_spec.rb @@ -71,4 +71,46 @@ RSpec.describe Api::AccountsController, type: :controller do expect(user.account.following?(other_account)).to be false end end + + describe 'GET #relationships' do + let(:simon) { Fabricate(:user, email: 'simon@example.com', account: Fabricate(:account, username: 'simon')).account } + let(:lewis) { Fabricate(:user, email: 'lewis@example.com', account: Fabricate(:account, username: 'lewis')).account } + + before do + user.account.follow!(simon) + lewis.follow!(user.account) + end + + context 'provided only one ID' do + before do + get :relationships, params: { id: simon.id } + end + + it 'returns http success' do + expect(response).to have_http_status(:success) + end + + it 'returns JSON with correct data' do + json = body_as_json + + expect(json).to be_a Enumerable + expect(json.first[:following]).to be true + expect(json.first[:followed_by]).to be false + end + end + + context 'provided multiple IDs' do + before do + get :relationships, params: { id: [simon.id, lewis.id] } + end + + it 'returns http success' do + expect(response).to have_http_status(:success) + end + + xit 'returns JSON with correct data' do + # todo + end + end + end end diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 8d77b39f3..2fdce8755 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -23,5 +23,5 @@ def body_as_json end def json_str_to_hash(str) - JSON.parse(str).with_indifferent_access + JSON.parse(str, symbolize_names: true) end -- cgit