aboutsummaryrefslogtreecommitdiff
path: root/spec/controllers/api/v1
diff options
context:
space:
mode:
Diffstat (limited to 'spec/controllers/api/v1')
-rw-r--r--spec/controllers/api/v1/accounts_controller_spec.rb84
-rw-r--r--spec/controllers/api/v1/admin/accounts_controller_spec.rb20
-rw-r--r--spec/controllers/api/v1/statuses/favourites_controller_spec.rb25
3 files changed, 101 insertions, 28 deletions
diff --git a/spec/controllers/api/v1/accounts_controller_spec.rb b/spec/controllers/api/v1/accounts_controller_spec.rb
index 024409dab..1e656503f 100644
--- a/spec/controllers/api/v1/accounts_controller_spec.rb
+++ b/spec/controllers/api/v1/accounts_controller_spec.rb
@@ -71,50 +71,80 @@ RSpec.describe Api::V1::AccountsController, type: :controller do
let(:scopes) { 'write:follows' }
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
+ context do
+ before do
+ post :follow, params: { id: other_account.id }
+ end
- context 'with unlocked account' do
- let(:locked) { false }
+ context 'with unlocked account' do
+ let(:locked) { false }
- it 'returns http success' do
- expect(response).to have_http_status(200)
- end
+ it 'returns http success' do
+ expect(response).to have_http_status(200)
+ 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
+ end
+
+ it 'creates a following relation between user and target user' do
+ expect(user.account.following?(other_account)).to be true
+ end
- it 'creates a following relation between user and target user' do
- expect(user.account.following?(other_account)).to be true
+ it_behaves_like 'forbidden for wrong scope', 'read:accounts'
end
- it_behaves_like 'forbidden for wrong scope', 'read:accounts'
+ context 'with locked account' do
+ let(:locked) { true }
+
+ it 'returns http success' do
+ expect(response).to have_http_status(200)
+ 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
+
+ it_behaves_like 'forbidden for wrong scope', 'read:accounts'
+ end
end
- context 'with locked account' do
- let(:locked) { true }
+ context 'modifying follow options' do
+ let(:locked) { false }
- it 'returns http success' do
- expect(response).to have_http_status(200)
+ before do
+ user.account.follow!(other_account, reblogs: false, notify: false)
end
- it 'returns JSON with following=false and requested=true' do
+ it 'changes reblogs option' do
+ post :follow, params: { id: other_account.id, reblogs: true }
+
json = body_as_json
- expect(json[:following]).to be false
- expect(json[:requested]).to be true
+ expect(json[:following]).to be true
+ expect(json[:showing_reblogs]).to be true
+ expect(json[:notifying]).to be false
end
- it 'creates a follow request relation between user and target user' do
- expect(user.account.requested?(other_account)).to be true
- end
+ it 'changes notify option' do
+ post :follow, params: { id: other_account.id, notify: true }
+
+ json = body_as_json
- it_behaves_like 'forbidden for wrong scope', 'read:accounts'
+ expect(json[:following]).to be true
+ expect(json[:showing_reblogs]).to be false
+ expect(json[:notifying]).to be true
+ end
end
end
diff --git a/spec/controllers/api/v1/admin/accounts_controller_spec.rb b/spec/controllers/api/v1/admin/accounts_controller_spec.rb
index f3f9946ba..f6be35f7f 100644
--- a/spec/controllers/api/v1/admin/accounts_controller_spec.rb
+++ b/spec/controllers/api/v1/admin/accounts_controller_spec.rb
@@ -111,7 +111,7 @@ RSpec.describe Api::V1::Admin::AccountsController, type: :controller do
describe 'POST #unsuspend' do
before do
- account.touch(:suspended_at)
+ account.suspend!
post :unsuspend, params: { id: account.id }
end
@@ -127,6 +127,24 @@ RSpec.describe Api::V1::Admin::AccountsController, type: :controller do
end
end
+ describe 'POST #unsensitive' do
+ before do
+ account.touch(:sensitized_at)
+ post :unsensitive, params: { id: account.id }
+ end
+
+ it_behaves_like 'forbidden for wrong scope', 'write:statuses'
+ it_behaves_like 'forbidden for wrong role', 'user'
+
+ it 'returns http success' do
+ expect(response).to have_http_status(200)
+ end
+
+ it 'unsensitives account' do
+ expect(account.reload.sensitized?).to be false
+ end
+ end
+
describe 'POST #unsilence' do
before do
account.touch(:silenced_at)
diff --git a/spec/controllers/api/v1/statuses/favourites_controller_spec.rb b/spec/controllers/api/v1/statuses/favourites_controller_spec.rb
index 6e947f5d2..4716ecae3 100644
--- a/spec/controllers/api/v1/statuses/favourites_controller_spec.rb
+++ b/spec/controllers/api/v1/statuses/favourites_controller_spec.rb
@@ -82,6 +82,31 @@ describe Api::V1::Statuses::FavouritesController do
end
end
+ context 'with public status when blocked by its author' do
+ let(:status) { Fabricate(:status) }
+
+ before do
+ FavouriteService.new.call(user.account, status)
+ status.account.block!(user.account)
+ post :destroy, params: { status_id: status.id }
+ end
+
+ it 'returns http success' do
+ expect(response).to have_http_status(200)
+ end
+
+ it 'updates the favourite attribute' do
+ expect(user.account.favourited?(status)).to be false
+ end
+
+ it 'returns json with updated attributes' do
+ hash_body = body_as_json
+
+ expect(hash_body[:id]).to eq status.id.to_s
+ expect(hash_body[:favourited]).to be false
+ end
+ end
+
context 'with private status that was not favourited' do
let(:status) { Fabricate(:status, visibility: :private) }