Minor speed improvement on `controllers/accounts` spec (#27679)

remotes/1723507292310805857/main
Matt Jankowski 2023-11-09 11:21:11 -05:00 committed by GitHub
parent 9429e30d75
commit e79bf1b1e7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 23 additions and 49 deletions

View File

@ -7,66 +7,44 @@ RSpec.describe AccountsController do
let(:account) { Fabricate(:account) } let(:account) { Fabricate(:account) }
shared_examples 'unapproved account check' do describe 'unapproved account check' do
before { account.user.update(approved: false) } before { account.user.update(approved: false) }
it 'returns http not found' do it 'returns http not found' do
get :show, params: { username: account.username, format: format } %w(html json rss).each do |format|
get :show, params: { username: account.username, format: format }
expect(response).to have_http_status(404) expect(response).to have_http_status(404)
end
end end
end end
shared_examples 'permanently suspended account check' do describe 'permanently suspended account check' do
before do before do
account.suspend! account.suspend!
account.deletion_request.destroy account.deletion_request.destroy
end end
it 'returns http gone' do it 'returns http gone' do
get :show, params: { username: account.username, format: format } %w(html json rss).each do |format|
get :show, params: { username: account.username, format: format }
expect(response).to have_http_status(410) expect(response).to have_http_status(410)
end
end end
end end
shared_examples 'temporarily suspended account check' do |code: 403| describe 'temporarily suspended account check' do
before { account.suspend! } before { account.suspend! }
it 'returns appropriate http response code' do it 'returns appropriate http response code' do
get :show, params: { username: account.username, format: format } { html: 403, json: 200, rss: 403 }.each do |format, code|
get :show, params: { username: account.username, format: format }
expect(response).to have_http_status(code) expect(response).to have_http_status(code)
end
end end
end end
describe 'GET #show' do describe 'GET #show' do
context 'with basic account status checks' do
context 'with HTML' do
let(:format) { 'html' }
it_behaves_like 'unapproved account check'
it_behaves_like 'permanently suspended account check'
it_behaves_like 'temporarily suspended account check'
end
context 'with JSON' do
let(:format) { 'json' }
it_behaves_like 'unapproved account check'
it_behaves_like 'permanently suspended account check'
it_behaves_like 'temporarily suspended account check', code: 200
end
context 'with RSS' do
let(:format) { 'rss' }
it_behaves_like 'unapproved account check'
it_behaves_like 'permanently suspended account check'
it_behaves_like 'temporarily suspended account check'
end
end
context 'with existing statuses' do context 'with existing statuses' do
let!(:status) { Fabricate(:status, account: account) } let!(:status) { Fabricate(:status, account: account) }
let!(:status_reply) { Fabricate(:status, account: account, thread: Fabricate(:status)) } let!(:status_reply) { Fabricate(:status, account: account, thread: Fabricate(:status)) }
@ -227,22 +205,15 @@ RSpec.describe AccountsController do
context 'with RSS' do context 'with RSS' do
let(:format) { 'rss' } let(:format) { 'rss' }
shared_examples 'common RSS response' do
it 'returns http success' do
expect(response).to have_http_status(200)
end
it_behaves_like 'cacheable response', expects_vary: 'Accept, Accept-Language, Cookie'
end
context 'with a normal account in an RSS request' do context 'with a normal account in an RSS request' do
before do before do
get :show, params: { username: account.username, format: format } get :show, params: { username: account.username, format: format }
end end
it_behaves_like 'common RSS response' it_behaves_like 'cacheable response', expects_vary: 'Accept, Accept-Language, Cookie'
it 'responds with correct statuses', :aggregate_failures do it 'responds with correct statuses', :aggregate_failures do
expect(response).to have_http_status(200)
expect(response.body).to include_status_tag(status_media) expect(response.body).to include_status_tag(status_media)
expect(response.body).to include_status_tag(status_self_reply) expect(response.body).to include_status_tag(status_self_reply)
expect(response.body).to include_status_tag(status) expect(response.body).to include_status_tag(status)
@ -259,9 +230,10 @@ RSpec.describe AccountsController do
get :show, params: { username: account.username, format: format } get :show, params: { username: account.username, format: format }
end end
it_behaves_like 'common RSS response' it_behaves_like 'cacheable response', expects_vary: 'Accept, Accept-Language, Cookie'
it 'responds with correct statuses with replies', :aggregate_failures do it 'responds with correct statuses with replies', :aggregate_failures do
expect(response).to have_http_status(200)
expect(response.body).to include_status_tag(status_media) expect(response.body).to include_status_tag(status_media)
expect(response.body).to include_status_tag(status_reply) expect(response.body).to include_status_tag(status_reply)
expect(response.body).to include_status_tag(status_self_reply) expect(response.body).to include_status_tag(status_self_reply)
@ -278,9 +250,10 @@ RSpec.describe AccountsController do
get :show, params: { username: account.username, format: format } get :show, params: { username: account.username, format: format }
end end
it_behaves_like 'common RSS response' it_behaves_like 'cacheable response', expects_vary: 'Accept, Accept-Language, Cookie'
it 'responds with correct statuses with media', :aggregate_failures do it 'responds with correct statuses with media', :aggregate_failures do
expect(response).to have_http_status(200)
expect(response.body).to include_status_tag(status_media) expect(response.body).to include_status_tag(status_media)
expect(response.body).to_not include_status_tag(status_direct) expect(response.body).to_not include_status_tag(status_direct)
expect(response.body).to_not include_status_tag(status_private) expect(response.body).to_not include_status_tag(status_private)
@ -302,9 +275,10 @@ RSpec.describe AccountsController do
get :show, params: { username: account.username, format: format, tag: tag.to_param } get :show, params: { username: account.username, format: format, tag: tag.to_param }
end end
it_behaves_like 'common RSS response' it_behaves_like 'cacheable response', expects_vary: 'Accept, Accept-Language, Cookie'
it 'responds with correct statuses with a tag', :aggregate_failures do it 'responds with correct statuses with a tag', :aggregate_failures do
expect(response).to have_http_status(200)
expect(response.body).to include_status_tag(status_tag) expect(response.body).to include_status_tag(status_tag)
expect(response.body).to_not include_status_tag(status_direct) expect(response.body).to_not include_status_tag(status_direct)
expect(response.body).to_not include_status_tag(status_media) expect(response.body).to_not include_status_tag(status_media)