75496059a1
Continues the iteration on the project overview UI: - moved star, fork and new clone button (copy SSH/HTTPS URLs) to top right, made them smaller - avatar is now larger (64px) - 'Request access' is now a link instead of a button - overview comes before the description + changed styling and added icons - description font-size is now 16px (large-paragraph) - quick links to files are moved downwards below the commit/pipeline info - margins changed to group content into 4 groups to clean up the interface - visibility info reduced to icon-only and moved to the right of the title
145 lines
3.6 KiB
Ruby
145 lines
3.6 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe 'projects/_home_panel' do
|
|
context 'notifications' do
|
|
let(:project) { create(:project) }
|
|
|
|
before do
|
|
assign(:project, project)
|
|
|
|
allow(view).to receive(:current_user).and_return(user)
|
|
allow(view).to receive(:can?).with(user, :read_project, project).and_return(false)
|
|
allow(project).to receive(:license_anchor_data).and_return(false)
|
|
end
|
|
|
|
context 'when user is signed in' do
|
|
let(:user) { create(:user) }
|
|
|
|
before do
|
|
notification_settings = user.notification_settings_for(project)
|
|
assign(:notification_setting, notification_settings)
|
|
end
|
|
|
|
it 'makes it possible to set notification level' do
|
|
render
|
|
|
|
expect(view).to render_template('projects/buttons/_notifications')
|
|
expect(rendered).to have_selector('.notification-dropdown')
|
|
end
|
|
end
|
|
|
|
context 'when user is signed out' do
|
|
let(:user) { nil }
|
|
|
|
before do
|
|
assign(:notification_setting, nil)
|
|
end
|
|
|
|
it 'is not possible to set notification level' do
|
|
render
|
|
|
|
expect(rendered).not_to have_selector('.notification_dropdown')
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'badges' do
|
|
shared_examples 'show badges' do
|
|
it 'should render the all badges' do
|
|
render
|
|
|
|
expect(rendered).to have_selector('.project-badges a')
|
|
|
|
badges.each do |badge|
|
|
expect(rendered).to have_link(href: badge.rendered_link_url)
|
|
end
|
|
end
|
|
end
|
|
|
|
let(:user) { create(:user) }
|
|
let(:badges) { project.badges }
|
|
|
|
before do
|
|
assign(:project, project)
|
|
|
|
allow(view).to receive(:current_user).and_return(user)
|
|
allow(view).to receive(:can?).with(user, :read_project, project).and_return(false)
|
|
allow(project).to receive(:license_anchor_data).and_return(false)
|
|
end
|
|
|
|
context 'has no badges' do
|
|
let(:project) { create(:project) }
|
|
|
|
it 'should not render any badge' do
|
|
render
|
|
|
|
expect(rendered).not_to have_selector('.project-badges')
|
|
end
|
|
end
|
|
|
|
context 'only has group badges' do
|
|
let(:group) { create(:group) }
|
|
let(:project) { create(:project, namespace: group) }
|
|
|
|
before do
|
|
create(:group_badge, group: project.group)
|
|
end
|
|
|
|
it_behaves_like 'show badges'
|
|
end
|
|
|
|
context 'only has project badges' do
|
|
let(:project) { create(:project) }
|
|
|
|
before do
|
|
create(:project_badge, project: project)
|
|
end
|
|
|
|
it_behaves_like 'show badges'
|
|
end
|
|
|
|
context 'has both group and project badges' do
|
|
let(:group) { create(:group) }
|
|
let(:project) { create(:project, namespace: group) }
|
|
|
|
before do
|
|
create(:project_badge, project: project)
|
|
create(:group_badge, group: project.group)
|
|
end
|
|
|
|
it_behaves_like 'show badges'
|
|
end
|
|
end
|
|
|
|
context 'project id' do
|
|
let(:project) { create(:project) }
|
|
let(:user) { create(:user) }
|
|
|
|
before do
|
|
assign(:project, project)
|
|
|
|
allow(view).to receive(:current_user).and_return(user)
|
|
allow(project).to receive(:license_anchor_data).and_return(false)
|
|
end
|
|
|
|
context 'user can read project' do
|
|
it 'is shown' do
|
|
allow(view).to receive(:can?).with(user, :read_project, project).and_return(true)
|
|
|
|
render
|
|
|
|
expect(rendered).to have_content("Project ID: #{project.id}")
|
|
end
|
|
end
|
|
|
|
context 'user cannot read project' do
|
|
it 'is not shown' do
|
|
allow(view).to receive(:can?).with(user, :read_project, project).and_return(false)
|
|
|
|
render
|
|
|
|
expect(rendered).not_to have_content("Project ID: #{project.id}")
|
|
end
|
|
end
|
|
end
|
|
end
|