Convert more API specs from controller->request style (#29004)

This commit is contained in:
Matt Jankowski 2024-03-01 11:24:45 -05:00 committed by GitHub
parent a25014de8f
commit 18945f62e0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
10 changed files with 159 additions and 156 deletions

View File

@ -2,20 +2,16 @@
require 'rails_helper' require 'rails_helper'
describe Api::V1::Accounts::StatusesController do describe 'API V1 Accounts Statuses' do
render_views
let(:user) { Fabricate(:user) } let(:user) { Fabricate(:user) }
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'read:statuses') } let(:scopes) { 'read:statuses' }
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
before do describe 'GET /api/v1/accounts/:account_id/statuses' do
allow(controller).to receive(:doorkeeper_token) { token }
end
describe 'GET #index' do
it 'returns expected headers', :aggregate_failures do it 'returns expected headers', :aggregate_failures do
Fabricate(:status, account: user.account) Fabricate(:status, account: user.account)
get :index, params: { account_id: user.account.id, limit: 1 } get "/api/v1/accounts/#{user.account.id}/statuses", params: { limit: 1 }, headers: headers
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
expect(links_from_header.size) expect(links_from_header.size)
@ -24,7 +20,7 @@ describe Api::V1::Accounts::StatusesController do
context 'with only media' do context 'with only media' do
it 'returns http success' do it 'returns http success' do
get :index, params: { account_id: user.account.id, only_media: true } get "/api/v1/accounts/#{user.account.id}/statuses", params: { only_media: true }, headers: headers
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
end end
@ -36,7 +32,7 @@ describe Api::V1::Accounts::StatusesController do
before do before do
Fabricate(:status, account: user.account, thread: Fabricate(:status)) # Reply to another user Fabricate(:status, account: user.account, thread: Fabricate(:status)) # Reply to another user
get :index, params: { account_id: user.account.id, exclude_replies: true } get "/api/v1/accounts/#{user.account.id}/statuses", params: { exclude_replies: true }, headers: headers
end end
it 'returns posts along with self replies', :aggregate_failures do it 'returns posts along with self replies', :aggregate_failures do
@ -57,7 +53,7 @@ describe Api::V1::Accounts::StatusesController do
end end
it 'returns http success and includes a header link' do it 'returns http success and includes a header link' do
get :index, params: { account_id: user.account.id, pinned: true } get "/api/v1/accounts/#{user.account.id}/statuses", params: { pinned: true }, headers: headers
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
expect(links_from_header.size) expect(links_from_header.size)
@ -79,7 +75,7 @@ describe Api::V1::Accounts::StatusesController do
end end
it 'returns http success and header pagination links to prev and next' do it 'returns http success and header pagination links to prev and next' do
get :index, params: { account_id: user.account.id, pinned: true } get "/api/v1/accounts/#{user.account.id}/statuses", params: { pinned: true }, headers: headers
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
expect(links_from_header.size) expect(links_from_header.size)
@ -109,15 +105,19 @@ describe Api::V1::Accounts::StatusesController do
end end
it 'returns http success' do it 'returns http success' do
get :index, params: { account_id: account.id, pinned: true } get "/api/v1/accounts/#{account.id}/statuses", params: { pinned: true }, headers: headers
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
end end
context 'when user does not follow account' do context 'when user does not follow account' do
it 'lists the public status only' do it 'lists the public status only' do
get :index, params: { account_id: account.id, pinned: true } get "/api/v1/accounts/#{account.id}/statuses", params: { pinned: true }, headers: headers
json = body_as_json
expect(json.map { |item| item[:id].to_i }).to eq [status.id] expect(body_as_json)
.to contain_exactly(
a_hash_including(id: status.id.to_s)
)
end end
end end
@ -127,9 +127,13 @@ describe Api::V1::Accounts::StatusesController do
end end
it 'lists both the public and the private statuses' do it 'lists both the public and the private statuses' do
get :index, params: { account_id: account.id, pinned: true } get "/api/v1/accounts/#{account.id}/statuses", params: { pinned: true }, headers: headers
json = body_as_json
expect(json.map { |item| item[:id].to_i }).to contain_exactly(status.id, private_status.id) expect(body_as_json)
.to contain_exactly(
a_hash_including(id: status.id.to_s),
a_hash_including(id: private_status.id.to_s)
)
end end
end end
end end

