Controller spec to request spec: api/v1/accounts/pins
(#28300)
This commit is contained in:
parent
94cc707ab3
commit
809506bdd4
2 changed files with 41 additions and 40 deletions
|
@ -1,40 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
require 'rails_helper'
|
|
||||||
|
|
||||||
RSpec.describe Api::V1::Accounts::PinsController do
|
|
||||||
let(:john) { Fabricate(:user) }
|
|
||||||
let(:kevin) { Fabricate(:user) }
|
|
||||||
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: john.id, scopes: 'write:accounts') }
|
|
||||||
|
|
||||||
before do
|
|
||||||
kevin.account.followers << john.account
|
|
||||||
allow(controller).to receive(:doorkeeper_token) { token }
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'POST #create' do
|
|
||||||
subject { post :create, params: { account_id: kevin.account.id } }
|
|
||||||
|
|
||||||
it 'creates account_pin', :aggregate_failures do
|
|
||||||
expect do
|
|
||||||
subject
|
|
||||||
end.to change { AccountPin.where(account: john.account, target_account: kevin.account).count }.by(1)
|
|
||||||
expect(response).to have_http_status(200)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'DELETE #destroy' do
|
|
||||||
subject { delete :destroy, params: { account_id: kevin.account.id } }
|
|
||||||
|
|
||||||
before do
|
|
||||||
Fabricate(:account_pin, account: john.account, target_account: kevin.account)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'destroys account_pin', :aggregate_failures do
|
|
||||||
expect do
|
|
||||||
subject
|
|
||||||
end.to change { AccountPin.where(account: john.account, target_account: kevin.account).count }.by(-1)
|
|
||||||
expect(response).to have_http_status(200)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
41
spec/requests/api/v1/accounts/pins_spec.rb
Normal file
41
spec/requests/api/v1/accounts/pins_spec.rb
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
describe 'Accounts Pins API' do
|
||||||
|
let(:user) { Fabricate(:user) }
|
||||||
|
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
|
||||||
|
let(:scopes) { 'write:accounts' }
|
||||||
|
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
|
||||||
|
let(:kevin) { Fabricate(:user) }
|
||||||
|
|
||||||
|
before do
|
||||||
|
kevin.account.followers << user.account
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'POST /api/v1/accounts/:account_id/pin' do
|
||||||
|
subject { post "/api/v1/accounts/#{kevin.account.id}/pin", headers: headers }
|
||||||
|
|
||||||
|
it 'creates account_pin', :aggregate_failures do
|
||||||
|
expect do
|
||||||
|
subject
|
||||||
|
end.to change { AccountPin.where(account: user.account, target_account: kevin.account).count }.by(1)
|
||||||
|
expect(response).to have_http_status(200)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'POST /api/v1/accounts/:account_id/unpin' do
|
||||||
|
subject { post "/api/v1/accounts/#{kevin.account.id}/unpin", headers: headers }
|
||||||
|
|
||||||
|
before do
|
||||||
|
Fabricate(:account_pin, account: user.account, target_account: kevin.account)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'destroys account_pin', :aggregate_failures do
|
||||||
|
expect do
|
||||||
|
subject
|
||||||
|
end.to change { AccountPin.where(account: user.account, target_account: kevin.account).count }.by(-1)
|
||||||
|
expect(response).to have_http_status(200)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue