2018-03-17 18:26:18 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe 'User browses commits' do
|
2018-10-15 14:42:47 +05:30
|
|
|
include RepoHelpers
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:project) { create(:project, :repository, namespace: user.namespace) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
project.add_master(user)
|
|
|
|
sign_in(user)
|
|
|
|
end
|
|
|
|
|
2018-10-15 14:42:47 +05:30
|
|
|
it 'renders commit' do
|
|
|
|
visit project_commit_path(project, sample_commit.id)
|
|
|
|
|
|
|
|
expect(page).to have_content(sample_commit.message)
|
|
|
|
.and have_content("Showing #{sample_commit.files_changed_count} changed files")
|
|
|
|
.and have_content('Side-by-side')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'fill commit sha when click new tag from commit page' do
|
|
|
|
visit project_commit_path(project, sample_commit.id)
|
|
|
|
click_link 'Tag'
|
|
|
|
|
|
|
|
expect(page).to have_selector("input[value='#{sample_commit.id}']", visible: false)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders inline diff button when click side-by-side diff button' do
|
|
|
|
visit project_commit_path(project, sample_commit.id)
|
|
|
|
find('#parallel-diff-btn').click
|
|
|
|
|
|
|
|
expect(page).to have_content 'Inline'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders breadcrumbs on specific commit path' do
|
|
|
|
visit project_commits_path(project, project.repository.root_ref + '/files/ruby/regex.rb', limit: 5)
|
|
|
|
|
|
|
|
expect(page).to have_selector('ul.breadcrumb')
|
|
|
|
.and have_selector('ul.breadcrumb a', count: 4)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders diff links to both the previous and current image' do
|
|
|
|
visit project_commit_path(project, sample_image_commit.id)
|
|
|
|
|
|
|
|
links = page.all('.file-actions a')
|
|
|
|
expect(links[0]['href']).to match %r{blob/#{sample_image_commit.old_blob_id}}
|
|
|
|
expect(links[1]['href']).to match %r{blob/#{sample_image_commit.new_blob_id}}
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when commit has ci status' do
|
|
|
|
let(:pipeline) { create(:ci_pipeline, project: project, sha: sample_commit.id) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
project.enable_ci
|
|
|
|
|
|
|
|
create(:ci_build, pipeline: pipeline)
|
|
|
|
|
|
|
|
allow_any_instance_of(Ci::Pipeline).to receive(:ci_yaml_file).and_return('')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders commit ci info' do
|
|
|
|
visit project_commit_path(project, sample_commit.id)
|
|
|
|
|
|
|
|
expect(page).to have_content "Pipeline ##{pipeline.id} pending"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
context 'primary email' do
|
|
|
|
it 'finds a commit by a primary email' do
|
|
|
|
user = create(:user, email: 'dmitriy.zaporozhets@gmail.com')
|
|
|
|
|
2018-10-15 14:42:47 +05:30
|
|
|
visit(project_commit_path(project, sample_commit.id))
|
2018-03-17 18:26:18 +05:30
|
|
|
|
2018-10-15 14:42:47 +05:30
|
|
|
check_author_link(sample_commit.author_email, user)
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'secondary email' do
|
|
|
|
it 'finds a commit by a secondary email' do
|
|
|
|
user =
|
|
|
|
create(:user) do |user|
|
|
|
|
create(:email, { user: user, email: 'dmitriy.zaporozhets@gmail.com' })
|
|
|
|
end
|
|
|
|
|
2018-10-15 14:42:47 +05:30
|
|
|
visit(project_commit_path(project, sample_commit.parent_id))
|
2018-03-17 18:26:18 +05:30
|
|
|
|
2018-10-15 14:42:47 +05:30
|
|
|
check_author_link(sample_commit.author_email, user)
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the blob does not exist' do
|
|
|
|
let(:commit) { create(:commit, project: project) }
|
|
|
|
|
|
|
|
it 'shows a blank label' do
|
|
|
|
allow_any_instance_of(Gitlab::Diff::File).to receive(:blob).and_return(nil)
|
|
|
|
allow_any_instance_of(Gitlab::Diff::File).to receive(:raw_binary?).and_return(true)
|
|
|
|
|
|
|
|
visit(project_commit_path(project, commit))
|
|
|
|
|
|
|
|
expect(find('.diff-file-changes', visible: false)).to have_content('No file name available')
|
|
|
|
end
|
|
|
|
end
|
2018-10-15 14:42:47 +05:30
|
|
|
|
|
|
|
describe 'commits list' do
|
|
|
|
let(:visit_commits_page) do
|
|
|
|
visit project_commits_path(project, project.repository.root_ref, limit: 5)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'searches commit', :js do
|
|
|
|
visit_commits_page
|
|
|
|
fill_in 'commits-search', with: 'submodules'
|
|
|
|
|
|
|
|
expect(page).to have_content 'More submodules'
|
|
|
|
expect(page).not_to have_content 'Change some files'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders commits atom feed' do
|
|
|
|
visit_commits_page
|
|
|
|
click_link('Commits feed')
|
|
|
|
|
|
|
|
commit = project.repository.commit
|
|
|
|
|
|
|
|
expect(response_headers['Content-Type']).to have_content("application/atom+xml")
|
|
|
|
expect(body).to have_selector('title', text: "#{project.name}:master commits")
|
|
|
|
.and have_selector('author email', text: commit.author_email)
|
|
|
|
.and have_selector('entry summary', text: commit.description[0..10].delete("\r\n"))
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'master branch' do
|
|
|
|
before do
|
|
|
|
visit_commits_page
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders project commits' do
|
|
|
|
commit = project.repository.commit
|
|
|
|
|
|
|
|
expect(page).to have_content(project.name)
|
|
|
|
.and have_content(commit.message[0..20])
|
|
|
|
.and have_content(commit.short_id)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not render create merge request button' do
|
|
|
|
expect(page).not_to have_link 'Create merge request'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when click the compare tab' do
|
|
|
|
before do
|
|
|
|
click_link('Compare')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not render create merge request button' do
|
|
|
|
expect(page).not_to have_link 'Create merge request'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'feature branch' do
|
|
|
|
let(:visit_commits_page) do
|
|
|
|
visit project_commits_path(project, 'feature')
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when project does not have open merge requests' do
|
|
|
|
before do
|
|
|
|
visit_commits_page
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders project commits' do
|
|
|
|
commit = project.repository.commit('0b4bc9a')
|
|
|
|
|
|
|
|
expect(page).to have_content(project.name)
|
|
|
|
.and have_content(commit.message[0..12])
|
|
|
|
.and have_content(commit.short_id)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders create merge request button' do
|
|
|
|
expect(page).to have_link 'Create merge request'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when click the compare tab' do
|
|
|
|
before do
|
|
|
|
click_link('Compare')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders create merge request button' do
|
|
|
|
expect(page).to have_link 'Create merge request'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when project have open merge request' do
|
|
|
|
let!(:merge_request) do
|
|
|
|
create(
|
|
|
|
:merge_request,
|
|
|
|
title: 'Feature',
|
|
|
|
source_project: project,
|
|
|
|
source_branch: 'feature',
|
|
|
|
target_branch: 'master',
|
|
|
|
author: project.users.first
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
visit_commits_page
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders project commits' do
|
|
|
|
commit = project.repository.commit('0b4bc9a')
|
|
|
|
|
|
|
|
expect(page).to have_content(project.name)
|
|
|
|
.and have_content(commit.message[0..12])
|
|
|
|
.and have_content(commit.short_id)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders button to the merge request' do
|
|
|
|
expect(page).not_to have_link 'Create merge request'
|
|
|
|
expect(page).to have_link 'View open merge request', href: project_merge_request_path(project, merge_request)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when click the compare tab' do
|
|
|
|
before do
|
|
|
|
click_link('Compare')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders button to the merge request' do
|
|
|
|
expect(page).not_to have_link 'Create merge request'
|
|
|
|
expect(page).to have_link 'View open merge request', href: project_merge_request_path(project, merge_request)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def check_author_link(email, author)
|
|
|
|
author_link = find('.commit-author-link')
|
|
|
|
|
|
|
|
expect(author_link['href']).to eq(user_path(author))
|
|
|
|
expect(author_link['title']).to eq(email)
|
|
|
|
expect(find('.commit-author-name').text).to eq(author.name)
|
|
|
|
end
|