View File

@ -2,31 +2,26 @@
require 'rails_helper' require 'rails_helper'
describe Api::V1::Admin::Trends::StatusesController do describe 'API V1 Admin Trends Statuses' do
render_views
let(:role) { UserRole.find_by(name: 'Admin') } let(:role) { UserRole.find_by(name: 'Admin') }
let(:user) { Fabricate(:user, role: role) } let(:user) { Fabricate(:user, role: role) }
let(:scopes) { 'admin:read admin:write' } let(:scopes) { 'admin:read admin:write' }
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) } let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
let(:account) { Fabricate(:account) } let(:account) { Fabricate(:account) }
let(:status) { Fabricate(:status) } let(:status) { Fabricate(:status) }
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
before do describe 'GET /api/v1/admin/trends/statuses' do
allow(controller).to receive(:doorkeeper_token) { token }
end
describe 'GET #index' do
it 'returns http success' do it 'returns http success' do
get :index, params: { account_id: account.id, limit: 2 } get '/api/v1/admin/trends/statuses', params: { account_id: account.id, limit: 2 }, headers: headers
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
end end
end end
describe 'POST #approve' do describe 'POST /api/v1/admin/trends/statuses/:id/approve' do
before do before do
post :approve, params: { id: status.id } post "/api/v1/admin/trends/statuses/#{status.id}/approve", headers: headers
end end
it_behaves_like 'forbidden for wrong scope', 'write:statuses' it_behaves_like 'forbidden for wrong scope', 'write:statuses'
@ -37,9 +32,9 @@ describe Api::V1::Admin::Trends::StatusesController do
end end
end end
describe 'POST #reject' do describe 'POST /api/v1/admin/trends/statuses/:id/unapprove' do
before do before do
post :reject, params: { id: status.id } post "/api/v1/admin/trends/statuses/#{status.id}/reject", headers: headers
end end
it_behaves_like 'forbidden for wrong scope', 'write:statuses' it_behaves_like 'forbidden for wrong scope', 'write:statuses'

View File

@ -2,31 +2,26 @@
require 'rails_helper' require 'rails_helper'
describe Api::V1::Admin::Trends::TagsController do describe 'API V1 Admin Trends Tags' do
render_views
let(:role) { UserRole.find_by(name: 'Admin') } let(:role) { UserRole.find_by(name: 'Admin') }
let(:user) { Fabricate(:user, role: role) } let(:user) { Fabricate(:user, role: role) }
let(:scopes) { 'admin:read admin:write' } let(:scopes) { 'admin:read admin:write' }
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) } let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
let(:account) { Fabricate(:account) } let(:account) { Fabricate(:account) }
let(:tag) { Fabricate(:tag) } let(:tag) { Fabricate(:tag) }
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
before do describe 'GET /api/v1/admin/trends/tags' do
allow(controller).to receive(:doorkeeper_token) { token }
end
describe 'GET #index' do
it 'returns http success' do it 'returns http success' do
get :index, params: { account_id: account.id, limit: 2 } get '/api/v1/admin/trends/tags', params: { account_id: account.id, limit: 2 }, headers: headers
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
end end
end end
describe 'POST #approve' do describe 'POST /api/v1/admin/trends/tags/:id/approve' do
before do before do
post :approve, params: { id: tag.id } post "/api/v1/admin/trends/tags/#{tag.id}/approve", headers: headers
end end
it_behaves_like 'forbidden for wrong scope', 'write:statuses' it_behaves_like 'forbidden for wrong scope', 'write:statuses'
@ -37,9 +32,9 @@ describe Api::V1::Admin::Trends::TagsController do
end end
end end
describe 'POST #reject' do describe 'POST /api/v1/admin/trends/tags/:id/reject' do
before do before do
post :reject, params: { id: tag.id } post "/api/v1/admin/trends/tags/#{tag.id}/reject", headers: headers
end end
it_behaves_like 'forbidden for wrong scope', 'write:statuses' it_behaves_like 'forbidden for wrong scope', 'write:statuses'

