debian-mirror-gitlab/spec/features/merge_request/user_sees_pipelines_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

282 lines
9.2 KiB
Ruby
Raw Normal View History

2019-10-12 21:52:04 +05:30
# frozen_string_literal: true
2019-12-04 20:38:33 +05:30
require 'spec_helper'
2016-09-13 17:45:13 +05:30
2023-03-17 16:20:25 +05:30
RSpec.describe 'Merge request > User sees pipelines', :js, feature_category: :code_review_workflow do
2017-09-10 17:25:29 +05:30
describe 'pipeline tab' do
2018-03-17 18:26:18 +05:30
let(:merge_request) { create(:merge_request) }
let(:project) { merge_request.target_project }
let(:user) { project.creator }
2016-09-13 17:45:13 +05:30
2017-09-10 17:25:29 +05:30
before do
2018-11-18 11:00:15 +05:30
project.add_maintainer(user)
2018-03-17 18:26:18 +05:30
sign_in(user)
2016-09-13 17:45:13 +05:30
end
2017-09-10 17:25:29 +05:30
context 'with pipelines' do
let!(:pipeline) do
2023-07-09 08:55:56 +05:30
create(:ci_pipeline,
:success,
2017-09-10 17:25:29 +05:30
project: merge_request.source_project,
ref: merge_request.source_branch,
sha: merge_request.diff_head_sha)
end
2023-07-09 08:55:56 +05:30
let!(:manual_job) { create(:ci_build, :manual, name: 'job1', stage: 'deploy', pipeline: pipeline) }
let!(:job) { create(:ci_build, :success, name: 'job2', stage: 'test', pipeline: pipeline) }
2017-09-10 17:25:29 +05:30
before do
2018-03-17 18:26:18 +05:30
merge_request.update_attribute(:head_pipeline_id, pipeline.id)
2017-09-10 17:25:29 +05:30
end
2023-07-09 08:55:56 +05:30
it 'pipelines table displays correctly' do
2018-03-17 18:26:18 +05:30
visit project_merge_request_path(project, merge_request)
2023-07-09 08:55:56 +05:30
expect(page.find('.ci-widget')).to have_content('passed')
2018-03-17 18:26:18 +05:30
2017-09-10 17:25:29 +05:30
page.within('.merge-request-tabs') do
click_link('Pipelines')
end
2023-07-09 08:55:56 +05:30
2017-09-10 17:25:29 +05:30
wait_for_requests
2023-07-09 08:55:56 +05:30
page.within('[data-testid="pipeline-table-row"]') do
expect(page).to have_selector('.ci-success')
expect(page).to have_content(pipeline.id)
expect(page).to have_content('API')
expect(page).to have_css('[data-testid="pipeline-mini-graph"]')
expect(page).to have_css('[data-testid="pipelines-manual-actions-dropdown"]')
expect(page).to have_css('[data-testid="pipeline-multi-actions-dropdown"]')
end
2017-09-10 17:25:29 +05:30
end
2018-03-17 18:26:18 +05:30
2019-12-04 20:38:33 +05:30
context 'with a detached merge request pipeline' do
let(:merge_request) { create(:merge_request, :with_detached_merge_request_pipeline) }
2021-04-29 21:17:54 +05:30
it 'displays the "Run pipeline" button' do
2019-12-04 20:38:33 +05:30
visit project_merge_request_path(project, merge_request)
page.within('.merge-request-tabs') do
click_link('Pipelines')
end
wait_for_requests
2021-04-29 21:17:54 +05:30
expect(page.find('[data-testid="run_pipeline_button"]')).to have_text('Run pipeline')
2019-12-04 20:38:33 +05:30
end
end
context 'with a merged results pipeline' do
let(:merge_request) { create(:merge_request, :with_merge_request_pipeline) }
2021-04-29 21:17:54 +05:30
it 'displays the "Run pipeline" button' do
2019-12-04 20:38:33 +05:30
visit project_merge_request_path(project, merge_request)
page.within('.merge-request-tabs') do
click_link('Pipelines')
end
wait_for_requests
2021-04-29 21:17:54 +05:30
expect(page.find('[data-testid="run_pipeline_button"]')).to have_text('Run pipeline')
2019-12-04 20:38:33 +05:30
end
end
2016-09-13 17:45:13 +05:30
end
2017-09-10 17:25:29 +05:30
context 'without pipelines' do
before do
visit project_merge_request_path(project, merge_request)
2016-09-13 17:45:13 +05:30
end
2018-03-17 18:26:18 +05:30
it 'user visits merge request page' do
2017-09-10 17:25:29 +05:30
page.within('.merge-request-tabs') do
2022-08-27 11:52:29 +05:30
expect(page).to have_link('Pipelines')
2017-09-10 17:25:29 +05:30
end
end
2022-08-27 11:52:29 +05:30
it 'shows empty state with run pipeline button' do
page.within('.merge-request-tabs') do
click_link('Pipelines')
end
expect(page).to have_content('There are currently no pipelines.')
expect(page.find('[data-testid="run_pipeline_button"]')).to have_text('Run pipeline')
end
2016-09-13 17:45:13 +05:30
end
end
2020-07-28 23:09:34 +05:30
describe 'fork MRs in parent project', :sidekiq_inline do
include ProjectForksHelper
let_it_be(:parent_project) { create(:project, :public, :repository) }
let_it_be(:forked_project) { fork_project(parent_project, developer_in_fork, repository: true, target_project: create(:project, :public, :repository)) }
let_it_be(:developer_in_parent) { create(:user) }
let_it_be(:developer_in_fork) { create(:user) }
let_it_be(:reporter_in_parent_and_developer_in_fork) { create(:user) }
let(:merge_request) do
create(:merge_request, :with_detached_merge_request_pipeline,
source_project: forked_project, source_branch: 'feature',
target_project: parent_project, target_branch: 'master')
end
let(:config) do
{ test: { script: 'test', rules: [{ if: '$CI_MERGE_REQUEST_ID' }] } }
end
before_all do
parent_project.add_developer(developer_in_parent)
parent_project.add_reporter(reporter_in_parent_and_developer_in_fork)
forked_project.add_developer(developer_in_fork)
forked_project.add_developer(reporter_in_parent_and_developer_in_fork)
end
before do
stub_ci_pipeline_yaml_file(YAML.dump(config))
sign_in(actor)
end
after do
parent_project.all_pipelines.delete_all
forked_project.all_pipelines.delete_all
end
context 'when actor is a developer in parent project' do
let(:actor) { developer_in_parent }
2020-10-24 23:57:45 +05:30
it 'creates a pipeline in the parent project when user proceeds with the warning' do
2020-07-28 23:09:34 +05:30
visit project_merge_request_path(parent_project, merge_request)
create_merge_request_pipeline
2021-04-29 21:17:54 +05:30
act_on_security_warning(action: 'Run pipeline')
2020-07-28 23:09:34 +05:30
check_pipeline(expected_project: parent_project)
check_head_pipeline(expected_project: parent_project)
end
2020-10-24 23:57:45 +05:30
2021-09-30 23:02:18 +05:30
it 'does not create a pipeline in the parent project when user cancels the action', :clean_gitlab_redis_cache, :clean_gitlab_redis_shared_state do
2020-10-24 23:57:45 +05:30
visit project_merge_request_path(parent_project, merge_request)
create_merge_request_pipeline
act_on_security_warning(action: 'Cancel')
check_no_pipelines
end
2020-07-28 23:09:34 +05:30
end
context 'when actor is a developer in fork project' do
let(:actor) { developer_in_fork }
it 'creates a pipeline in the fork project' do
visit project_merge_request_path(parent_project, merge_request)
create_merge_request_pipeline
check_pipeline(expected_project: forked_project)
check_head_pipeline(expected_project: forked_project)
end
end
context 'when actor is a reporter in parent project and a developer in fork project' do
let(:actor) { reporter_in_parent_and_developer_in_fork }
it 'creates a pipeline in the fork project' do
visit project_merge_request_path(parent_project, merge_request)
create_merge_request_pipeline
check_pipeline(expected_project: forked_project)
check_head_pipeline(expected_project: forked_project)
end
end
def create_merge_request_pipeline
page.within('.merge-request-tabs') { click_link('Pipelines') }
2021-04-29 21:17:54 +05:30
click_button('Run pipeline')
2020-07-28 23:09:34 +05:30
end
def check_pipeline(expected_project:)
page.within('.ci-table') do
expect(page).to have_selector('.commit', count: 2)
page.within(first('.commit')) do
page.within('.pipeline-tags') do
2021-03-08 18:12:59 +05:30
expect(page.find('[data-testid="pipeline-url-link"]')[:href]).to include(expected_project.full_path)
2022-05-07 20:08:51 +05:30
expect(page).to have_content('merge request')
2020-07-28 23:09:34 +05:30
end
page.within('.pipeline-triggerer') do
expect(page).to have_link(href: user_path(actor))
end
end
end
end
def check_head_pipeline(expected_project:)
page.within('.merge-request-tabs') { click_link('Overview') }
page.within('.ci-widget-content') do
expect(page.find('.pipeline-id')[:href]).to include(expected_project.full_path)
end
end
2020-10-24 23:57:45 +05:30
def act_on_security_warning(action:)
page.within('#create-pipeline-for-fork-merge-request-modal') do
expect(page).to have_content('Are you sure you want to run this pipeline?')
click_button(action)
end
end
def check_no_pipelines
page.within('.ci-table') do
expect(page).to have_selector('.commit', count: 1)
end
end
2020-07-28 23:09:34 +05:30
end
2017-09-10 17:25:29 +05:30
describe 'race condition' do
2018-03-17 18:26:18 +05:30
let(:project) { create(:project, :repository) }
let(:user) { create(:user) }
let(:build_push_data) { { ref: 'feature', checkout_sha: TestEnv::BRANCH_SHA['feature'] } }
2017-09-10 17:25:29 +05:30
2018-03-17 18:26:18 +05:30
let(:merge_request_params) do
2017-09-10 17:25:29 +05:30
{ "source_branch" => "feature", "source_project_id" => project.id,
"target_branch" => "master", "target_project_id" => project.id, "title" => "A" }
end
2018-03-17 18:26:18 +05:30
before do
2018-11-18 11:00:15 +05:30
project.add_maintainer(user)
2017-09-10 17:25:29 +05:30
sign_in user
2016-09-13 17:45:13 +05:30
end
2022-05-07 20:08:51 +05:30
context 'when pipeline and merge request were created simultaneously', :delete do
2018-03-17 18:26:18 +05:30
before do
2017-09-10 17:25:29 +05:30
stub_ci_pipeline_to_return_yaml_file
threads = []
threads << Thread.new do
2021-03-08 18:12:59 +05:30
Sidekiq::Worker.skipping_transaction_check do
2021-06-08 01:23:25 +05:30
@merge_request = MergeRequests::CreateService.new(project: project, current_user: user, params: merge_request_params).execute
2021-03-08 18:12:59 +05:30
end
2017-09-10 17:25:29 +05:30
end
threads << Thread.new do
2021-03-08 18:12:59 +05:30
Sidekiq::Worker.skipping_transaction_check do
2021-10-27 15:23:28 +05:30
@pipeline = Ci::CreatePipelineService.new(project, user, build_push_data).execute(:push).payload
2021-03-08 18:12:59 +05:30
end
2017-09-10 17:25:29 +05:30
end
threads.each { |thr| thr.join }
end
2019-12-26 22:10:19 +05:30
it 'user sees pipeline in merge request widget', :sidekiq_might_not_need_inline do
2017-09-10 17:25:29 +05:30
visit project_merge_request_path(project, @merge_request)
expect(page.find(".ci-widget")).to have_content(TestEnv::BRANCH_SHA['feature'])
expect(page.find(".ci-widget")).to have_content("##{@pipeline.id}")
2016-09-13 17:45:13 +05:30
end
end
end
end