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
7427c140
Commit
7427c140
authored
Mar 02, 2020
by
Etienne Baqué
Committed by
Imre Farkas
Mar 02, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Updated Deploy Keys rspecs
Updated existing rspecs. Moved Deploy Keys feature specs into new file.
parent
99860899
Changes
17
Hide whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
139 additions
and
116 deletions
+139
-116
app/assets/javascripts/pages/projects/settings/ci_cd/show/index.js
...s/javascripts/pages/projects/settings/ci_cd/show/index.js
+2
-0
app/assets/javascripts/pages/projects/settings/repository/form.js
...ts/javascripts/pages/projects/settings/repository/form.js
+0
-2
app/controllers/projects/deploy_keys_controller.rb
app/controllers/projects/deploy_keys_controller.rb
+10
-7
app/controllers/projects/settings/ci_cd_controller.rb
app/controllers/projects/settings/ci_cd_controller.rb
+5
-0
app/controllers/projects/settings/repository_controller.rb
app/controllers/projects/settings/repository_controller.rb
+0
-2
app/views/projects/settings/ci_cd/show.html.haml
app/views/projects/settings/ci_cd/show.html.haml
+2
-0
app/views/projects/settings/repository/show.html.haml
app/views/projects/settings/repository/show.html.haml
+0
-2
changelogs/unreleased/199370-move-deploy_keys-to-cicd.yml
changelogs/unreleased/199370-move-deploy_keys-to-cicd.yml
+5
-0
doc/ssh/README.md
doc/ssh/README.md
+2
-2
doc/user/project/pipelines/settings.md
doc/user/project/pipelines/settings.md
+8
-0
ee/app/controllers/ee/projects/settings/repository_controller.rb
...controllers/ee/projects/settings/repository_controller.rb
+0
-1
ee/spec/controllers/projects/deploy_keys_controller_spec.rb
ee/spec/controllers/projects/deploy_keys_controller_spec.rb
+1
-1
spec/controllers/projects/deploy_keys_controller_spec.rb
spec/controllers/projects/deploy_keys_controller_spec.rb
+8
-8
spec/features/projects/deploy_keys_spec.rb
spec/features/projects/deploy_keys_spec.rb
+2
-2
spec/features/projects/settings/ci_cd_settings_spec.rb
spec/features/projects/settings/ci_cd_settings_spec.rb
+92
-4
spec/features/projects/settings/repository_settings_spec.rb
spec/features/projects/settings/repository_settings_spec.rb
+0
-83
spec/features/projects/settings/user_interacts_with_deploy_keys_spec.rb
...projects/settings/user_interacts_with_deploy_keys_spec.rb
+2
-2
No files found.
app/assets/javascripts/pages/projects/settings/ci_cd/show/index.js
View file @
7427c140
...
@@ -4,6 +4,7 @@ import AjaxVariableList from '~/ci_variable_list/ajax_variable_list';
...
@@ -4,6 +4,7 @@ import AjaxVariableList from '~/ci_variable_list/ajax_variable_list';
import
registrySettingsApp
from
'
~/registry/settings/registry_settings_bundle
'
;
import
registrySettingsApp
from
'
~/registry/settings/registry_settings_bundle
'
;
import
initVariableList
from
'
~/ci_variable_list
'
;
import
initVariableList
from
'
~/ci_variable_list
'
;
import
DueDateSelectors
from
'
~/due_date_select
'
;
import
DueDateSelectors
from
'
~/due_date_select
'
;
import
initDeployKeys
from
'
~/deploy_keys
'
;
document
.
addEventListener
(
'
DOMContentLoaded
'
,
()
=>
{
document
.
addEventListener
(
'
DOMContentLoaded
'
,
()
=>
{
// Initialize expandable settings panels
// Initialize expandable settings panels
...
@@ -44,4 +45,5 @@ document.addEventListener('DOMContentLoaded', () => {
...
@@ -44,4 +45,5 @@ document.addEventListener('DOMContentLoaded', () => {
new
DueDateSelectors
();
new
DueDateSelectors
();
registrySettingsApp
();
registrySettingsApp
();
initDeployKeys
();
});
});
app/assets/javascripts/pages/projects/settings/repository/form.js
View file @
7427c140
...
@@ -3,7 +3,6 @@
...
@@ -3,7 +3,6 @@
import
ProtectedTagCreate
from
'
~/protected_tags/protected_tag_create
'
;
import
ProtectedTagCreate
from
'
~/protected_tags/protected_tag_create
'
;
import
ProtectedTagEditList
from
'
~/protected_tags/protected_tag_edit_list
'
;
import
ProtectedTagEditList
from
'
~/protected_tags/protected_tag_edit_list
'
;
import
initSettingsPanels
from
'
~/settings_panels
'
;
import
initSettingsPanels
from
'
~/settings_panels
'
;
import
initDeployKeys
from
'
~/deploy_keys
'
;
import
ProtectedBranchCreate
from
'
~/protected_branches/protected_branch_create
'
;
import
ProtectedBranchCreate
from
'
~/protected_branches/protected_branch_create
'
;
import
ProtectedBranchEditList
from
'
~/protected_branches/protected_branch_edit_list
'
;
import
ProtectedBranchEditList
from
'
~/protected_branches/protected_branch_edit_list
'
;
import
DueDateSelectors
from
'
~/due_date_select
'
;
import
DueDateSelectors
from
'
~/due_date_select
'
;
...
@@ -12,7 +11,6 @@ import fileUpload from '~/lib/utils/file_upload';
...
@@ -12,7 +11,6 @@ import fileUpload from '~/lib/utils/file_upload';
export
default
()
=>
{
export
default
()
=>
{
new
ProtectedTagCreate
();
new
ProtectedTagCreate
();
new
ProtectedTagEditList
();
new
ProtectedTagEditList
();
initDeployKeys
();
initSettingsPanels
();
initSettingsPanels
();
new
ProtectedBranchCreate
();
new
ProtectedBranchCreate
();
new
ProtectedBranchEditList
();
new
ProtectedBranchEditList
();
...
...
app/controllers/projects/deploy_keys_controller.rb
View file @
7427c140
# frozen_string_literal: true
# frozen_string_literal: true
class
Projects::DeployKeysController
<
Projects
::
ApplicationController
class
Projects::DeployKeysController
<
Projects
::
ApplicationController
include
RepositorySettingsRedirect
respond_to
:html
respond_to
:html
# Authorize
# Authorize
...
@@ -12,7 +11,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
...
@@ -12,7 +11,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
def
index
def
index
respond_to
do
|
format
|
respond_to
do
|
format
|
format
.
html
{
redirect_to_
repository_settings
(
@project
,
anchor:
'js-deploy-keys-settings'
)
}
format
.
html
{
redirect_to_
ci_cd_settings
}
format
.
json
do
format
.
json
do
render
json:
Projects
::
Settings
::
DeployKeysPresenter
.
new
(
@project
,
current_user:
current_user
).
as_json
render
json:
Projects
::
Settings
::
DeployKeysPresenter
.
new
(
@project
,
current_user:
current_user
).
as_json
end
end
...
@@ -20,7 +19,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
...
@@ -20,7 +19,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
end
end
def
new
def
new
redirect_to_
repository_settings
(
@project
,
anchor:
'js-deploy-keys-settings'
)
redirect_to_
ci_cd_settings
end
end
def
create
def
create
...
@@ -30,7 +29,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
...
@@ -30,7 +29,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
flash
[
:alert
]
=
@key
.
errors
.
full_messages
.
join
(
', '
).
html_safe
flash
[
:alert
]
=
@key
.
errors
.
full_messages
.
join
(
', '
).
html_safe
end
end
redirect_to_
repository_settings
(
@project
,
anchor:
'js-deploy-keys-settings'
)
redirect_to_
ci_cd_settings
end
end
def
edit
def
edit
...
@@ -39,7 +38,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
...
@@ -39,7 +38,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
def
update
def
update
if
deploy_key
.
update
(
update_params
)
if
deploy_key
.
update
(
update_params
)
flash
[
:notice
]
=
_
(
'Deploy key was successfully updated.'
)
flash
[
:notice
]
=
_
(
'Deploy key was successfully updated.'
)
redirect_to_
repository_settings
(
@project
,
anchor:
'js-deploy-keys-settings'
)
redirect_to_
ci_cd_settings
else
else
render
'edit'
render
'edit'
end
end
...
@@ -51,7 +50,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
...
@@ -51,7 +50,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
return
render_404
unless
key
return
render_404
unless
key
respond_to
do
|
format
|
respond_to
do
|
format
|
format
.
html
{
redirect_to_
repository_settings
(
@project
,
anchor:
'js-deploy-keys-settings'
)
}
format
.
html
{
redirect_to_
ci_cd_settings
}
format
.
json
{
head
:ok
}
format
.
json
{
head
:ok
}
end
end
end
end
...
@@ -62,7 +61,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
...
@@ -62,7 +61,7 @@ class Projects::DeployKeysController < Projects::ApplicationController
return
render_404
unless
deploy_key_project
return
render_404
unless
deploy_key_project
respond_to
do
|
format
|
respond_to
do
|
format
|
format
.
html
{
redirect_to_
repository_settings
(
@project
,
anchor:
'js-deploy-keys-settings'
)
}
format
.
html
{
redirect_to_
ci_cd_settings
}
format
.
json
{
head
:ok
}
format
.
json
{
head
:ok
}
end
end
end
end
...
@@ -97,4 +96,8 @@ class Projects::DeployKeysController < Projects::ApplicationController
...
@@ -97,4 +96,8 @@ class Projects::DeployKeysController < Projects::ApplicationController
access_denied!
access_denied!
end
end
end
end
def
redirect_to_ci_cd_settings
redirect_to
project_settings_ci_cd_path
(
@project
,
anchor:
'js-deploy-keys-settings'
)
end
end
end
app/controllers/projects/settings/ci_cd_controller.rb
View file @
7427c140
...
@@ -101,6 +101,7 @@ module Projects
...
@@ -101,6 +101,7 @@ module Projects
define_triggers_variables
define_triggers_variables
define_badges_variables
define_badges_variables
define_auto_devops_variables
define_auto_devops_variables
define_deploy_keys
end
end
def
define_runners_variables
def
define_runners_variables
...
@@ -153,6 +154,10 @@ module Projects
...
@@ -153,6 +154,10 @@ module Projects
@new_deploy_token
=
DeployToken
.
new
@new_deploy_token
=
DeployToken
.
new
end
end
def
define_deploy_keys
@deploy_keys
=
DeployKeysPresenter
.
new
(
@project
,
current_user:
current_user
)
end
end
end
end
end
end
end
...
...
app/controllers/projects/settings/repository_controller.rb
View file @
7427c140
...
@@ -27,8 +27,6 @@ module Projects
...
@@ -27,8 +27,6 @@ module Projects
private
private
def
render_show
def
render_show
@deploy_keys
=
DeployKeysPresenter
.
new
(
@project
,
current_user:
current_user
)
define_protected_refs
define_protected_refs
remote_mirror
remote_mirror
...
...
app/views/projects/settings/ci_cd/show.html.haml
View file @
7427c140
...
@@ -54,6 +54,8 @@
...
@@ -54,6 +54,8 @@
=
render
"shared/deploy_tokens/index"
,
group_or_project:
@project
,
description:
deploy_token_description
=
render
"shared/deploy_tokens/index"
,
group_or_project:
@project
,
description:
deploy_token_description
=
render
@deploy_keys
%section
.settings.no-animate
#js-pipeline-triggers
{
class:
(
'expanded'
if
expanded
)
}
%section
.settings.no-animate
#js-pipeline-triggers
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
.settings-header
%h4
%h4
...
...
app/views/projects/settings/repository/show.html.haml
View file @
7427c140
...
@@ -11,8 +11,6 @@
...
@@ -11,8 +11,6 @@
-# Those are used throughout the actual views. These `shared` views are then
-# Those are used throughout the actual views. These `shared` views are then
-# reused in EE.
-# reused in EE.
=
render
"projects/settings/repository/protected_branches"
=
render
"projects/settings/repository/protected_branches"
=
render
@deploy_keys
=
render
"projects/cleanup/show"
=
render
"projects/cleanup/show"
=
render_if_exists
'shared/promotions/promote_repository_features'
=
render_if_exists
'shared/promotions/promote_repository_features'
changelogs/unreleased/199370-move-deploy_keys-to-cicd.yml
0 → 100644
View file @
7427c140
---
title
:
Moved Deploy Keys from Repository to CI/CD settings.
merge_request
:
25444
author
:
type
:
changed
doc/ssh/README.md
View file @
7427c140
...
@@ -344,7 +344,7 @@ Integration (CI) server. By using deploy keys, you don't have to set up a
...
@@ -344,7 +344,7 @@ Integration (CI) server. By using deploy keys, you don't have to set up a
dummy user account.
dummy user account.
If you are a project maintainer or owner, you can add a deploy key in the
If you are a project maintainer or owner, you can add a deploy key in the
project's
**
Settings > Repository
**
page by expanding the
project's
**
{settings}**
**Settings > CI / CD
**
page by expanding the
**Deploy Keys**
section. Specify a title for the new
**Deploy Keys**
section. Specify a title for the new
deploy key and paste a public SSH key. After this, the machine that uses
deploy key and paste a public SSH key. After this, the machine that uses
the corresponding private SSH key has read-only or read-write (if enabled)
the corresponding private SSH key has read-only or read-write (if enabled)
...
@@ -387,7 +387,7 @@ of broader usage for something like "Anywhere you need to give read access to
...
@@ -387,7 +387,7 @@ of broader usage for something like "Anywhere you need to give read access to
your repository".
your repository".
Once a GitLab administrator adds the Global Deployment key, project maintainers
Once a GitLab administrator adds the Global Deployment key, project maintainers
and owners can add it in project's
**
Settings > Repository
**
page by expanding the
and owners can add it in project's
**
{settings}**
**Settings > CI / CD
**
page by expanding the
**Deploy Keys**
section and clicking
**Enable**
next to the appropriate key listed
**Deploy Keys**
section and clicking
**Enable**
next to the appropriate key listed
under
**Public deploy keys available to any project**
.
under
**Public deploy keys available to any project**
.
...
...
doc/user/project/pipelines/settings.md
View file @
7427c140
...
@@ -268,6 +268,14 @@ https://example.gitlab.com/<namespace>/<project>/badges/<branch>/coverage.svg?st
...
@@ -268,6 +268,14 @@ https://example.gitlab.com/<namespace>/<project>/badges/<branch>/coverage.svg?st
[
Environment variables
](
../../../ci/variables/README.html#gitlab-cicd-environment-variables
)
can be set in an environment to be available to a runner.
[
Environment variables
](
../../../ci/variables/README.html#gitlab-cicd-environment-variables
)
can be set in an environment to be available to a runner.
## Deploy Keys
With Deploy Keys, GitLab allows you to import SSH public keys. You can then have
read only or read/write access to your project from the machines the keys were generated from.
SSH keys added to your project settings will be used for continuous integration,
staging, or production servers.
<!-- ## Troubleshooting
<!-- ## Troubleshooting
Include any troubleshooting steps that you can foresee. If you know beforehand what issues
Include any troubleshooting steps that you can foresee. If you know beforehand what issues
...
...
ee/app/controllers/ee/projects/settings/repository_controller.rb
View file @
7427c140
...
@@ -39,7 +39,6 @@ module EE
...
@@ -39,7 +39,6 @@ module EE
# rubocop:disable Gitlab/ModuleWithInstanceVariables
# rubocop:disable Gitlab/ModuleWithInstanceVariables
def
render_show
def
render_show
@deploy_keys
=
::
Projects
::
Settings
::
DeployKeysPresenter
.
new
(
@project
,
current_user:
current_user
)
@deploy_tokens
=
@project
.
deploy_tokens
.
active
@deploy_tokens
=
@project
.
deploy_tokens
.
active
define_protected_refs
define_protected_refs
...
...
ee/spec/controllers/projects/deploy_keys_controller_spec.rb
View file @
7427c140
...
@@ -30,7 +30,7 @@ describe Projects::DeployKeysController do
...
@@ -30,7 +30,7 @@ describe Projects::DeployKeysController do
it
'records an audit event'
do
it
'records an audit event'
do
expect
{
post
:create
,
params:
params
}.
to
change
{
AuditEvent
.
count
}.
by
(
1
)
expect
{
post
:create
,
params:
params
}.
to
change
{
AuditEvent
.
count
}.
by
(
1
)
expect
(
response
).
to
redirect_to
(
project_settings_
repository
_path
(
project
,
anchor:
'js-deploy-keys-settings'
))
expect
(
response
).
to
redirect_to
(
project_settings_
ci_cd
_path
(
project
,
anchor:
'js-deploy-keys-settings'
))
end
end
end
end
...
...
spec/controllers/projects/deploy_keys_controller_spec.rb
View file @
7427c140
...
@@ -19,10 +19,10 @@ describe Projects::DeployKeysController do
...
@@ -19,10 +19,10 @@ describe Projects::DeployKeysController do
end
end
context
'when html requested'
do
context
'when html requested'
do
it
'redirects to project settings with the correct anchor'
do
it
'redirects to project
ci / cd
settings with the correct anchor'
do
get
:index
,
params:
params
get
:index
,
params:
params
expect
(
response
).
to
redirect_to
(
project_settings_
repository
_path
(
project
,
anchor:
'js-deploy-keys-settings'
))
expect
(
response
).
to
redirect_to
(
project_settings_
ci_cd
_path
(
project
,
anchor:
'js-deploy-keys-settings'
))
end
end
end
end
...
@@ -87,13 +87,13 @@ describe Projects::DeployKeysController do
...
@@ -87,13 +87,13 @@ describe Projects::DeployKeysController do
it
'creates a new deploy key for the project'
do
it
'creates a new deploy key for the project'
do
expect
{
post
:create
,
params:
create_params
}.
to
change
(
project
.
deploy_keys
,
:count
).
by
(
1
)
expect
{
post
:create
,
params:
create_params
}.
to
change
(
project
.
deploy_keys
,
:count
).
by
(
1
)
expect
(
response
).
to
redirect_to
(
project_settings_
repository
_path
(
project
,
anchor:
'js-deploy-keys-settings'
))
expect
(
response
).
to
redirect_to
(
project_settings_
ci_cd
_path
(
project
,
anchor:
'js-deploy-keys-settings'
))
end
end
it
'redirects to project settings with the correct anchor'
do
it
'redirects to project settings with the correct anchor'
do
post
:create
,
params:
create_params
post
:create
,
params:
create_params
expect
(
response
).
to
redirect_to
(
project_settings_
repository
_path
(
project
,
anchor:
'js-deploy-keys-settings'
))
expect
(
response
).
to
redirect_to
(
project_settings_
ci_cd
_path
(
project
,
anchor:
'js-deploy-keys-settings'
))
end
end
context
'when the deploy key is invalid'
do
context
'when the deploy key is invalid'
do
...
@@ -153,7 +153,7 @@ describe Projects::DeployKeysController do
...
@@ -153,7 +153,7 @@ describe Projects::DeployKeysController do
expect
(
DeployKeysProject
.
where
(
project_id:
project
.
id
,
deploy_key_id:
deploy_key
.
id
).
count
).
to
eq
(
1
)
expect
(
DeployKeysProject
.
where
(
project_id:
project
.
id
,
deploy_key_id:
deploy_key
.
id
).
count
).
to
eq
(
1
)
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
expect
(
response
).
to
redirect_to
(
namespace_project_settings_
repository
_path
(
anchor:
'js-deploy-keys-settings'
))
expect
(
response
).
to
redirect_to
(
namespace_project_settings_
ci_cd
_path
(
anchor:
'js-deploy-keys-settings'
))
end
end
it
'returns 404'
do
it
'returns 404'
do
...
@@ -175,7 +175,7 @@ describe Projects::DeployKeysController do
...
@@ -175,7 +175,7 @@ describe Projects::DeployKeysController do
expect
(
DeployKeysProject
.
where
(
project_id:
project
.
id
,
deploy_key_id:
deploy_key
.
id
).
count
).
to
eq
(
1
)
expect
(
DeployKeysProject
.
where
(
project_id:
project
.
id
,
deploy_key_id:
deploy_key
.
id
).
count
).
to
eq
(
1
)
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
expect
(
response
).
to
redirect_to
(
namespace_project_settings_
repository
_path
(
anchor:
'js-deploy-keys-settings'
))
expect
(
response
).
to
redirect_to
(
namespace_project_settings_
ci_cd
_path
(
anchor:
'js-deploy-keys-settings'
))
end
end
end
end
end
end
...
@@ -216,7 +216,7 @@ describe Projects::DeployKeysController do
...
@@ -216,7 +216,7 @@ describe Projects::DeployKeysController do
put
:disable
,
params:
{
id:
deploy_key
.
id
,
namespace_id:
project
.
namespace
,
project_id:
project
}
put
:disable
,
params:
{
id:
deploy_key
.
id
,
namespace_id:
project
.
namespace
,
project_id:
project
}
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
expect
(
response
).
to
redirect_to
(
namespace_project_settings_
repository
_path
(
anchor:
'js-deploy-keys-settings'
))
expect
(
response
).
to
redirect_to
(
namespace_project_settings_
ci_cd
_path
(
anchor:
'js-deploy-keys-settings'
))
expect
{
DeployKey
.
find
(
deploy_key
.
id
)
}.
to
raise_error
(
ActiveRecord
::
RecordNotFound
)
expect
{
DeployKey
.
find
(
deploy_key
.
id
)
}.
to
raise_error
(
ActiveRecord
::
RecordNotFound
)
end
end
...
@@ -239,7 +239,7 @@ describe Projects::DeployKeysController do
...
@@ -239,7 +239,7 @@ describe Projects::DeployKeysController do
end
.
to
change
{
DeployKey
.
count
}.
by
(
-
1
)
end
.
to
change
{
DeployKey
.
count
}.
by
(
-
1
)
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
expect
(
response
).
to
redirect_to
(
namespace_project_settings_
repository
_path
(
anchor:
'js-deploy-keys-settings'
))
expect
(
response
).
to
redirect_to
(
namespace_project_settings_
ci_cd
_path
(
anchor:
'js-deploy-keys-settings'
))
expect
{
DeployKey
.
find
(
deploy_key
.
id
)
}.
to
raise_error
(
ActiveRecord
::
RecordNotFound
)
expect
{
DeployKey
.
find
(
deploy_key
.
id
)
}.
to
raise_error
(
ActiveRecord
::
RecordNotFound
)
end
end
...
...
spec/features/projects/deploy_keys_spec.rb
View file @
7427c140
...
@@ -17,9 +17,9 @@ describe 'Project deploy keys', :js do
...
@@ -17,9 +17,9 @@ describe 'Project deploy keys', :js do
end
end
it
'removes association between project and deploy key'
do
it
'removes association between project and deploy key'
do
visit
project_settings_
repository
_path
(
project
)
visit
project_settings_
ci_cd
_path
(
project
)
page
.
within
(
find
(
'.
deploy-key
s'
))
do
page
.
within
(
find
(
'.
qa-deploy-keys-setting
s'
))
do
expect
(
page
).
to
have_selector
(
'.deploy-key'
,
count:
1
)
expect
(
page
).
to
have_selector
(
'.deploy-key'
,
count:
1
)
accept_confirm
{
find
(
'.ic-remove'
).
click
}
accept_confirm
{
find
(
'.ic-remove'
).
click
}
...
...
spec/features/projects/settings/ci_cd_settings_spec.rb
View file @
7427c140
...
@@ -2,10 +2,10 @@
...
@@ -2,10 +2,10 @@
require
'spec_helper'
require
'spec_helper'
describe
'Projects > Settings > CI
/
CD settings'
do
describe
'Projects > Settings > CI
/
CD settings'
do
let
(
:project
)
{
create
(
:project_empty_repo
)
}
let
_it_be
(
:project
)
{
create
(
:project_empty_repo
)
}
let
(
:user
)
{
create
(
:user
)
}
let
_it_be
(
:user
)
{
create
(
:user
)
}
let
(
:role
)
{
:maintainer
}
let
_it_be
(
:role
)
{
:maintainer
}
context
'Deploy tokens'
do
context
'Deploy tokens'
do
let!
(
:deploy_token
)
{
create
(
:deploy_token
,
projects:
[
project
])
}
let!
(
:deploy_token
)
{
create
(
:deploy_token
,
projects:
[
project
])
}
...
@@ -21,4 +21,92 @@ describe 'Projects > Settings > CI/CD settings' do
...
@@ -21,4 +21,92 @@ describe 'Projects > Settings > CI/CD settings' do
let
(
:entity_type
)
{
'project'
}
let
(
:entity_type
)
{
'project'
}
end
end
end
end
context
'Deploy Keys'
,
:js
do
let_it_be
(
:private_deploy_key
)
{
create
(
:deploy_key
,
title:
'private_deploy_key'
,
public:
false
)
}
let_it_be
(
:public_deploy_key
)
{
create
(
:another_deploy_key
,
title:
'public_deploy_key'
,
public:
true
)
}
let
(
:new_ssh_key
)
{
attributes_for
(
:key
)[
:key
]
}
before
do
project
.
add_role
(
user
,
role
)
sign_in
(
user
)
end
it
'get list of keys'
do
project
.
deploy_keys
<<
private_deploy_key
project
.
deploy_keys
<<
public_deploy_key
visit
project_settings_ci_cd_path
(
project
)
expect
(
page
).
to
have_content
(
'private_deploy_key'
)
expect
(
page
).
to
have_content
(
'public_deploy_key'
)
end
it
'add a new deploy key'
do
visit
project_settings_ci_cd_path
(
project
)
fill_in
'deploy_key_title'
,
with:
'new_deploy_key'
fill_in
'deploy_key_key'
,
with:
new_ssh_key
check
'deploy_key_deploy_keys_projects_attributes_0_can_push'
click_button
'Add key'
expect
(
page
).
to
have_content
(
'new_deploy_key'
)
expect
(
page
).
to
have_content
(
'Write access allowed'
)
end
it
'edit an existing deploy key'
do
project
.
deploy_keys
<<
private_deploy_key
visit
project_settings_ci_cd_path
(
project
)
find
(
'.deploy-key'
,
text:
private_deploy_key
.
title
).
find
(
'.ic-pencil'
).
click
fill_in
'deploy_key_title'
,
with:
'updated_deploy_key'
check
'deploy_key_deploy_keys_projects_attributes_0_can_push'
click_button
'Save changes'
expect
(
page
).
to
have_content
(
'updated_deploy_key'
)
expect
(
page
).
to
have_content
(
'Write access allowed'
)
end
it
'edit an existing public deploy key to be writable'
do
project
.
deploy_keys
<<
public_deploy_key
visit
project_settings_ci_cd_path
(
project
)
find
(
'.deploy-key'
,
text:
public_deploy_key
.
title
).
find
(
'.ic-pencil'
).
click
check
'deploy_key_deploy_keys_projects_attributes_0_can_push'
click_button
'Save changes'
expect
(
page
).
to
have_content
(
'public_deploy_key'
)
expect
(
page
).
to
have_content
(
'Write access allowed'
)
end
it
'edit a deploy key from projects user has access to'
do
project2
=
create
(
:project_empty_repo
)
project2
.
add_role
(
user
,
role
)
project2
.
deploy_keys
<<
private_deploy_key
visit
project_settings_ci_cd_path
(
project
)
find
(
'.js-deployKeys-tab-available_project_keys'
).
click
find
(
'.deploy-key'
,
text:
private_deploy_key
.
title
).
find
(
'.ic-pencil'
).
click
fill_in
'deploy_key_title'
,
with:
'updated_deploy_key'
click_button
'Save changes'
find
(
'.js-deployKeys-tab-available_project_keys'
).
click
expect
(
page
).
to
have_content
(
'updated_deploy_key'
)
end
it
'remove an existing deploy key'
do
project
.
deploy_keys
<<
private_deploy_key
visit
project_settings_ci_cd_path
(
project
)
accept_confirm
{
find
(
'.deploy-key'
,
text:
private_deploy_key
.
title
).
find
(
'.ic-remove'
).
click
}
expect
(
page
).
not_to
have_content
(
private_deploy_key
.
title
)
end
end
end
end
spec/features/projects/settings/repository_settings_spec.rb
View file @
7427c140
...
@@ -25,89 +25,6 @@ describe 'Projects > Settings > Repository settings' do
...
@@ -25,89 +25,6 @@ describe 'Projects > Settings > Repository settings' do
context
'for maintainer'
do
context
'for maintainer'
do
let
(
:role
)
{
:maintainer
}
let
(
:role
)
{
:maintainer
}
context
'Deploy Keys'
,
:js
do
let
(
:private_deploy_key
)
{
create
(
:deploy_key
,
title:
'private_deploy_key'
,
public:
false
)
}
let
(
:public_deploy_key
)
{
create
(
:another_deploy_key
,
title:
'public_deploy_key'
,
public:
true
)
}
let
(
:new_ssh_key
)
{
attributes_for
(
:key
)[
:key
]
}
it
'get list of keys'
do
project
.
deploy_keys
<<
private_deploy_key
project
.
deploy_keys
<<
public_deploy_key
visit
project_settings_repository_path
(
project
)
expect
(
page
).
to
have_content
(
'private_deploy_key'
)
expect
(
page
).
to
have_content
(
'public_deploy_key'
)
end
it
'add a new deploy key'
do
visit
project_settings_repository_path
(
project
)
fill_in
'deploy_key_title'
,
with:
'new_deploy_key'
fill_in
'deploy_key_key'
,
with:
new_ssh_key
check
'deploy_key_deploy_keys_projects_attributes_0_can_push'
click_button
'Add key'
expect
(
page
).
to
have_content
(
'new_deploy_key'
)
expect
(
page
).
to
have_content
(
'Write access allowed'
)
end
it
'edit an existing deploy key'
do
project
.
deploy_keys
<<
private_deploy_key
visit
project_settings_repository_path
(
project
)
find
(
'.deploy-key'
,
text:
private_deploy_key
.
title
).
find
(
'.ic-pencil'
).
click
fill_in
'deploy_key_title'
,
with:
'updated_deploy_key'
check
'deploy_key_deploy_keys_projects_attributes_0_can_push'
click_button
'Save changes'
expect
(
page
).
to
have_content
(
'updated_deploy_key'
)
expect
(
page
).
to
have_content
(
'Write access allowed'
)
end
it
'edit an existing public deploy key to be writable'
do
project
.
deploy_keys
<<
public_deploy_key
visit
project_settings_repository_path
(
project
)
find
(
'.deploy-key'
,
text:
public_deploy_key
.
title
).
find
(
'.ic-pencil'
).
click
check
'deploy_key_deploy_keys_projects_attributes_0_can_push'
click_button
'Save changes'
expect
(
page
).
to
have_content
(
'public_deploy_key'
)
expect
(
page
).
to
have_content
(
'Write access allowed'
)
end
it
'edit a deploy key from projects user has access to'
do
project2
=
create
(
:project_empty_repo
)
project2
.
add_role
(
user
,
role
)
project2
.
deploy_keys
<<
private_deploy_key
visit
project_settings_repository_path
(
project
)
find
(
'.js-deployKeys-tab-available_project_keys'
).
click
find
(
'.deploy-key'
,
text:
private_deploy_key
.
title
).
find
(
'.ic-pencil'
).
click
fill_in
'deploy_key_title'
,
with:
'updated_deploy_key'
click_button
'Save changes'
find
(
'.js-deployKeys-tab-available_project_keys'
).
click
expect
(
page
).
to
have_content
(
'updated_deploy_key'
)
end
it
'remove an existing deploy key'
do
project
.
deploy_keys
<<
private_deploy_key
visit
project_settings_repository_path
(
project
)
accept_confirm
{
find
(
'.deploy-key'
,
text:
private_deploy_key
.
title
).
find
(
'.ic-remove'
).
click
}
expect
(
page
).
not_to
have_content
(
private_deploy_key
.
title
)
end
end
context
'remote mirror settings'
do
context
'remote mirror settings'
do
let
(
:user2
)
{
create
(
:user
)
}
let
(
:user2
)
{
create
(
:user
)
}
...
...
spec/features/projects/settings/user_interacts_with_deploy_keys_spec.rb
View file @
7427c140
...
@@ -20,7 +20,7 @@ describe "User interacts with deploy keys", :js do
...
@@ -20,7 +20,7 @@ describe "User interacts with deploy keys", :js do
click_button
(
"Enable"
)
click_button
(
"Enable"
)
expect
(
page
).
not_to
have_selector
(
".fa-spinner"
)
expect
(
page
).
not_to
have_selector
(
".fa-spinner"
)
expect
(
current_path
).
to
eq
(
project_settings_
repository
_path
(
project
))
expect
(
current_path
).
to
eq
(
project_settings_
ci_cd
_path
(
project
))
find
(
".js-deployKeys-tab-enabled_keys"
).
click
find
(
".js-deployKeys-tab-enabled_keys"
).
click
...
@@ -96,7 +96,7 @@ describe "User interacts with deploy keys", :js do
...
@@ -96,7 +96,7 @@ describe "User interacts with deploy keys", :js do
click_button
(
"Add key"
)
click_button
(
"Add key"
)
expect
(
current_path
).
to
eq
(
project_settings_
repository
_path
(
project
))
expect
(
current_path
).
to
eq
(
project_settings_
ci_cd
_path
(
project
))
page
.
within
(
".deploy-keys"
)
do
page
.
within
(
".deploy-keys"
)
do
expect
(
page
).
to
have_content
(
DEPLOY_KEY_TITLE
)
expect
(
page
).
to
have_content
(
DEPLOY_KEY_TITLE
)
...
...
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