View File

@ -2,27 +2,26 @@
require 'rails_helper' require 'rails_helper'
RSpec.describe Api::V1::Announcements::ReactionsController do RSpec.describe 'API V1 Announcements Reactions' do
render_views
let(:user) { Fabricate(:user) } let(:user) { Fabricate(:user) }
let(:scopes) { 'write:favourites' } let(:scopes) { 'write:favourites' }
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) } let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
let!(:announcement) { Fabricate(:announcement) } let!(:announcement) { Fabricate(:announcement) }
describe 'PUT #update' do describe 'PUT /api/v1/announcements/:announcement_id/reactions/:id' do
context 'without token' do context 'without token' do
it 'returns http unauthorized' do it 'returns http unauthorized' do
put :update, params: { announcement_id: announcement.id, id: '😂' } put "/api/v1/announcements/#{announcement.id}/reactions/#{escaped_emoji}"
expect(response).to have_http_status 401 expect(response).to have_http_status 401
end end
end end
context 'with token' do context 'with token' do
before do before do
allow(controller).to receive(:doorkeeper_token) { token } put "/api/v1/announcements/#{announcement.id}/reactions/#{escaped_emoji}", headers: headers
put :update, params: { announcement_id: announcement.id, id: '😂' }
end end
it 'creates reaction', :aggregate_failures do it 'creates reaction', :aggregate_failures do
@ -32,22 +31,21 @@ RSpec.describe Api::V1::Announcements::ReactionsController do
end end
end end
describe 'DELETE #destroy' do describe 'DELETE /api/v1/announcements/:announcement_id/reactions/:id' do
before do before do
announcement.announcement_reactions.create!(account: user.account, name: '😂') announcement.announcement_reactions.create!(account: user.account, name: '😂')
end end
context 'without token' do context 'without token' do
it 'returns http unauthorized' do it 'returns http unauthorized' do
delete :destroy, params: { announcement_id: announcement.id, id: '😂' } delete "/api/v1/announcements/#{announcement.id}/reactions/#{escaped_emoji}"
expect(response).to have_http_status 401 expect(response).to have_http_status 401
end end
end end
context 'with token' do context 'with token' do
before do before do
allow(controller).to receive(:doorkeeper_token) { token } delete "/api/v1/announcements/#{announcement.id}/reactions/#{escaped_emoji}", headers: headers
delete :destroy, params: { announcement_id: announcement.id, id: '😂' }
end end
it 'creates reaction', :aggregate_failures do it 'creates reaction', :aggregate_failures do
@ -56,4 +54,8 @@ RSpec.describe Api::V1::Announcements::ReactionsController do
end end
end end
end end
def escaped_emoji
CGI.escape('😂')
end
end end

View File

