Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
f90b2a36
Commit
f90b2a36
authored
Nov 20, 2017
by
Eric Eastwood
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add checkboxes to automatically run AutoDevops pipeline
Fix
https://gitlab.com/gitlab-org/gitlab-ce/issues/38962
parent
a6558c91
Changes
12
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
187 additions
and
30 deletions
+187
-30
app/assets/javascripts/dispatcher.js
app/assets/javascripts/dispatcher.js
+7
-0
app/assets/javascripts/flash.js
app/assets/javascripts/flash.js
+1
-1
app/assets/javascripts/main.js
app/assets/javascripts/main.js
+3
-1
app/assets/javascripts/projects/ci_cd_settings_bundle.js
app/assets/javascripts/projects/ci_cd_settings_bundle.js
+19
-0
app/assets/stylesheets/framework/flash.scss
app/assets/stylesheets/framework/flash.scss
+10
-2
app/controllers/projects/pipelines_settings_controller.rb
app/controllers/projects/pipelines_settings_controller.rb
+1
-0
app/views/layouts/_flash.html.haml
app/views/layouts/_flash.html.haml
+4
-8
app/views/projects/pipelines_settings/_show.html.haml
app/views/projects/pipelines_settings/_show.html.haml
+18
-8
doc/topics/autodevops/img/auto_devops_settings.png
doc/topics/autodevops/img/auto_devops_settings.png
+0
-0
doc/topics/autodevops/index.md
doc/topics/autodevops/index.md
+5
-1
spec/features/projects/settings/pipelines_settings_spec.rb
spec/features/projects/settings/pipelines_settings_spec.rb
+118
-8
spec/javascripts/flash_spec.js
spec/javascripts/flash_spec.js
+1
-1
No files found.
app/assets/javascripts/dispatcher.js
View file @
f90b2a36
...
...
@@ -583,6 +583,13 @@ import initGroupAnalytics from './init_group_analytics';
case
'
projects:settings:ci_cd:show
'
:
// Initialize expandable settings panels
initSettingsPanels
();
import
(
/* webpackChunkName: "ci-cd-settings" */
'
./projects/ci_cd_settings_bundle
'
)
.
then
(
ciCdSettings
=>
ciCdSettings
.
default
())
.
catch
((
err
)
=>
{
Flash
(
s__
(
'
ProjectSettings|Problem setting up the CI/CD settings JavaScript
'
));
throw
err
;
});
case
'
groups:settings:ci_cd:show
'
:
new
ProjectVariables
();
break
;
...
...
app/assets/javascripts/flash.js
View file @
f90b2a36
...
...
@@ -41,7 +41,7 @@ const createFlashEl = (message, type, isInContentWrapper = false) => `
`
;
const
removeFlashClickListener
=
(
flashEl
,
fadeTransition
)
=>
{
flashEl
.
parentNode
.
addEventListener
(
'
click
'
,
()
=>
hideFlash
(
flashEl
,
fadeTransition
));
flashEl
.
addEventListener
(
'
click
'
,
()
=>
hideFlash
(
flashEl
,
fadeTransition
));
};
/*
...
...
app/assets/javascripts/main.js
View file @
f90b2a36
...
...
@@ -319,6 +319,8 @@ $(function () {
const
flashContainer
=
document
.
querySelector
(
'
.flash-container
'
);
if
(
flashContainer
&&
flashContainer
.
children
.
length
)
{
removeFlashClickListener
(
flashContainer
.
children
[
0
]);
flashContainer
.
querySelectorAll
(
'
.flash-alert, .flash-notice, .flash-success
'
).
forEach
((
flashEl
)
=>
{
removeFlashClickListener
(
flashEl
);
});
}
});
app/assets/javascripts/projects/ci_cd_settings_bundle.js
0 → 100644
View file @
f90b2a36
function
updateAutoDevopsRadios
(
radioWrappers
)
{
radioWrappers
.
forEach
((
radioWrapper
)
=>
{
const
radio
=
radioWrapper
.
querySelector
(
'
.js-auto-devops-enable-radio
'
);
const
runPipelineCheckboxWrapper
=
radioWrapper
.
querySelector
(
'
.js-run-auto-devops-pipeline-checkbox-wrapper
'
);
const
runPipelineCheckbox
=
radioWrapper
.
querySelector
(
'
.js-run-auto-devops-pipeline-checkbox
'
);
if
(
runPipelineCheckbox
)
{
runPipelineCheckbox
.
checked
=
radio
.
checked
;
runPipelineCheckboxWrapper
.
classList
.
toggle
(
'
hide
'
,
!
radio
.
checked
);
}
});
}
export
default
function
initCiCdSettings
()
{
const
radioWrappers
=
document
.
querySelectorAll
(
'
.js-auto-devops-enable-radio-wrapper
'
);
radioWrappers
.
forEach
(
radioWrapper
=>
radioWrapper
.
addEventListener
(
'
change
'
,
()
=>
updateAutoDevopsRadios
(
radioWrappers
)),
);
}
app/assets/stylesheets/framework/flash.scss
View file @
f90b2a36
...
...
@@ -34,8 +34,15 @@
}
}
.flash-success
{
@extend
.alert
;
@extend
.alert-success
;
margin
:
0
;
}
.flash-notice
,
.flash-alert
{
.flash-alert
,
.flash-success
{
border-radius
:
$border-radius-default
;
.container-fluid
,
...
...
@@ -48,7 +55,8 @@
margin-bottom
:
0
;
.flash-notice
,
.flash-alert
{
.flash-alert
,
.flash-success
{
border-radius
:
0
;
}
}
...
...
app/controllers/projects/pipelines_settings_controller.rb
View file @
f90b2a36
...
...
@@ -12,6 +12,7 @@ class Projects::PipelinesSettingsController < Projects::ApplicationController
if
service
.
run_auto_devops_pipeline?
CreatePipelineWorker
.
perform_async
(
project
.
id
,
current_user
.
id
,
project
.
default_branch
,
:web
,
ignore_skip_ci:
true
,
save_on_errors:
false
)
flash
[
:success
]
=
"A new Auto DevOps pipeline has been created, go to <a href=
\"
#{
project_pipelines_path
(
@project
)
}
\"
>Pipelines page</a> for details"
.
html_safe
end
redirect_to
project_settings_ci_cd_path
(
@project
)
...
...
app/views/layouts/_flash.html.haml
View file @
f90b2a36
.flash-container.flash-container-page
-
if
alert
.flash-alert
-# We currently only support `alert`, `notice`, `success`
-
flash
.
each
do
|
key
,
value
|
%div
{
class:
"flash-#{key}"
}
%div
{
class:
(
container_class
)
}
%span
=
alert
-
elsif
notice
.flash-notice
%div
{
class:
(
container_class
)
}
%span
=
notice
%span
=
value
app/views/projects/pipelines_settings/_show.html.haml
View file @
f90b2a36
...
...
@@ -13,29 +13,39 @@
%p
.settings-message.text-center
=
message
.
html_safe
=
f
.
fields_for
:auto_devops_attributes
,
@auto_devops
do
|
form
|
.radio
.radio
.js-auto-devops-enable-radio-wrapper
=
form
.
label
:enabled_true
do
=
form
.
radio_button
:enabled
,
'true'
=
form
.
radio_button
:enabled
,
'true'
,
class:
'js-auto-devops-enable-radio'
%strong
Enable Auto DevOps
%br
%span
.descr
The Auto DevOps pipeline configuration will be used when there is no
<code>
.gitlab-ci.yml
</code>
in the project.
.radio
-
if
show_run_auto_devops_pipeline_checkbox_for_explicit_setting?
(
@project
)
.checkbox.hide.js-run-auto-devops-pipeline-checkbox-wrapper
=
label_tag
'project[run_auto_devops_pipeline_explicit]'
do
=
check_box_tag
'project[run_auto_devops_pipeline_explicit]'
,
true
,
false
,
class:
'js-run-auto-devops-pipeline-checkbox'
=
s_
(
'ProjectSettings|Immediately run a pipeline on the default branch'
)
.radio.js-auto-devops-enable-radio-wrapper
=
form
.
label
:enabled_false
do
=
form
.
radio_button
:enabled
,
'false'
=
form
.
radio_button
:enabled
,
'false'
,
class:
'js-auto-devops-enable-radio'
%strong
Disable Auto DevOps
%br
%span
.descr
An explicit
<code>
.gitlab-ci.yml
</code>
needs to be specified before you can begin using Continuous Integration and Delivery.
.radio
=
form
.
label
:enabled_
nil
do
=
form
.
radio_button
:enabled
,
''
.radio
.js-auto-devops-enable-radio-wrapper
=
form
.
label
:enabled_
do
=
form
.
radio_button
:enabled
,
''
,
class:
'js-auto-devops-enable-radio'
%strong
Instance default (
#{
current_application_settings
.
auto_devops_enabled?
?
'enabled'
:
'disabled'
}
)
%br
%span
.descr
Follow the instance default to either have Auto DevOps enabled or disabled when there is no project specific
<code>
.gitlab-ci.yml
</code>
.
%br
-
if
show_run_auto_devops_pipeline_checkbox_for_instance_setting?
(
@project
)
.checkbox.hide.js-run-auto-devops-pipeline-checkbox-wrapper
=
label_tag
'project[run_auto_devops_pipeline_implicit]'
do
=
check_box_tag
'project[run_auto_devops_pipeline_implicit]'
,
true
,
false
,
class:
'js-run-auto-devops-pipeline-checkbox'
=
s_
(
'ProjectSettings|Immediately run a pipeline on the default branch'
)
%p
You need to specify a domain if you want to use Auto Review Apps and Auto Deploy stages.
=
form
.
text_field
:domain
,
class:
'form-control'
,
placeholder:
'domain.com'
...
...
doc/topics/autodevops/img/auto_devops_settings.png
0 → 100644
View file @
f90b2a36
66.3 KB
doc/topics/autodevops/index.md
View file @
f90b2a36
...
...
@@ -121,7 +121,7 @@ Google Cloud.
## Enabling Auto DevOps
NOTE:
**Note:**
**Note:**
If you haven't done already, read the
[
prerequisites
](
#prerequisites
)
to make
full use of Auto DevOps. If this is your fist time, we recommend you follow the
[
quick start guide
](
#quick-start
)
.
...
...
@@ -129,10 +129,14 @@ full use of Auto DevOps. If this is your fist time, we recommend you follow the
1.
Go to your project's
**Settings > CI/CD > General pipelines settings**
and
find the Auto DevOps section
1.
Select "Enable Auto DevOps"
1.
After selecting an option to enable Auto DevOps, a checkbox will appear below
so you can immediately run a pipeline on the default branch
1.
Optionally, but recommended, add in the
[
base domain
](
#auto-devops-base-domain
)
that will be used by Kubernetes to deploy your application
1.
Hit
**Save changes**
for the changes to take effect
![
Project AutoDevops settings section
](
img/auto_devops_settings.png
)
Now that it's enabled, there are a few more steps depending on whether your project
has a
`.gitlab-ci.yml`
or not:
...
...
spec/features/projects/settings/pipelines_settings_spec.rb
View file @
f90b2a36
...
...
@@ -8,13 +8,14 @@ feature "Pipelines settings" do
background
do
sign_in
(
user
)
project
.
team
<<
[
user
,
role
]
visit
project_pipelines_settings_path
(
project
)
end
context
'for developer'
do
given
(
:role
)
{
:developer
}
scenario
'to be disallowed to view'
do
visit
project_settings_ci_cd_path
(
project
)
expect
(
page
.
status_code
).
to
eq
(
404
)
end
end
...
...
@@ -23,6 +24,8 @@ feature "Pipelines settings" do
given
(
:role
)
{
:master
}
scenario
'be allowed to change'
do
visit
project_settings_ci_cd_path
(
project
)
fill_in
(
'Test coverage parsing'
,
with:
'coverage_regex'
)
click_on
'Save changes'
...
...
@@ -32,6 +35,8 @@ feature "Pipelines settings" do
end
scenario
'updates auto_cancel_pending_pipelines'
do
visit
project_settings_ci_cd_path
(
project
)
page
.
check
(
'Auto-cancel redundant, pending pipelines'
)
click_on
'Save changes'
...
...
@@ -42,7 +47,10 @@ feature "Pipelines settings" do
expect
(
checkbox
).
to
be_checked
end
scenario
'update auto devops settings'
do
describe
'Auto DevOps'
do
it
'update auto devops settings'
do
visit
project_settings_ci_cd_path
(
project
)
fill_in
(
'project_auto_devops_attributes_domain'
,
with:
'test.com'
)
page
.
choose
(
'project_auto_devops_attributes_enabled_false'
)
click_on
'Save changes'
...
...
@@ -51,5 +59,107 @@ feature "Pipelines settings" do
expect
(
project
.
auto_devops
).
to
be_present
expect
(
project
.
auto_devops
).
not_to
be_enabled
end
describe
'Immediately run pipeline checkbox option'
,
:js
do
context
'when auto devops is set to instance default (enabled)'
do
before
do
stub_application_setting
(
auto_devops_enabled:
true
)
project
.
create_auto_devops!
(
enabled:
nil
)
visit
project_settings_ci_cd_path
(
project
)
end
it
'does not show checkboxes on page-load'
do
expect
(
page
).
to
have_selector
(
'.js-run-auto-devops-pipeline-checkbox-wrapper.hide'
,
count:
1
,
visible:
false
)
end
it
'selecting explicit disabled hides all checkboxes'
do
page
.
choose
(
'project_auto_devops_attributes_enabled_false'
)
expect
(
page
).
to
have_selector
(
'.js-run-auto-devops-pipeline-checkbox-wrapper.hide'
,
count:
1
,
visible:
false
)
end
it
'selecting explicit enabled hides all checkboxes because we are already enabled'
do
page
.
choose
(
'project_auto_devops_attributes_enabled_true'
)
expect
(
page
).
to
have_selector
(
'.js-run-auto-devops-pipeline-checkbox-wrapper.hide'
,
count:
1
,
visible:
false
)
end
end
context
'when auto devops is set to instance default (disabled)'
do
before
do
stub_application_setting
(
auto_devops_enabled:
false
)
project
.
create_auto_devops!
(
enabled:
nil
)
visit
project_settings_ci_cd_path
(
project
)
end
it
'does not show checkboxes on page-load'
do
expect
(
page
).
to
have_selector
(
'.js-run-auto-devops-pipeline-checkbox-wrapper.hide'
,
count:
1
,
visible:
false
)
end
it
'selecting explicit disabled hides all checkboxes'
do
page
.
choose
(
'project_auto_devops_attributes_enabled_false'
)
expect
(
page
).
to
have_selector
(
'.js-run-auto-devops-pipeline-checkbox-wrapper.hide'
,
count:
1
,
visible:
false
)
end
it
'selecting explicit enabled shows a checkbox'
do
page
.
choose
(
'project_auto_devops_attributes_enabled_true'
)
expect
(
page
).
to
have_selector
(
'.js-run-auto-devops-pipeline-checkbox-wrapper:not(.hide)'
,
count:
1
)
end
end
context
'when auto devops is set to explicit disabled'
do
before
do
stub_application_setting
(
auto_devops_enabled:
true
)
project
.
create_auto_devops!
(
enabled:
false
)
visit
project_settings_ci_cd_path
(
project
)
end
it
'does not show checkboxes on page-load'
do
expect
(
page
).
to
have_selector
(
'.js-run-auto-devops-pipeline-checkbox-wrapper.hide'
,
count:
2
,
visible:
false
)
end
it
'selecting explicit enabled shows a checkbox'
do
page
.
choose
(
'project_auto_devops_attributes_enabled_true'
)
expect
(
page
).
to
have_selector
(
'.js-run-auto-devops-pipeline-checkbox-wrapper:not(.hide)'
,
count:
1
)
end
it
'selecting instance default (enabled) shows a checkbox'
do
page
.
choose
(
'project_auto_devops_attributes_enabled_'
)
expect
(
page
).
to
have_selector
(
'.js-run-auto-devops-pipeline-checkbox-wrapper:not(.hide)'
,
count:
1
)
end
end
context
'when auto devops is set to explicit enabled'
do
before
do
stub_application_setting
(
auto_devops_enabled:
false
)
project
.
create_auto_devops!
(
enabled:
true
)
visit
project_settings_ci_cd_path
(
project
)
end
it
'does not have any checkboxes'
do
expect
(
page
).
not_to
have_selector
(
'.js-run-auto-devops-pipeline-checkbox-wrapper'
,
visible:
false
)
end
end
context
'when master contains a .gitlab-ci.yml file'
do
let
(
:project
)
{
create
(
:project
,
:repository
)
}
before
do
project
.
repository
.
create_file
(
user
,
'.gitlab-ci.yml'
,
"script: ['test']"
,
message:
'test'
,
branch_name:
project
.
default_branch
)
stub_application_setting
(
auto_devops_enabled:
true
)
project
.
create_auto_devops!
(
enabled:
false
)
visit
project_settings_ci_cd_path
(
project
)
end
it
'does not have any checkboxes'
do
expect
(
page
).
not_to
have_selector
(
'.js-run-auto-devops-pipeline-checkbox-wrapper'
,
visible:
false
)
end
end
end
end
end
end
spec/javascripts/flash_spec.js
View file @
f90b2a36
...
...
@@ -278,7 +278,7 @@ describe('Flash', () => {
removeFlashClickListener
(
flashEl
,
false
);
flashEl
.
parentNode
.
click
();
flashEl
.
click
();
setTimeout
(()
=>
{
expect
(
document
.
querySelector
(
'
.flash
'
)).
toBeNull
();
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment