Commit 9bd4e0d1 authored by Kushal Pandya's avatar Kushal Pandya

Merge branch...

Merge branch '273293-fy21q4-foundations-kr2-audit-and-update-buttons-on-projects-pipelinescontroller-index' into 'master'

Audit and update buttons on Projects::PipelinesController#index

See merge request gitlab-org/gitlab!58112
parents fd78a98e 96e26e15
...@@ -81,7 +81,7 @@ export default { ...@@ -81,7 +81,7 @@ export default {
return this.hasError && !this.isLoading; return this.hasError && !this.isLoading;
}, },
/** /**
* The Run Pipeline button can only be rendered when: * The "Run pipeline" button can only be rendered when:
* - In MR view - we use `canCreatePipelineInTargetProject` for that purpose * - In MR view - we use `canCreatePipelineInTargetProject` for that purpose
* - If the latest pipeline has the `detached_merge_request_pipeline` flag * - If the latest pipeline has the `detached_merge_request_pipeline` flag
* *
...@@ -148,7 +148,7 @@ export default { ...@@ -148,7 +148,7 @@ export default {
} }
}, },
/** /**
* When the user clicks on the Run Pipeline button * When the user clicks on the "Run pipeline" button
* we need to make a post request and * we need to make a post request and
* to update the table content once the request is finished. * to update the table content once the request is finished.
* *
...@@ -177,7 +177,7 @@ export default { ...@@ -177,7 +177,7 @@ export default {
<div class="content-list pipelines"> <div class="content-list pipelines">
<gl-loading-icon <gl-loading-icon
v-if="isLoading" v-if="isLoading"
:label="s__('Pipelines|Loading Pipelines')" :label="s__('Pipelines|Loading pipelines')"
size="lg" size="lg"
class="prepend-top-20" class="prepend-top-20"
/> />
...@@ -197,12 +197,12 @@ export default { ...@@ -197,12 +197,12 @@ export default {
block block
class="gl-mt-3 gl-mb-3" class="gl-mt-3 gl-mb-3"
:class="pipelineButtonClass" :class="pipelineButtonClass"
variant="success" variant="confirm"
data-testid="run_pipeline_button_mobile" data-testid="run_pipeline_button_mobile"
:loading="state.isRunningMergeRequestPipeline" :loading="state.isRunningMergeRequestPipeline"
@click="tryRunPipeline" @click="tryRunPipeline"
> >
{{ s__('Pipelines|Run Pipeline') }} {{ s__('Pipeline|Run pipeline') }}
</gl-button> </gl-button>
<pipelines-table-component <pipelines-table-component
...@@ -213,12 +213,12 @@ export default { ...@@ -213,12 +213,12 @@ export default {
<template #table-header-actions> <template #table-header-actions>
<div v-if="canRenderPipelineButton" class="gl-text-right"> <div v-if="canRenderPipelineButton" class="gl-text-right">
<gl-button <gl-button
variant="success" variant="confirm"
data-testid="run_pipeline_button" data-testid="run_pipeline_button"
:loading="state.isRunningMergeRequestPipeline" :loading="state.isRunningMergeRequestPipeline"
@click="tryRunPipeline" @click="tryRunPipeline"
> >
{{ s__('Pipelines|Run Pipeline') }} {{ s__('Pipeline|Run pipeline') }}
</gl-button> </gl-button>
</div> </div>
</template> </template>
...@@ -231,7 +231,7 @@ export default { ...@@ -231,7 +231,7 @@ export default {
ref="modal" ref="modal"
:modal-id="modalId" :modal-id="modalId"
:title="s__('Pipelines|Are you sure you want to run this pipeline?')" :title="s__('Pipelines|Are you sure you want to run this pipeline?')"
:ok-title="s__('Pipelines|Run Pipeline')" :ok-title="s__('Pipeline|Run pipeline')"
ok-variant="danger" ok-variant="danger"
@ok="onClickRunPipeline" @ok="onClickRunPipeline"
> >
......
...@@ -444,18 +444,16 @@ export default { ...@@ -444,18 +444,16 @@ export default {
</gl-sprintf></template </gl-sprintf></template
> >
</gl-form-group> </gl-form-group>
<div <div class="gl-pt-5 gl-display-flex">
class="gl-border-t-solid gl-border-gray-100 gl-border-t-1 gl-p-5 gl-bg-gray-10 gl-display-flex gl-justify-content-space-between"
>
<gl-button <gl-button
type="submit" type="submit"
category="primary" category="primary"
variant="confirm" variant="confirm"
class="js-no-auto-disable" class="js-no-auto-disable gl-mr-3"
data-qa-selector="run_pipeline_button" data-qa-selector="run_pipeline_button"
data-testid="run_pipeline_button" data-testid="run_pipeline_button"
:disabled="submitted" :disabled="submitted"
>{{ s__('Pipeline|Run Pipeline') }}</gl-button >{{ s__('Pipeline|Run pipeline') }}</gl-button
> >
<gl-button :href="pipelinesPath">{{ __('Cancel') }}</gl-button> <gl-button :href="pipelinesPath">{{ __('Cancel') }}</gl-button>
</div> </div>
......
...@@ -40,18 +40,6 @@ export default { ...@@ -40,18 +40,6 @@ export default {
</script> </script>
<template> <template>
<div class="nav-controls"> <div class="nav-controls">
<gl-button
v-if="newPipelinePath"
:href="newPipelinePath"
variant="success"
category="primary"
class="js-run-pipeline"
data-testid="run-pipeline-button"
data-qa-selector="run_pipeline_button"
>
{{ s__('Pipelines|Run Pipeline') }}
</gl-button>
<gl-button <gl-button
v-if="resetCachePath" v-if="resetCachePath"
:loading="isResetCacheButtonLoading" :loading="isResetCacheButtonLoading"
...@@ -59,11 +47,23 @@ export default { ...@@ -59,11 +47,23 @@ export default {
data-testid="clear-cache-button" data-testid="clear-cache-button"
@click="onClickResetCache" @click="onClickResetCache"
> >
{{ s__('Pipelines|Clear Runner Caches') }} {{ s__('Pipelines|Clear runner caches') }}
</gl-button> </gl-button>
<gl-button v-if="ciLintPath" :href="ciLintPath" class="js-ci-lint" data-testid="ci-lint-button"> <gl-button v-if="ciLintPath" :href="ciLintPath" class="js-ci-lint" data-testid="ci-lint-button">
{{ s__('Pipelines|CI Lint') }} {{ s__('Pipelines|CI lint') }}
</gl-button>
<gl-button
v-if="newPipelinePath"
:href="newPipelinePath"
variant="confirm"
category="primary"
class="js-run-pipeline"
data-testid="run-pipeline-button"
data-qa-selector="run_pipeline_button"
>
{{ s__('Pipeline|Run pipeline') }}
</gl-button> </gl-button>
</div> </div>
</template> </template>
- breadcrumb_title _('Pipelines') - breadcrumb_title _('Pipelines')
- page_title s_('Pipeline|Run Pipeline') - page_title s_('Pipeline|Run pipeline')
- settings_link = link_to _('CI/CD settings'), project_settings_ci_cd_path(@project) - settings_link = link_to _('CI/CD settings'), project_settings_ci_cd_path(@project)
%h3.page-title %h3.page-title
= s_('Pipeline|Run Pipeline') = s_('Pipeline|Run pipeline')
%hr %hr
- if Feature.enabled?(:new_pipeline_form, @project, default_enabled: :yaml) - if Feature.enabled?(:new_pipeline_form, @project, default_enabled: :yaml)
...@@ -49,7 +49,7 @@ ...@@ -49,7 +49,7 @@
= (s_("Pipeline|Specify variable values to be used in this run. The values specified in %{settings_link} will be used by default.") % {settings_link: settings_link}).html_safe = (s_("Pipeline|Specify variable values to be used in this run. The values specified in %{settings_link} will be used by default.") % {settings_link: settings_link}).html_safe
.form-actions .form-actions
= f.submit s_('Pipeline|Run Pipeline'), class: 'btn btn-success js-variables-save-button' = f.submit s_('Pipeline|Run pipeline'), class: 'btn gl-button btn-confirm gl-mr-3 js-variables-save-button'
= link_to _('Cancel'), project_pipelines_path(@project), class: 'btn btn-default float-right' = link_to _('Cancel'), project_pipelines_path(@project), class: 'btn gl-button btn-default'
%script#availableRefs{ type: "application/json" }= @project.repository.ref_names.to_json.html_safe %script#availableRefs{ type: "application/json" }= @project.repository.ref_names.to_json.html_safe
---
title: Updating success button to confirm variant and reordering buttons per Pajamas
Design System guidelines for buttons
merge_request: 58112
author:
type: other
...@@ -197,7 +197,7 @@ could mistakenly trust the merge request because it passed a faked pipeline. ...@@ -197,7 +197,7 @@ could mistakenly trust the merge request because it passed a faked pipeline.
Parent project members with at least [Developer permissions](../../user/permissions.md) Parent project members with at least [Developer permissions](../../user/permissions.md)
can create pipelines in the parent project for merge requests can create pipelines in the parent project for merge requests
from a forked project. In the merge request, go to the **Pipelines** and click from a forked project. In the merge request, go to the **Pipelines** and click
**Run Pipeline** button. **Run pipeline** button.
WARNING: WARNING:
Fork merge requests could contain malicious code that tries to steal secrets in the Fork merge requests could contain malicious code that tries to steal secrets in the
......
...@@ -133,8 +133,8 @@ operation of the pipeline. ...@@ -133,8 +133,8 @@ operation of the pipeline.
To execute a pipeline manually: To execute a pipeline manually:
1. Navigate to your project's **CI/CD > Pipelines**. 1. Navigate to your project's **CI/CD > Pipelines**.
1. Select the **Run Pipeline** button. 1. Select the **Run pipeline** button.
1. On the **Run Pipeline** page: 1. On the **Run pipeline** page:
1. Select the branch or tag to run the pipeline for in the **Run for branch name or tag** field. 1. Select the branch or tag to run the pipeline for in the **Run for branch name or tag** field.
1. Enter any [environment variables](../variables/README.md) required for the pipeline run. 1. Enter any [environment variables](../variables/README.md) required for the pipeline run.
You can set specific variables to have their [values prefilled in the form](#prefill-variables-in-manual-pipelines). You can set specific variables to have their [values prefilled in the form](#prefill-variables-in-manual-pipelines).
......
...@@ -23,7 +23,7 @@ On the left side we have the events that can trigger a pipeline based on various ...@@ -23,7 +23,7 @@ On the left side we have the events that can trigger a pipeline based on various
- A `git push` is the most common event that triggers a pipeline. - A `git push` is the most common event that triggers a pipeline.
- The [Web API](../../api/pipelines.md#create-a-new-pipeline). - The [Web API](../../api/pipelines.md#create-a-new-pipeline).
- A user clicking the "Run Pipeline" button in the UI. - A user clicking the "Run pipeline" button in the UI.
- When a [merge request is created or updated](../../ci/merge_request_pipelines/index.md#pipelines-for-merge-requests). - When a [merge request is created or updated](../../ci/merge_request_pipelines/index.md#pipelines-for-merge-requests).
- When an MR is added to a [Merge Train](../../ci/merge_request_pipelines/pipelines_for_merged_results/merge_trains/index.md#merge-trains). - When an MR is added to a [Merge Train](../../ci/merge_request_pipelines/pipelines_for_merged_results/merge_trains/index.md#merge-trains).
- A [scheduled pipeline](../../ci/pipelines/schedules.md#pipeline-schedules). - A [scheduled pipeline](../../ci/pipelines/schedules.md#pipeline-schedules).
......
...@@ -418,7 +418,7 @@ If the MR source branch is more than 100 commits behind the target branch, ask t ...@@ -418,7 +418,7 @@ If the MR source branch is more than 100 commits behind the target branch, ask t
Review links and images, especially in documentation MRs. Review links and images, especially in documentation MRs.
When in doubt, ask someone from `@gitlab-com/gl-security/appsec` to review the merge request **before starting any merge request pipeline**. When in doubt, ask someone from `@gitlab-com/gl-security/appsec` to review the merge request **before starting any merge request pipeline**.
- Start a new merge request pipeline with the `Run Pipeline` button in the merge - Start a new merge request pipeline with the `Run pipeline` button in the merge
request's "Pipelines" tab, and enable "Merge When Pipeline Succeeds" (MWPS). request's "Pipelines" tab, and enable "Merge When Pipeline Succeeds" (MWPS).
Note that: Note that:
- If **[master is broken](https://about.gitlab.com/handbook/engineering/workflow/#broken-master), - If **[master is broken](https://about.gitlab.com/handbook/engineering/workflow/#broken-master),
......
...@@ -119,7 +119,7 @@ pipeline in the main `gitlab` repository as well as in `gitlab-docs`. Create an ...@@ -119,7 +119,7 @@ pipeline in the main `gitlab` repository as well as in `gitlab-docs`. Create an
a different name first and test it to ensure you do not break the pipelines. a different name first and test it to ensure you do not break the pipelines.
1. In [`gitlab-docs`](https://gitlab.com/gitlab-org/gitlab-docs), go to **{rocket}** **CI/CD > Pipelines**. 1. In [`gitlab-docs`](https://gitlab.com/gitlab-org/gitlab-docs), go to **{rocket}** **CI/CD > Pipelines**.
1. Click the **Run Pipeline** button. 1. Click the **Run pipeline** button.
1. See that a new pipeline is running. The jobs that build the images are in the first 1. See that a new pipeline is running. The jobs that build the images are in the first
stage, `build-images`. You can click the pipeline number to see the larger pipeline stage, `build-images`. You can click the pipeline number to see the larger pipeline
graph, or click the first (`build-images`) stage in the mini pipeline graph to graph, or click the first (`build-images`) stage in the mini pipeline graph to
......
...@@ -732,7 +732,7 @@ To use Auto Monitoring: ...@@ -732,7 +732,7 @@ To use Auto Monitoring:
1. [Install and configure the Auto DevOps requirements](requirements.md). 1. [Install and configure the Auto DevOps requirements](requirements.md).
1. [Enable Auto DevOps](index.md#enable-or-disable-auto-devops), if you haven't done already. 1. [Enable Auto DevOps](index.md#enable-or-disable-auto-devops), if you haven't done already.
1. Navigate to your project's **{rocket}** **CI/CD > Pipelines** and click **Run Pipeline**. 1. Navigate to your project's **{rocket}** **CI/CD > Pipelines** and click **Run pipeline**.
1. After the pipeline finishes successfully, open the 1. After the pipeline finishes successfully, open the
[monitoring dashboard for a deployed environment](../../ci/environments/index.md#monitoring-environments) [monitoring dashboard for a deployed environment](../../ci/environments/index.md#monitoring-environments)
to view the metrics of your deployed application. To view the metrics of the to view the metrics of your deployed application. To view the metrics of the
......
...@@ -246,7 +246,7 @@ This can be done: ...@@ -246,7 +246,7 @@ This can be done:
- For a single pipeline run: - For a single pipeline run:
1. Go to **CI/CD > Pipelines** 1. Go to **CI/CD > Pipelines**
1. Click **Run Pipeline** 1. Click **Run pipeline**
1. Add `CODE_QUALITY_DISABLED` as the variable key, with any value. 1. Add `CODE_QUALITY_DISABLED` as the variable key, with any value.
### Using with merge request pipelines ### Using with merge request pipelines
......
...@@ -22899,13 +22899,13 @@ msgstr "" ...@@ -22899,13 +22899,13 @@ msgstr ""
msgid "Pipelines|By revoking a trigger you will break any processes making use of it. Are you sure?" msgid "Pipelines|By revoking a trigger you will break any processes making use of it. Are you sure?"
msgstr "" msgstr ""
msgid "Pipelines|CI Lint" msgid "Pipelines|CI lint"
msgstr "" msgstr ""
msgid "Pipelines|Child pipeline" msgid "Pipelines|Child pipeline"
msgstr "" msgstr ""
msgid "Pipelines|Clear Runner Caches" msgid "Pipelines|Clear runner caches"
msgstr "" msgstr ""
msgid "Pipelines|Continuous deployment template to test and deploy your %{name} project." msgid "Pipelines|Continuous deployment template to test and deploy your %{name} project."
...@@ -22953,6 +22953,9 @@ msgstr "" ...@@ -22953,6 +22953,9 @@ msgstr ""
msgid "Pipelines|Loading Pipelines" msgid "Pipelines|Loading Pipelines"
msgstr "" msgstr ""
msgid "Pipelines|Loading pipelines"
msgstr ""
msgid "Pipelines|Merged YAML is view only" msgid "Pipelines|Merged YAML is view only"
msgstr "" msgstr ""
...@@ -22974,9 +22977,6 @@ msgstr "" ...@@ -22974,9 +22977,6 @@ msgstr ""
msgid "Pipelines|Revoke" msgid "Pipelines|Revoke"
msgstr "" msgstr ""
msgid "Pipelines|Run Pipeline"
msgstr ""
msgid "Pipelines|Something went wrong while cleaning runners cache." msgid "Pipelines|Something went wrong while cleaning runners cache."
msgstr "" msgstr ""
...@@ -23130,15 +23130,15 @@ msgstr "" ...@@ -23130,15 +23130,15 @@ msgstr ""
msgid "Pipeline|Raw text search is not currently supported. Please use the available search tokens." msgid "Pipeline|Raw text search is not currently supported. Please use the available search tokens."
msgstr "" msgstr ""
msgid "Pipeline|Run Pipeline"
msgstr ""
msgid "Pipeline|Run for" msgid "Pipeline|Run for"
msgstr "" msgstr ""
msgid "Pipeline|Run for branch name or tag" msgid "Pipeline|Run for branch name or tag"
msgstr "" msgstr ""
msgid "Pipeline|Run pipeline"
msgstr ""
msgid "Pipeline|Running" msgid "Pipeline|Running"
msgstr "" msgstr ""
......
...@@ -41,7 +41,7 @@ RSpec.describe 'Merge request > User sees pipelines', :js do ...@@ -41,7 +41,7 @@ RSpec.describe 'Merge request > User sees pipelines', :js do
context 'with a detached merge request pipeline' do context 'with a detached merge request pipeline' do
let(:merge_request) { create(:merge_request, :with_detached_merge_request_pipeline) } let(:merge_request) { create(:merge_request, :with_detached_merge_request_pipeline) }
it 'displays the Run Pipeline button' do it 'displays the "Run pipeline" button' do
visit project_merge_request_path(project, merge_request) visit project_merge_request_path(project, merge_request)
page.within('.merge-request-tabs') do page.within('.merge-request-tabs') do
...@@ -50,14 +50,14 @@ RSpec.describe 'Merge request > User sees pipelines', :js do ...@@ -50,14 +50,14 @@ RSpec.describe 'Merge request > User sees pipelines', :js do
wait_for_requests wait_for_requests
expect(page.find('[data-testid="run_pipeline_button"]')).to have_text('Run Pipeline') expect(page.find('[data-testid="run_pipeline_button"]')).to have_text('Run pipeline')
end end
end end
context 'with a merged results pipeline' do context 'with a merged results pipeline' do
let(:merge_request) { create(:merge_request, :with_merge_request_pipeline) } let(:merge_request) { create(:merge_request, :with_merge_request_pipeline) }
it 'displays the Run Pipeline button' do it 'displays the "Run pipeline" button' do
visit project_merge_request_path(project, merge_request) visit project_merge_request_path(project, merge_request)
page.within('.merge-request-tabs') do page.within('.merge-request-tabs') do
...@@ -66,7 +66,7 @@ RSpec.describe 'Merge request > User sees pipelines', :js do ...@@ -66,7 +66,7 @@ RSpec.describe 'Merge request > User sees pipelines', :js do
wait_for_requests wait_for_requests
expect(page.find('[data-testid="run_pipeline_button"]')).to have_text('Run Pipeline') expect(page.find('[data-testid="run_pipeline_button"]')).to have_text('Run pipeline')
end end
end end
end end
...@@ -131,7 +131,7 @@ RSpec.describe 'Merge request > User sees pipelines', :js do ...@@ -131,7 +131,7 @@ RSpec.describe 'Merge request > User sees pipelines', :js do
visit project_merge_request_path(parent_project, merge_request) visit project_merge_request_path(parent_project, merge_request)
create_merge_request_pipeline create_merge_request_pipeline
act_on_security_warning(action: 'Run Pipeline') act_on_security_warning(action: 'Run pipeline')
check_pipeline(expected_project: parent_project) check_pipeline(expected_project: parent_project)
check_head_pipeline(expected_project: parent_project) check_head_pipeline(expected_project: parent_project)
...@@ -175,7 +175,7 @@ RSpec.describe 'Merge request > User sees pipelines', :js do ...@@ -175,7 +175,7 @@ RSpec.describe 'Merge request > User sees pipelines', :js do
def create_merge_request_pipeline def create_merge_request_pipeline
page.within('.merge-request-tabs') { click_link('Pipelines') } page.within('.merge-request-tabs') { click_link('Pipelines') }
click_button('Run Pipeline') click_button('Run pipeline')
end end
def check_pipeline(expected_project:) def check_pipeline(expected_project:)
......
...@@ -93,12 +93,12 @@ RSpec.describe 'Pipelines', :js do ...@@ -93,12 +93,12 @@ RSpec.describe 'Pipelines', :js do
wait_for_requests wait_for_requests
end end
it 'renders run pipeline link' do it 'renders "CI lint" link' do
expect(page).to have_link('Run Pipeline') expect(page).to have_link('CI lint')
end end
it 'renders ci lint link' do it 'renders "Run pipeline" link' do
expect(page).to have_link('CI Lint') expect(page).to have_link('Run pipeline')
end end
end end
...@@ -676,7 +676,7 @@ RSpec.describe 'Pipelines', :js do ...@@ -676,7 +676,7 @@ RSpec.describe 'Pipelines', :js do
end end
it 'creates a new pipeline' do it 'creates a new pipeline' do
expect { click_on 'Run Pipeline' } expect { click_on 'Run pipeline' }
.to change { Ci::Pipeline.count }.by(1) .to change { Ci::Pipeline.count }.by(1)
expect(Ci::Pipeline.last).to be_web expect(Ci::Pipeline.last).to be_web
...@@ -689,7 +689,7 @@ RSpec.describe 'Pipelines', :js do ...@@ -689,7 +689,7 @@ RSpec.describe 'Pipelines', :js do
fill_in "Input variable value", with: "value" fill_in "Input variable value", with: "value"
end end
expect { click_on 'Run Pipeline' } expect { click_on 'Run pipeline' }
.to change { Ci::Pipeline.count }.by(1) .to change { Ci::Pipeline.count }.by(1)
expect(Ci::Pipeline.last.variables.map { |var| var.slice(:key, :secret_value) }) expect(Ci::Pipeline.last.variables.map { |var| var.slice(:key, :secret_value) })
...@@ -700,7 +700,7 @@ RSpec.describe 'Pipelines', :js do ...@@ -700,7 +700,7 @@ RSpec.describe 'Pipelines', :js do
context 'without gitlab-ci.yml' do context 'without gitlab-ci.yml' do
before do before do
click_on 'Run Pipeline' click_on 'Run pipeline'
end end
it { expect(page).to have_content('Missing CI config file') } it { expect(page).to have_content('Missing CI config file') }
...@@ -713,44 +713,13 @@ RSpec.describe 'Pipelines', :js do ...@@ -713,44 +713,13 @@ RSpec.describe 'Pipelines', :js do
click_link 'master' click_link 'master'
end end
expect { click_on 'Run Pipeline' } expect { click_on 'Run pipeline' }
.to change { Ci::Pipeline.count }.by(1) .to change { Ci::Pipeline.count }.by(1)
end end
end end
end end
end end
describe 'Run Pipelines' do
let(:project) { create(:project, :repository) }
before do
stub_feature_flags(new_pipeline_form: false)
visit new_project_pipeline_path(project)
end
describe 'new pipeline page' do
it 'has field to add a new pipeline' do
expect(page).to have_selector('.js-branch-select')
expect(find('.js-branch-select')).to have_content project.default_branch
expect(page).to have_content('Run for')
end
end
describe 'find pipelines' do
it 'shows filtered pipelines', :js do
click_button project.default_branch
page.within '.dropdown-menu' do
find('.dropdown-input-field').native.send_keys('fix')
page.within '.dropdown-content' do
expect(page).to have_content('fix')
end
end
end
end
end
describe 'Reset runner caches' do describe 'Reset runner caches' do
let(:project) { create(:project, :repository) } let(:project) { create(:project, :repository) }
...@@ -761,7 +730,7 @@ RSpec.describe 'Pipelines', :js do ...@@ -761,7 +730,7 @@ RSpec.describe 'Pipelines', :js do
end end
it 'has a clear caches button' do it 'has a clear caches button' do
expect(page).to have_button 'Clear Runner Caches' expect(page).to have_button 'Clear runner caches'
end end
describe 'user clicks the button' do describe 'user clicks the button' do
...@@ -771,7 +740,7 @@ RSpec.describe 'Pipelines', :js do ...@@ -771,7 +740,7 @@ RSpec.describe 'Pipelines', :js do
end end
it 'increments jobs_cache_index' do it 'increments jobs_cache_index' do
click_button 'Clear Runner Caches' click_button 'Clear runner caches'
wait_for_requests wait_for_requests
expect(page.find('.flash-notice')).to have_content 'Project cache successfully reset.' expect(page.find('.flash-notice')).to have_content 'Project cache successfully reset.'
end end
...@@ -779,7 +748,7 @@ RSpec.describe 'Pipelines', :js do ...@@ -779,7 +748,7 @@ RSpec.describe 'Pipelines', :js do
context 'when project does not have jobs_cache_index' do context 'when project does not have jobs_cache_index' do
it 'sets jobs_cache_index to 1' do it 'sets jobs_cache_index to 1' do
click_button 'Clear Runner Caches' click_button 'Clear runner caches'
wait_for_requests wait_for_requests
expect(page.find('.flash-notice')).to have_content 'Project cache successfully reset.' expect(page.find('.flash-notice')).to have_content 'Project cache successfully reset.'
end end
...@@ -787,6 +756,37 @@ RSpec.describe 'Pipelines', :js do ...@@ -787,6 +756,37 @@ RSpec.describe 'Pipelines', :js do
end end
end end
describe 'Run Pipelines' do
let(:project) { create(:project, :repository) }
before do
stub_feature_flags(new_pipeline_form: false)
visit new_project_pipeline_path(project)
end
describe 'new pipeline page' do
it 'has field to add a new pipeline' do
expect(page).to have_selector('.js-branch-select')
expect(find('.js-branch-select')).to have_content project.default_branch
expect(page).to have_content('Run for')
end
end
describe 'find pipelines' do
it 'shows filtered pipelines', :js do
click_button project.default_branch
page.within '.dropdown-menu' do
find('.dropdown-input-field').native.send_keys('fix')
page.within '.dropdown-content' do
expect(page).to have_content('fix')
end
end
end
end
end
describe 'Empty State' do describe 'Empty State' do
let(:project) { create(:project, :repository) } let(:project) { create(:project, :repository) }
......
...@@ -29,7 +29,7 @@ describe('Pipelines Nav Controls', () => { ...@@ -29,7 +29,7 @@ describe('Pipelines Nav Controls', () => {
createComponent(mockData); createComponent(mockData);
const runPipeline = findRunPipeline(); const runPipeline = findRunPipeline();
expect(runPipeline.text()).toContain('Run Pipeline'); expect(runPipeline.text()).toContain('Run pipeline');
expect(runPipeline.attributes('href')).toBe(mockData.newPipelinePath); expect(runPipeline.attributes('href')).toBe(mockData.newPipelinePath);
}); });
...@@ -55,7 +55,7 @@ describe('Pipelines Nav Controls', () => { ...@@ -55,7 +55,7 @@ describe('Pipelines Nav Controls', () => {
createComponent(mockData); createComponent(mockData);
expect(wrapper.find('.js-ci-lint').text().trim()).toContain('CI Lint'); expect(wrapper.find('.js-ci-lint').text().trim()).toContain('CI lint');
expect(wrapper.find('.js-ci-lint').attributes('href')).toBe(mockData.ciLintPath); expect(wrapper.find('.js-ci-lint').attributes('href')).toBe(mockData.ciLintPath);
}); });
...@@ -70,7 +70,7 @@ describe('Pipelines Nav Controls', () => { ...@@ -70,7 +70,7 @@ describe('Pipelines Nav Controls', () => {
}); });
it('should render button for resetting runner caches', () => { it('should render button for resetting runner caches', () => {
expect(wrapper.find('.js-clear-cache').text().trim()).toContain('Clear Runner Caches'); expect(wrapper.find('.js-clear-cache').text().trim()).toContain('Clear runner caches');
}); });
it('should emit postAction event when reset runner cache button is clicked', async () => { it('should emit postAction event when reset runner cache button is clicked', async () => {
......
...@@ -191,16 +191,16 @@ describe('Pipelines', () => { ...@@ -191,16 +191,16 @@ describe('Pipelines', () => {
expect(findNavigationControls().exists()).toBe(true); expect(findNavigationControls().exists()).toBe(true);
}); });
it('renders Run Pipeline link', () => { it('renders Run pipeline link', () => {
expect(findRunPipelineButton().attributes('href')).toBe(paths.newPipelinePath); expect(findRunPipelineButton().attributes('href')).toBe(paths.newPipelinePath);
}); });
it('renders CI Lint link', () => { it('renders CI lint link', () => {
expect(findCiLintButton().attributes('href')).toBe(paths.ciLintPath); expect(findCiLintButton().attributes('href')).toBe(paths.ciLintPath);
}); });
it('renders Clear Runner Cache button', () => { it('renders Clear runner cache button', () => {
expect(findCleanCacheButton().text()).toBe('Clear Runner Caches'); expect(findCleanCacheButton().text()).toBe('Clear runner caches');
}); });
it('renders pipelines in a table', () => { it('renders pipelines in a table', () => {
...@@ -499,16 +499,16 @@ describe('Pipelines', () => { ...@@ -499,16 +499,16 @@ describe('Pipelines', () => {
expect(findTab('all').text()).toMatchInterpolatedText('All 0'); expect(findTab('all').text()).toMatchInterpolatedText('All 0');
}); });
it('renders Run Pipeline link', () => { it('renders Run pipeline link', () => {
expect(findRunPipelineButton().attributes('href')).toBe(paths.newPipelinePath); expect(findRunPipelineButton().attributes('href')).toBe(paths.newPipelinePath);
}); });
it('renders CI Lint link', () => { it('renders CI lint link', () => {
expect(findCiLintButton().attributes('href')).toBe(paths.ciLintPath); expect(findCiLintButton().attributes('href')).toBe(paths.ciLintPath);
}); });
it('renders Clear Runner Cache button', () => { it('renders Clear runner cache button', () => {
expect(findCleanCacheButton().text()).toBe('Clear Runner Caches'); expect(findCleanCacheButton().text()).toBe('Clear runner caches');
}); });
it('renders empty state', () => { it('renders empty state', () => {
...@@ -714,7 +714,7 @@ describe('Pipelines', () => { ...@@ -714,7 +714,7 @@ describe('Pipelines', () => {
expect(findRunPipelineButton().attributes('href')).toBe(paths.newPipelinePath); expect(findRunPipelineButton().attributes('href')).toBe(paths.newPipelinePath);
expect(findCiLintButton().attributes('href')).toBe(paths.ciLintPath); expect(findCiLintButton().attributes('href')).toBe(paths.ciLintPath);
expect(findCleanCacheButton().text()).toBe('Clear Runner Caches'); expect(findCleanCacheButton().text()).toBe('Clear runner caches');
}); });
it('shows error state', () => { it('shows error state', () => {
......
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