@ -2,27 +2,26 @@
require 'rails_helper' require 'rails_helper'
RSpec.describe Api::V1::AnnouncementsController do RSpec.describe 'API V1 Announcements' do
render_views
let(:user) { Fabricate(:user) } let(:user) { Fabricate(:user) }
let(:scopes) { 'read' } let(:scopes) { 'read' }
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) } let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
let!(:announcement) { Fabricate(:announcement) } let!(:announcement) { Fabricate(:announcement) }
describe 'GET #index' do describe 'GET /api/v1/announcements' do
context 'without token' do context 'without token' do
it 'returns http unprocessable entity' do it 'returns http unprocessable entity' do
get :index get '/api/v1/announcements'
expect(response).to have_http_status 422 expect(response).to have_http_status 422
end end
end end
context 'with token' do context 'with token' do
before do before do
allow(controller).to receive(:doorkeeper_token) { token } get '/api/v1/announcements', headers: headers
get :index
end end
it 'returns http success' do it 'returns http success' do
@ -31,10 +30,11 @@ RSpec.describe Api::V1::AnnouncementsController do
end end
end end
describe 'POST #dismiss' do describe 'POST /api/v1/announcements/:id/dismiss' do
context 'without token' do context 'without token' do
it 'returns http unauthorized' do it 'returns http unauthorized' do
post :dismiss, params: { id: announcement.id } post "/api/v1/announcements/#{announcement.id}/dismiss"
expect(response).to have_http_status 401 expect(response).to have_http_status 401
end end
end end
@ -43,8 +43,7 @@ RSpec.describe Api::V1::AnnouncementsController do
let(:scopes) { 'write:accounts' } let(:scopes) { 'write:accounts' }
before do before do
allow(controller).to receive(:doorkeeper_token) { token } post "/api/v1/announcements/#{announcement.id}/dismiss", headers: headers
post :dismiss, params: { id: announcement.id }
end end
it 'dismisses announcement', :aggregate_failures do it 'dismisses announcement', :aggregate_failures do

View File

@ -2,53 +2,48 @@
require 'rails_helper' require 'rails_helper'
RSpec.describe Api::V1::ConversationsController do RSpec.describe 'API V1 Conversations' do
render_views
let!(:user) { Fabricate(:user, account_attributes: { username: 'alice' }) } let!(:user) { Fabricate(:user, account_attributes: { username: 'alice' }) }
let(:scopes) { 'read:statuses' }
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) } let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
let(:other) { Fabricate(:user) } let(:other) { Fabricate(:user) }
before do describe 'GET /api/v1/conversations', :sidekiq_inline do
allow(controller).to receive(:doorkeeper_token) { token }
end
describe 'GET #index', :sidekiq_inline do
let(:scopes) { 'read:statuses' }
before do before do
PostStatusService.new.call(other.account, text: 'Hey @alice', visibility: 'direct') PostStatusService.new.call(other.account, text: 'Hey @alice', visibility: 'direct')
PostStatusService.new.call(user.account, text: 'Hey, nobody here', visibility: 'direct') PostStatusService.new.call(user.account, text: 'Hey, nobody here', visibility: 'direct')
end end
it 'returns pagination headers', :aggregate_failures do it 'returns pagination headers', :aggregate_failures do
get :index, params: { limit: 1 } get '/api/v1/conversations', params: { limit: 1 }, headers: headers
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
expect(response.headers['Link'].links.size).to eq(2) expect(response.headers['Link'].links.size).to eq(2)
end end
it 'returns conversations', :aggregate_failures do it 'returns conversations', :aggregate_failures do
get :index get '/api/v1/conversations', headers: headers
json = body_as_json
expect(json.size).to eq 2 expect(body_as_json.size).to eq 2
expect(json[0][:accounts].size).to eq 1 expect(body_as_json[0][:accounts].size).to eq 1
end end
context 'with since_id' do context 'with since_id' do
context 'when requesting old posts' do context 'when requesting old posts' do
it 'returns conversations' do it 'returns conversations' do
get :index, params: { since_id: Mastodon::Snowflake.id_at(1.hour.ago, with_random: false) } get '/api/v1/conversations', params: { since_id: Mastodon::Snowflake.id_at(1.hour.ago, with_random: false) }, headers: headers
json = body_as_json
expect(json.size).to eq 2 expect(body_as_json.size).to eq 2
end end
end end
context 'when requesting posts in the future' do context 'when requesting posts in the future' do
it 'returns no conversation' do it 'returns no conversation' do
get :index, params: { since_id: Mastodon::Snowflake.id_at(1.hour.from_now, with_random: false) } get '/api/v1/conversations', params: { since_id: Mastodon::Snowflake.id_at(1.hour.from_now, with_random: false) }, headers: headers
json = body_as_json
expect(json.size).to eq 0 expect(body_as_json.size).to eq 0
end end
end end
end end

