139 lines
3.9 KiB
Ruby
139 lines
3.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe 'User visits their profile' do
|
|
let_it_be_with_refind(:user) { create(:user) }
|
|
|
|
before do
|
|
sign_in(user)
|
|
end
|
|
|
|
it 'shows correct menu item' do
|
|
visit(profile_path)
|
|
|
|
expect(page).to have_active_navigation('Profile')
|
|
end
|
|
|
|
it 'shows profile info' do
|
|
visit(profile_path)
|
|
|
|
expect(page).to have_content "This information will appear on your profile"
|
|
end
|
|
|
|
it 'shows user readme' do
|
|
create(:project, :repository, :public, path: user.username, namespace: user.namespace)
|
|
|
|
visit(user_path(user))
|
|
|
|
expect(find('.file-content')).to have_content('testme')
|
|
end
|
|
|
|
it 'hides empty user readme' do
|
|
project = create(:project, :repository, :public, path: user.username, namespace: user.namespace)
|
|
|
|
Files::UpdateService.new(
|
|
project,
|
|
user,
|
|
start_branch: 'master',
|
|
branch_name: 'master',
|
|
commit_message: 'Update feature',
|
|
file_path: 'README.md',
|
|
file_content: ''
|
|
).execute
|
|
|
|
visit(user_path(user))
|
|
|
|
expect(page).not_to have_selector('.file-content')
|
|
end
|
|
|
|
context 'when user has groups' do
|
|
let(:group) do
|
|
create :group do |group|
|
|
group.add_owner(user)
|
|
end
|
|
end
|
|
|
|
let!(:project) do
|
|
create(:project, :repository, namespace: group) do |project|
|
|
create(:closed_issue_event, project: project)
|
|
project.add_maintainer(user)
|
|
end
|
|
end
|
|
|
|
def click_on_profile_picture
|
|
find(:css, '.header-user-dropdown-toggle').click
|
|
|
|
page.within ".header-user" do
|
|
click_link user.username
|
|
end
|
|
end
|
|
|
|
it 'shows user groups', :js do
|
|
visit(profile_path)
|
|
click_on_profile_picture
|
|
|
|
page.within ".cover-block" do
|
|
expect(page).to have_content user.name
|
|
expect(page).to have_content user.username
|
|
end
|
|
|
|
page.within ".content" do
|
|
click_link "Groups"
|
|
end
|
|
|
|
page.within "#groups" do
|
|
expect(page).to have_content group.name
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'storage_enforcement_banner', :js do
|
|
context 'with storage_enforcement_date set' do
|
|
let_it_be(:storage_enforcement_date) { Date.today + 30 }
|
|
|
|
before do
|
|
allow_next_found_instance_of(Namespaces::UserNamespace) do |g|
|
|
allow(g).to receive(:storage_enforcement_date).and_return(storage_enforcement_date)
|
|
end
|
|
end
|
|
|
|
it 'displays the banner in the profile page' do
|
|
visit(profile_path)
|
|
expect_page_to_have_storage_enforcement_banner(storage_enforcement_date)
|
|
end
|
|
|
|
it 'does not display the banner if user has previously closed unless threshold has changed' do
|
|
visit(profile_path)
|
|
expect_page_to_have_storage_enforcement_banner(storage_enforcement_date)
|
|
find('.js-storage-enforcement-banner [data-testid="close-icon"]').click
|
|
page.refresh
|
|
expect_page_not_to_have_storage_enforcement_banner
|
|
|
|
storage_enforcement_date = Date.today + 13
|
|
allow_next_found_instance_of(Namespaces::UserNamespace) do |g|
|
|
allow(g).to receive(:storage_enforcement_date).and_return(storage_enforcement_date)
|
|
end
|
|
page.refresh
|
|
expect_page_to_have_storage_enforcement_banner(storage_enforcement_date)
|
|
end
|
|
end
|
|
|
|
context 'with storage_enforcement_date not set' do
|
|
# This test should break and be rewritten after the implementation of the storage_enforcement_date
|
|
# TBD: https://gitlab.com/gitlab-org/gitlab/-/issues/350632
|
|
it 'does not display the banner in the group page' do
|
|
visit(profile_path)
|
|
expect_page_not_to_have_storage_enforcement_banner
|
|
end
|
|
end
|
|
end
|
|
|
|
def expect_page_to_have_storage_enforcement_banner(storage_enforcement_date)
|
|
expect(page).to have_text "From #{storage_enforcement_date} storage limits will apply to this namespace"
|
|
end
|
|
|
|
def expect_page_not_to_have_storage_enforcement_banner
|
|
expect(page).not_to have_text "storage limits will apply to this namespace"
|
|
end
|
|
end
|