Commit 37452de8 authored by Jose Ivan Vargas's avatar Jose Ivan Vargas

Merge branch 'redirect-cicd-quick-buttons-to-pipeline-editor' into 'master'

Redirect users to the pipeline editor when clicking on CI/CD quick links

See merge request gitlab-org/gitlab!57085
parents 825cde32 92138aff
...@@ -93,10 +93,6 @@ class ProjectPresenter < Gitlab::View::Presenter::Delegated ...@@ -93,10 +93,6 @@ class ProjectPresenter < Gitlab::View::Presenter::Delegated
filename_path(repository.license_blob&.name) filename_path(repository.license_blob&.name)
end end
def ci_configuration_path
filename_path(repository.gitlab_ci_yml&.name)
end
def contribution_guide_path def contribution_guide_path
if project && contribution_guide = repository.contribution_guide if project && contribution_guide = repository.contribution_guide
project_blob_path( project_blob_path(
...@@ -131,10 +127,6 @@ class ProjectPresenter < Gitlab::View::Presenter::Delegated ...@@ -131,10 +127,6 @@ class ProjectPresenter < Gitlab::View::Presenter::Delegated
ide_edit_path(project, default_branch_or_master, 'CONTRIBUTING.md') ide_edit_path(project, default_branch_or_master, 'CONTRIBUTING.md')
end end
def add_ci_yml_path
add_special_file_path(file_name: ci_config_path_or_default)
end
def add_readme_path def add_readme_path
add_special_file_path(file_name: 'README.md') add_special_file_path(file_name: 'README.md')
end end
...@@ -384,11 +376,11 @@ class ProjectPresenter < Gitlab::View::Presenter::Delegated ...@@ -384,11 +376,11 @@ class ProjectPresenter < Gitlab::View::Presenter::Delegated
if cicd_missing? if cicd_missing?
AnchorData.new(false, AnchorData.new(false,
statistic_icon + _('Set up CI/CD'), statistic_icon + _('Set up CI/CD'),
add_ci_yml_path) project_ci_pipeline_editor_path(project))
elsif repository.gitlab_ci_yml.present? elsif repository.gitlab_ci_yml.present?
AnchorData.new(false, AnchorData.new(false,
statistic_icon('doc-text') + _('CI/CD configuration'), statistic_icon('doc-text') + _('CI/CD configuration'),
ci_configuration_path, project_ci_pipeline_editor_path(project),
'btn-default') 'btn-default')
end end
end end
......
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
= s_('Jobs|Use jobs to automate your tasks') = s_('Jobs|Use jobs to automate your tasks')
%p %p
= s_('Jobs|Jobs are the building blocks of a GitLab CI/CD pipeline. Each job has a specific task, like testing code. To set up jobs in a CI/CD pipeline, add a CI/CD configuration file to your project.') = s_('Jobs|Jobs are the building blocks of a GitLab CI/CD pipeline. Each job has a specific task, like testing code. To set up jobs in a CI/CD pipeline, add a CI/CD configuration file to your project.')
= link_to s_('Jobs|Create CI/CD configuration file'), @project.present(current_user: current_user).add_ci_yml_path, class: 'btn gl-button btn-info js-empty-state-button' = link_to s_('Jobs|Create CI/CD configuration file'), project_ci_pipeline_editor_path(project), class: 'btn gl-button btn-info js-empty-state-button'
- else - else
.nothing-here-block= s_('Jobs|No jobs to show') .nothing-here-block= s_('Jobs|No jobs to show')
- else - else
......
---
title: Redirect to the pipeline editor when clicking on CI/CD quick links
merge_request: 57085
author:
type: changed
...@@ -32,7 +32,7 @@ RSpec.describe 'Jobs', :clean_gitlab_redis_shared_state do ...@@ -32,7 +32,7 @@ RSpec.describe 'Jobs', :clean_gitlab_redis_shared_state do
it 'shows the empty state page' do it 'shows the empty state page' do
expect(page).to have_content('Use jobs to automate your tasks') expect(page).to have_content('Use jobs to automate your tasks')
expect(page).to have_link('Create CI/CD configuration file', href: project.present(current_user: user).add_ci_yml_path) expect(page).to have_link('Create CI/CD configuration file', href: project_ci_pipeline_editor_path(project))
end end
end end
......
...@@ -226,11 +226,11 @@ RSpec.describe 'Projects > Show > User sees setup shortcut buttons' do ...@@ -226,11 +226,11 @@ RSpec.describe 'Projects > Show > User sees setup shortcut buttons' do
expect(project.repository.gitlab_ci_yml).to be_nil expect(project.repository.gitlab_ci_yml).to be_nil
page.within('.project-buttons') do page.within('.project-buttons') do
expect(page).to have_link('Set up CI/CD', href: presenter.add_ci_yml_path) expect(page).to have_link('Set up CI/CD', href: project_ci_pipeline_editor_path(project))
end end
end end
it 'no "Set up CI/CD" button if the project already has a .gitlab-ci.yml' do it '"Set up CI/CD" button is renamed if the project already has a .gitlab-ci.yml' do
Files::CreateService.new( Files::CreateService.new(
project, project,
project.creator, project.creator,
...@@ -247,6 +247,7 @@ RSpec.describe 'Projects > Show > User sees setup shortcut buttons' do ...@@ -247,6 +247,7 @@ RSpec.describe 'Projects > Show > User sees setup shortcut buttons' do
page.within('.project-buttons') do page.within('.project-buttons') do
expect(page).not_to have_link('Set up CI/CD') expect(page).not_to have_link('Set up CI/CD')
expect(page).to have_link('CI/CD configuration')
end end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment