2020-01-01 13:55:28 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2023-04-23 21:23:45 +05:30
|
|
|
RSpec.describe 'Loading a user avatar', feature_category: :user_profile do
|
2020-01-01 13:55:28 +05:30
|
|
|
let(:user) { create(:user, :with_avatar) }
|
|
|
|
|
|
|
|
context 'when logged in' do
|
|
|
|
# The exact query count will vary depending on the 2FA settings of the
|
|
|
|
# instance, group, and user. Removing those extra 2FA queries in this case
|
|
|
|
# may not be a good idea, so we just set up the ideal case.
|
|
|
|
before do
|
|
|
|
stub_application_setting(require_two_factor_authentication: true)
|
|
|
|
|
|
|
|
login_as(create(:user, :two_factor))
|
|
|
|
end
|
|
|
|
|
|
|
|
# One each for: current user, avatar user, and upload record
|
|
|
|
it 'only performs three SQL queries' do
|
|
|
|
get user.avatar_url # Skip queries on first application load
|
|
|
|
|
2020-03-13 15:44:24 +05:30
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
2020-01-01 13:55:28 +05:30
|
|
|
expect { get user.avatar_url }.not_to exceed_query_limit(3)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when logged out' do
|
|
|
|
# One each for avatar user and upload record
|
|
|
|
it 'only performs two SQL queries' do
|
|
|
|
get user.avatar_url # Skip queries on first application load
|
|
|
|
|
2020-03-13 15:44:24 +05:30
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
2020-01-01 13:55:28 +05:30
|
|
|
expect { get user.avatar_url }.not_to exceed_query_limit(2)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|