View File

@ -2,23 +2,18 @@
require 'rails_helper' require 'rails_helper'
RSpec.describe Api::V1::FiltersController do RSpec.describe 'API V1 Filters' do
render_views
let(:user) { Fabricate(:user) } let(:user) { Fabricate(:user) }
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) } let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
before do describe 'GET /api/v1/filters' do
allow(controller).to receive(:doorkeeper_token) { token }
end
describe 'GET #index' do
let(:scopes) { 'read:filters' } let(:scopes) { 'read:filters' }
let!(:filter) { Fabricate(:custom_filter, account: user.account) } let!(:filter) { Fabricate(:custom_filter, account: user.account) }
let!(:custom_filter_keyword) { Fabricate(:custom_filter_keyword, custom_filter: filter) } let!(:custom_filter_keyword) { Fabricate(:custom_filter_keyword, custom_filter: filter) }
it 'returns http success' do it 'returns http success' do
get :index get '/api/v1/filters', headers: headers
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
expect(body_as_json) expect(body_as_json)
.to contain_exactly( .to contain_exactly(
@ -27,13 +22,13 @@ RSpec.describe Api::V1::FiltersController do
end end
end end
describe 'POST #create' do describe 'POST /api/v1/filters' do
let(:scopes) { 'write:filters' } let(:scopes) { 'write:filters' }
let(:irreversible) { true } let(:irreversible) { true }
let(:whole_word) { false } let(:whole_word) { false }
before do before do
post :create, params: { phrase: 'magic', context: %w(home), irreversible: irreversible, whole_word: whole_word } post '/api/v1/filters', params: { phrase: 'magic', context: %w(home), irreversible: irreversible, whole_word: whole_word }, headers: headers
end end
it 'creates a filter', :aggregate_failures do it 'creates a filter', :aggregate_failures do
@ -64,24 +59,25 @@ RSpec.describe Api::V1::FiltersController do
end end
end end
describe 'GET #show' do describe 'GET /api/v1/filters/:id' do
let(:scopes) { 'read:filters' } let(:scopes) { 'read:filters' }
let(:filter) { Fabricate(:custom_filter, account: user.account) } let(:filter) { Fabricate(:custom_filter, account: user.account) }
let(:keyword) { Fabricate(:custom_filter_keyword, custom_filter: filter) } let(:keyword) { Fabricate(:custom_filter_keyword, custom_filter: filter) }
it 'returns http success' do it 'returns http success' do
get :show, params: { id: keyword.id } get "/api/v1/filters/#{keyword.id}", headers: headers
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
end end
end end
describe 'PUT #update' do describe 'PUT /api/v1/filters/:id' do
let(:scopes) { 'write:filters' } let(:scopes) { 'write:filters' }
let(:filter) { Fabricate(:custom_filter, account: user.account) } let(:filter) { Fabricate(:custom_filter, account: user.account) }
let(:keyword) { Fabricate(:custom_filter_keyword, custom_filter: filter) } let(:keyword) { Fabricate(:custom_filter_keyword, custom_filter: filter) }
before do before do
put :update, params: { id: keyword.id, phrase: 'updated' } put "/api/v1/filters/#{keyword.id}", headers: headers, params: { phrase: 'updated' }
end end
it 'updates the filter', :aggregate_failures do it 'updates the filter', :aggregate_failures do
@ -90,13 +86,13 @@ RSpec.describe Api::V1::FiltersController do
end end
end end
describe 'DELETE #destroy' do describe 'DELETE /api/v1/filters/:id' do
let(:scopes) { 'write:filters' } let(:scopes) { 'write:filters' }
let(:filter) { Fabricate(:custom_filter, account: user.account) } let(:filter) { Fabricate(:custom_filter, account: user.account) }
let(:keyword) { Fabricate(:custom_filter_keyword, custom_filter: filter) } let(:keyword) { Fabricate(:custom_filter_keyword, custom_filter: filter) }
before do before do
delete :destroy, params: { id: keyword.id } delete "/api/v1/filters/#{keyword.id}", headers: headers
end end
it 'removes the filter', :aggregate_failures do it 'removes the filter', :aggregate_failures do

View File

@ -2,30 +2,32 @@
require 'rails_helper' require 'rails_helper'
RSpec.describe Api::V1::Polls::VotesController do RSpec.describe 'API V1 Polls Votes' do
render_views
let(:user) { Fabricate(:user) } let(:user) { Fabricate(:user) }
let(:scopes) { 'write:statuses' } let(:scopes) { 'write:statuses' }
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) } let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
before { allow(controller).to receive(:doorkeeper_token) { token } } describe 'POST /api/v1/polls/:poll_id/votes' do
describe 'POST #create' do
let(:poll) { Fabricate(:poll) } let(:poll) { Fabricate(:poll) }
before do before do
post :create, params: { poll_id: poll.id, choices: %w(1) } post "/api/v1/polls/#{poll.id}/votes", params: { choices: %w(1) }, headers: headers
end end
it 'creates a vote', :aggregate_failures do it 'creates a vote', :aggregate_failures do
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
vote = poll.votes.where(account: user.account).first
expect(vote).to_not be_nil expect(vote).to_not be_nil
expect(vote.choice).to eq 1 expect(vote.choice).to eq 1
expect(poll.reload.cached_tallies).to eq [0, 1] expect(poll.reload.cached_tallies).to eq [0, 1]
end end
private
def vote
poll.votes.where(account: user.account).first
end
end end
end end

