2015-10-24 18:46:33 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2015-12-23 02:04:40 +05:30
|
|
|
describe 'Commits' do
|
2015-10-24 18:46:33 +05:30
|
|
|
include CiStatusHelper
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
let(:project) { create(:project, :repository) }
|
2017-09-10 17:25:29 +05:30
|
|
|
let(:user) { create(:user) }
|
2015-10-24 18:46:33 +05:30
|
|
|
|
2015-12-23 02:04:40 +05:30
|
|
|
describe 'CI' do
|
2015-10-24 18:46:33 +05:30
|
|
|
before do
|
2017-09-10 17:25:29 +05:30
|
|
|
sign_in(user)
|
2016-06-16 23:09:34 +05:30
|
|
|
stub_ci_pipeline_to_return_yaml_file
|
2015-10-24 18:46:33 +05:30
|
|
|
end
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
let(:creator) { create(:user) }
|
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
let!(:pipeline) do
|
2016-11-24 13:41:30 +05:30
|
|
|
create(:ci_pipeline,
|
|
|
|
project: project,
|
2017-08-17 22:00:37 +05:30
|
|
|
user: creator,
|
2016-11-24 13:41:30 +05:30
|
|
|
ref: project.default_branch,
|
|
|
|
sha: project.commit.sha,
|
2017-08-17 22:00:37 +05:30
|
|
|
status: :success,
|
|
|
|
created_at: 5.months.ago)
|
2015-12-23 02:04:40 +05:30
|
|
|
end
|
|
|
|
|
2016-02-05 20:25:01 +05:30
|
|
|
context 'commit status is Generic Commit Status' do
|
2016-11-24 13:41:30 +05:30
|
|
|
let!(:status) { create(:generic_commit_status, pipeline: pipeline) }
|
2015-12-23 02:04:40 +05:30
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
before do
|
2017-09-10 17:25:29 +05:30
|
|
|
project.team << [user, :reporter]
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
|
2016-02-05 20:25:01 +05:30
|
|
|
describe 'Commit builds' do
|
|
|
|
before do
|
2016-06-16 23:09:34 +05:30
|
|
|
visit ci_status_path(pipeline)
|
2016-02-05 20:25:01 +05:30
|
|
|
end
|
2015-12-23 02:04:40 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
it { expect(page).to have_content pipeline.sha[0..7] }
|
2016-02-05 20:25:01 +05:30
|
|
|
|
|
|
|
it 'contains generic commit status build' do
|
|
|
|
page.within('.table-holder') do
|
|
|
|
expect(page).to have_content "##{status.id}" # build id
|
|
|
|
expect(page).to have_content 'generic' # build name
|
|
|
|
end
|
2015-12-23 02:04:40 +05:30
|
|
|
end
|
|
|
|
end
|
2015-10-24 18:46:33 +05:30
|
|
|
end
|
|
|
|
|
2016-02-05 20:25:01 +05:30
|
|
|
context 'commit status is Ci Build' do
|
2016-11-24 13:41:30 +05:30
|
|
|
let!(:build) { create(:ci_build, pipeline: pipeline) }
|
2016-04-02 18:10:28 +05:30
|
|
|
let(:artifacts_file) { fixture_file_upload(Rails.root + 'spec/fixtures/banana_sample.gif', 'image/gif') }
|
2015-10-24 18:46:33 +05:30
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
context 'when logged as developer' do
|
2016-02-05 20:25:01 +05:30
|
|
|
before do
|
2017-09-10 17:25:29 +05:30
|
|
|
project.team << [user, :developer]
|
2016-02-05 20:25:01 +05:30
|
|
|
end
|
2015-11-26 14:37:03 +05:30
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
describe 'Project commits' do
|
2016-11-24 13:41:30 +05:30
|
|
|
let!(:pipeline_from_other_branch) do
|
|
|
|
create(:ci_pipeline,
|
|
|
|
project: project,
|
|
|
|
ref: 'fix',
|
|
|
|
sha: project.commit.sha,
|
|
|
|
status: :failed)
|
|
|
|
end
|
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
before do
|
2017-09-10 17:25:29 +05:30
|
|
|
visit project_commits_path(project, :master)
|
2016-02-05 20:25:01 +05:30
|
|
|
end
|
2015-11-26 14:37:03 +05:30
|
|
|
|
2016-11-24 13:41:30 +05:30
|
|
|
it 'shows correct build status from default branch' do
|
2016-06-16 23:09:34 +05:30
|
|
|
page.within("//li[@id='commit-#{pipeline.short_sha}']") do
|
2016-11-24 13:41:30 +05:30
|
|
|
expect(page).to have_css('.ci-status-link')
|
|
|
|
expect(page).to have_css('.ci-status-icon-success')
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
end
|
2016-02-05 20:25:01 +05:30
|
|
|
end
|
2015-11-26 14:37:03 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
describe 'Commit builds', :js do
|
2016-04-02 18:10:28 +05:30
|
|
|
before do
|
2016-06-16 23:09:34 +05:30
|
|
|
visit ci_status_path(pipeline)
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
2015-10-24 18:46:33 +05:30
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
it 'shows pipeline`s data' do
|
|
|
|
expect(page).to have_content pipeline.sha[0..7]
|
|
|
|
expect(page).to have_content pipeline.git_commit_message
|
|
|
|
expect(page).to have_content pipeline.user.name
|
|
|
|
end
|
2015-12-23 02:04:40 +05:30
|
|
|
end
|
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
context 'Download artifacts' do
|
|
|
|
before do
|
|
|
|
build.update_attributes(artifacts_file: artifacts_file)
|
|
|
|
end
|
2015-10-24 18:46:33 +05:30
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
it do
|
2016-06-16 23:09:34 +05:30
|
|
|
visit ci_status_path(pipeline)
|
2016-04-02 18:10:28 +05:30
|
|
|
click_on 'Download artifacts'
|
|
|
|
expect(page.response_headers['Content-Type']).to eq(artifacts_file.content_type)
|
|
|
|
end
|
2015-12-23 02:04:40 +05:30
|
|
|
end
|
2016-02-05 20:25:01 +05:30
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
describe 'Cancel all builds' do
|
2017-09-10 17:25:29 +05:30
|
|
|
it 'cancels commit', :js do
|
2016-06-16 23:09:34 +05:30
|
|
|
visit ci_status_path(pipeline)
|
2016-04-02 18:10:28 +05:30
|
|
|
click_on 'Cancel running'
|
|
|
|
expect(page).to have_content 'canceled'
|
2016-02-05 20:25:01 +05:30
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
2016-02-05 20:25:01 +05:30
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
describe 'Cancel build' do
|
2017-09-10 17:25:29 +05:30
|
|
|
it 'cancels build', :js do
|
2016-06-16 23:09:34 +05:30
|
|
|
visit ci_status_path(pipeline)
|
2017-09-10 17:25:29 +05:30
|
|
|
find('.js-btn-cancel-pipeline').click
|
2016-04-02 18:10:28 +05:30
|
|
|
expect(page).to have_content 'canceled'
|
2016-02-05 20:25:01 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
describe '.gitlab-ci.yml not found warning' do
|
|
|
|
context 'ci builds enabled' do
|
|
|
|
it "does not show warning" do
|
2016-06-16 23:09:34 +05:30
|
|
|
visit ci_status_path(pipeline)
|
2016-04-02 18:10:28 +05:30
|
|
|
expect(page).not_to have_content '.gitlab-ci.yml not found in this commit'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'shows warning' do
|
2016-06-16 23:09:34 +05:30
|
|
|
stub_ci_pipeline_yaml_file(nil)
|
|
|
|
visit ci_status_path(pipeline)
|
2016-04-02 18:10:28 +05:30
|
|
|
expect(page).to have_content '.gitlab-ci.yml not found in this commit'
|
|
|
|
end
|
2016-02-05 20:25:01 +05:30
|
|
|
end
|
2015-12-23 02:04:40 +05:30
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
context 'ci builds disabled' do
|
|
|
|
before do
|
|
|
|
stub_ci_builds_disabled
|
2016-06-16 23:09:34 +05:30
|
|
|
stub_ci_pipeline_yaml_file(nil)
|
|
|
|
visit ci_status_path(pipeline)
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not show warning' do
|
|
|
|
expect(page).not_to have_content '.gitlab-ci.yml not found in this commit'
|
|
|
|
end
|
2016-02-05 20:25:01 +05:30
|
|
|
end
|
2015-12-23 02:04:40 +05:30
|
|
|
end
|
2015-10-24 18:46:33 +05:30
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
|
|
|
|
context "when logged as reporter" do
|
|
|
|
before do
|
2017-09-10 17:25:29 +05:30
|
|
|
project.team << [user, :reporter]
|
2016-04-02 18:10:28 +05:30
|
|
|
build.update_attributes(artifacts_file: artifacts_file)
|
2016-06-16 23:09:34 +05:30
|
|
|
visit ci_status_path(pipeline)
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
it 'Renders header', :js do
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(page).to have_content pipeline.sha[0..7]
|
|
|
|
expect(page).to have_content pipeline.git_commit_message
|
2017-08-17 22:00:37 +05:30
|
|
|
expect(page).to have_content pipeline.user.name
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(page).not_to have_link('Cancel running')
|
2017-08-17 22:00:37 +05:30
|
|
|
expect(page).not_to have_link('Retry')
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
2017-09-10 17:25:29 +05:30
|
|
|
|
|
|
|
it do
|
|
|
|
expect(page).to have_link('Download artifacts')
|
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
context 'when accessing internal project with disallowed access', :js do
|
2016-04-02 18:10:28 +05:30
|
|
|
before do
|
|
|
|
project.update(
|
|
|
|
visibility_level: Gitlab::VisibilityLevel::INTERNAL,
|
|
|
|
public_builds: false)
|
|
|
|
build.update_attributes(artifacts_file: artifacts_file)
|
2016-06-16 23:09:34 +05:30
|
|
|
visit ci_status_path(pipeline)
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it do
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(page).to have_content pipeline.sha[0..7]
|
|
|
|
expect(page).to have_content pipeline.git_commit_message
|
2017-08-17 22:00:37 +05:30
|
|
|
expect(page).to have_content pipeline.user.name
|
2017-09-10 17:25:29 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(page).not_to have_link('Cancel running')
|
2017-08-17 22:00:37 +05:30
|
|
|
expect(page).not_to have_link('Retry')
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
end
|
2015-10-24 18:46:33 +05:30
|
|
|
end
|
|
|
|
end
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
context 'viewing commits for a branch' do
|
|
|
|
let(:branch_name) { 'master' }
|
|
|
|
|
|
|
|
before do
|
|
|
|
project.team << [user, :master]
|
2017-09-10 17:25:29 +05:30
|
|
|
sign_in(user)
|
|
|
|
visit project_commits_path(project, branch_name)
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it 'includes the committed_date for each commit' do
|
|
|
|
commits = project.repository.commits(branch_name)
|
|
|
|
|
|
|
|
commits.each do |commit|
|
|
|
|
expect(page).to have_content("committed #{commit.committed_date.strftime("%b %d, %Y")}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-09-10 17:25:29 +05:30
|
|
|
|
|
|
|
describe 'GPG signed commits', :js do
|
|
|
|
it 'changes from unverified to verified when the user changes his email to match the gpg key' do
|
|
|
|
user = create :user, email: 'unrelated.user@example.org'
|
|
|
|
project.team << [user, :master]
|
|
|
|
|
|
|
|
Sidekiq::Testing.inline! do
|
|
|
|
create :gpg_key, key: GpgHelpers::User1.public_key, user: user
|
|
|
|
end
|
|
|
|
|
|
|
|
sign_in(user)
|
|
|
|
|
|
|
|
visit project_commits_path(project, :'signed-commits')
|
|
|
|
|
|
|
|
within '#commits-list' do
|
|
|
|
expect(page).to have_content 'Unverified'
|
|
|
|
expect(page).not_to have_content 'Verified'
|
|
|
|
end
|
|
|
|
|
|
|
|
# user changes his email which makes the gpg key verified
|
|
|
|
Sidekiq::Testing.inline! do
|
|
|
|
user.skip_reconfirmation!
|
|
|
|
user.update_attributes!(email: GpgHelpers::User1.emails.first)
|
|
|
|
end
|
|
|
|
|
|
|
|
visit project_commits_path(project, :'signed-commits')
|
|
|
|
|
|
|
|
within '#commits-list' do
|
|
|
|
expect(page).to have_content 'Unverified'
|
|
|
|
expect(page).to have_content 'Verified'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'changes from unverified to verified when the user adds the missing gpg key' do
|
|
|
|
user = create :user, email: GpgHelpers::User1.emails.first
|
|
|
|
project.team << [user, :master]
|
|
|
|
|
|
|
|
sign_in(user)
|
|
|
|
|
|
|
|
visit project_commits_path(project, :'signed-commits')
|
|
|
|
|
|
|
|
within '#commits-list' do
|
|
|
|
expect(page).to have_content 'Unverified'
|
|
|
|
expect(page).not_to have_content 'Verified'
|
|
|
|
end
|
|
|
|
|
|
|
|
# user adds the gpg key which makes the signature valid
|
|
|
|
Sidekiq::Testing.inline! do
|
|
|
|
create :gpg_key, key: GpgHelpers::User1.public_key, user: user
|
|
|
|
end
|
|
|
|
|
|
|
|
visit project_commits_path(project, :'signed-commits')
|
|
|
|
|
|
|
|
within '#commits-list' do
|
|
|
|
expect(page).to have_content 'Unverified'
|
|
|
|
expect(page).to have_content 'Verified'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'shows popover badges' do
|
|
|
|
gpg_user = create :user, email: GpgHelpers::User1.emails.first, username: 'nannie.bernhard', name: 'Nannie Bernhard'
|
|
|
|
Sidekiq::Testing.inline! do
|
|
|
|
create :gpg_key, key: GpgHelpers::User1.public_key, user: gpg_user
|
|
|
|
end
|
|
|
|
|
|
|
|
user = create :user
|
|
|
|
project.team << [user, :master]
|
|
|
|
|
|
|
|
sign_in(user)
|
|
|
|
visit project_commits_path(project, :'signed-commits')
|
|
|
|
|
|
|
|
# unverified signature
|
|
|
|
click_on 'Unverified', match: :first
|
|
|
|
within '.popover' do
|
|
|
|
expect(page).to have_content 'This commit was signed with an unverified signature.'
|
|
|
|
expect(page).to have_content "GPG Key ID: #{GpgHelpers::User2.primary_keyid}"
|
|
|
|
end
|
|
|
|
|
|
|
|
# verified and the gpg user has a gitlab profile
|
|
|
|
click_on 'Verified', match: :first
|
|
|
|
within '.popover' do
|
|
|
|
expect(page).to have_content 'This commit was signed with a verified signature.'
|
|
|
|
expect(page).to have_content 'Nannie Bernhard'
|
|
|
|
expect(page).to have_content '@nannie.bernhard'
|
|
|
|
expect(page).to have_content "GPG Key ID: #{GpgHelpers::User1.primary_keyid}"
|
|
|
|
end
|
|
|
|
|
|
|
|
# verified and the gpg user's profile doesn't exist anymore
|
|
|
|
gpg_user.destroy!
|
|
|
|
|
|
|
|
visit project_commits_path(project, :'signed-commits')
|
|
|
|
|
|
|
|
click_on 'Verified', match: :first
|
|
|
|
within '.popover' do
|
|
|
|
expect(page).to have_content 'This commit was signed with a verified signature.'
|
|
|
|
expect(page).to have_content 'Nannie Bernhard'
|
|
|
|
expect(page).to have_content 'nannie.bernhard@example.com'
|
|
|
|
expect(page).to have_content "GPG Key ID: #{GpgHelpers::User1.primary_keyid}"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2015-10-24 18:46:33 +05:30
|
|
|
end
|