summaryrefslogtreecommitdiffstats
path: root/spec
diff options
context:
space:
mode:
authorLevi Bard <taktaktaktaktaktaktaktaktaktak@gmail.com>2021-01-10 12:47:21 +0100
committerGitHub <noreply@github.com>2021-01-10 12:47:21 +0100
commit11d603101a7b3389c679b8c155a3cb06203ca31a (patch)
treeb54db656ef55f1ea3dc82750030d504ecdb4b3fd /spec
parent087ed84367537ac168ed3e00bb7eb4bd582dc3d0 (diff)
Fix muting users with duration via the REST api (#15516)
Diffstat (limited to 'spec')
-rw-r--r--spec/controllers/api/v1/accounts_controller_spec.rb28
1 files changed, 28 insertions, 0 deletions
diff --git a/spec/controllers/api/v1/accounts_controller_spec.rb b/spec/controllers/api/v1/accounts_controller_spec.rb
index 1e656503fbc..d9ee37ffa24 100644
--- a/spec/controllers/api/v1/accounts_controller_spec.rb
+++ b/spec/controllers/api/v1/accounts_controller_spec.rb
@@ -268,6 +268,34 @@ RSpec.describe Api::V1::AccountsController, type: :controller do
it_behaves_like 'forbidden for wrong scope', 'read:accounts'
end
+ describe 'POST #mute with nonzero duration set' do
+ let(:scopes) { 'write:mutes' }
+ let(:other_account) { Fabricate(:user, email: 'bob@example.com', account: Fabricate(:account, username: 'bob')).account }
+
+ before do
+ user.account.follow!(other_account)
+ post :mute, params: { id: other_account.id, duration: 300 }
+ end
+
+ it 'returns http success' do
+ expect(response).to have_http_status(200)
+ end
+
+ it 'does not remove the following relation between user and target user' do
+ expect(user.account.following?(other_account)).to be true
+ end
+
+ it 'creates a muting relation' do
+ expect(user.account.muting?(other_account)).to be true
+ end
+
+ it 'mutes notifications' do
+ expect(user.account.muting_notifications?(other_account)).to be true
+ end
+
+ it_behaves_like 'forbidden for wrong scope', 'read:accounts'
+ end
+
describe 'POST #unmute' do
let(:scopes) { 'write:mutes' }
let(:other_account) { Fabricate(:user, email: 'bob@example.com', account: Fabricate(:account, username: 'bob')).account }