View File

@ -2,9 +2,7 @@
require 'rails_helper' require 'rails_helper'
describe Api::V1::Push::SubscriptionsController do describe 'API V1 Push Subscriptions' do
render_views
let(:user) { Fabricate(:user) } let(:user) { Fabricate(:user) }
let(:create_payload) do let(:create_payload) do
{ {
@ -34,15 +32,13 @@ describe Api::V1::Push::SubscriptionsController do
}, },
}.with_indifferent_access }.with_indifferent_access
end end
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'push') } let(:scopes) { 'push' }
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
describe 'POST /api/v1/push/subscription' do
before do before do
allow(controller).to receive(:doorkeeper_token) { token } post '/api/v1/push/subscription', params: create_payload, headers: headers
end
describe 'POST #create' do
before do
post :create, params: create_payload
end end
it 'saves push subscriptions' do it 'saves push subscriptions' do
@ -56,19 +52,23 @@ describe Api::V1::Push::SubscriptionsController do
end end
it 'replaces old subscription on repeat calls' do it 'replaces old subscription on repeat calls' do
post :create, params: create_payload post '/api/v1/push/subscription', params: create_payload, headers: headers
expect(Web::PushSubscription.where(endpoint: create_payload[:subscription][:endpoint]).count).to eq 1 expect(Web::PushSubscription.where(endpoint: create_payload[:subscription][:endpoint]).count).to eq 1
end end
it 'returns the expected JSON' do it 'returns the expected JSON' do
expect(body_as_json.with_indifferent_access).to include({ endpoint: create_payload[:subscription][:endpoint], alerts: {}, policy: 'all' }) expect(body_as_json.with_indifferent_access)
.to include(
{ endpoint: create_payload[:subscription][:endpoint], alerts: {}, policy: 'all' }
)
end end
end end
describe 'PUT #update' do describe 'PUT /api/v1/push/subscription' do
before do before do
post :create, params: create_payload post '/api/v1/push/subscription', params: create_payload, headers: headers
put :update, params: alerts_payload put '/api/v1/push/subscription', params: alerts_payload, headers: headers
end end
it 'changes alert settings' do it 'changes alert settings' do
@ -82,14 +82,17 @@ describe Api::V1::Push::SubscriptionsController do
end end
it 'returns the expected JSON' do it 'returns the expected JSON' do
expect(body_as_json.with_indifferent_access).to include({ endpoint: create_payload[:subscription][:endpoint], alerts: alerts_payload[:data][:alerts], policy: alerts_payload[:data][:policy] }) expect(body_as_json.with_indifferent_access)
.to include(
{ endpoint: create_payload[:subscription][:endpoint], alerts: alerts_payload[:data][:alerts], policy: alerts_payload[:data][:policy] }
)
end end
end end
describe 'DELETE #destroy' do describe 'DELETE /api/v1/push/subscription' do
before do before do
post :create, params: create_payload post '/api/v1/push/subscription', params: create_payload, headers: headers
delete :destroy delete '/api/v1/push/subscription', headers: headers
end end
it 'removes the subscription' do it 'removes the subscription' do

View File

@ -2,7 +2,7 @@
require 'rails_helper' require 'rails_helper'
describe Api::V1::StreamingController do describe 'API V1 Streaming' do
around do |example| around do |example|
before = Rails.configuration.x.streaming_api_base_url before = Rails.configuration.x.streaming_api_base_url
Rails.configuration.x.streaming_api_base_url = "wss://#{Rails.configuration.x.web_domain}" Rails.configuration.x.streaming_api_base_url = "wss://#{Rails.configuration.x.web_domain}"
@ -10,14 +10,13 @@ describe Api::V1::StreamingController do
Rails.configuration.x.streaming_api_base_url = before Rails.configuration.x.streaming_api_base_url = before
end end
before do let(:headers) { { 'Host' => Rails.configuration.x.web_domain } }
request.headers.merge! Host: Rails.configuration.x.web_domain
end
context 'with streaming api on same host' do context 'with streaming api on same host' do
describe 'GET #index' do describe 'GET /api/v1/streaming' do
it 'raises ActiveRecord::RecordNotFound' do it 'raises ActiveRecord::RecordNotFound' do
get :index get '/api/v1/streaming', headers: headers
expect(response).to have_http_status(404) expect(response).to have_http_status(404)
end end
end end
@ -28,20 +27,33 @@ describe Api::V1::StreamingController do
Rails.configuration.x.streaming_api_base_url = "wss://streaming-#{Rails.configuration.x.web_domain}" Rails.configuration.x.streaming_api_base_url = "wss://streaming-#{Rails.configuration.x.web_domain}"
end end
describe 'GET #index' do describe 'GET /api/v1/streaming' do
it 'redirects to streaming host' do it 'redirects to streaming host' do
get :index, params: { access_token: 'deadbeef', stream: 'public' } get '/api/v1/streaming', headers: headers, params: { access_token: 'deadbeef', stream: 'public' }
expect(response).to have_http_status(301)
request_uri = URI.parse(request.url) expect(response)
redirect_to_uri = URI.parse(response.location) .to have_http_status(301)
[:scheme, :path, :query, :fragment].each do |part|
expect(redirect_to_uri.send(part)).to eq(request_uri.send(part)), "redirect target #{part}" expect(redirect_to_uri)
end .to have_attributes(
expect(redirect_to_uri.host).to eq(streaming_host), 'redirect target host' fragment: request_uri.fragment,
host: eq(streaming_host),
path: request_uri.path,
query: request_uri.query,
scheme: request_uri.scheme
)
end end
private private
def request_uri
URI.parse(request.url)
end
def redirect_to_uri
URI.parse(response.location)
end
def streaming_host def streaming_host
URI.parse(Rails.configuration.x.streaming_api_base_url).host URI.parse(Rails.configuration.x.streaming_api_base_url).host
end end