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
29fbf961
Commit
29fbf961
authored
Jul 26, 2021
by
Vitali Tatarintev
Committed by
Fabio Pitino
Jul 26, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Create Backend Services for Cancel and Unschedule job actions
parent
3a46ab2e
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
288 additions
and
70 deletions
+288
-70
app/controllers/projects/jobs_controller.rb
app/controllers/projects/jobs_controller.rb
+16
-10
app/services/ci/build_cancel_service.rb
app/services/ci/build_cancel_service.rb
+35
-0
app/services/ci/build_unschedule_service.rb
app/services/ci/build_unschedule_service.rb
+35
-0
spec/controllers/projects/jobs_controller_spec.rb
spec/controllers/projects/jobs_controller_spec.rb
+98
-60
spec/services/ci/build_cancel_service_spec.rb
spec/services/ci/build_cancel_service_spec.rb
+52
-0
spec/services/ci/build_unschedule_service_spec.rb
spec/services/ci/build_unschedule_service_spec.rb
+52
-0
No files found.
app/controllers/projects/jobs_controller.rb
View file @
29fbf961
...
@@ -9,7 +9,7 @@ class Projects::JobsController < Projects::ApplicationController
...
@@ -9,7 +9,7 @@ class Projects::JobsController < Projects::ApplicationController
before_action
:authorize_read_build_trace!
,
only:
[
:trace
,
:raw
]
before_action
:authorize_read_build_trace!
,
only:
[
:trace
,
:raw
]
before_action
:authorize_read_build!
before_action
:authorize_read_build!
before_action
:authorize_update_build!
,
before_action
:authorize_update_build!
,
except:
[
:index
,
:show
,
:status
,
:raw
,
:trace
,
:erase
]
except:
[
:index
,
:show
,
:status
,
:raw
,
:trace
,
:erase
,
:cancel
,
:unschedule
]
before_action
:authorize_erase_build!
,
only:
[
:erase
]
before_action
:authorize_erase_build!
,
only:
[
:erase
]
before_action
:authorize_use_build_terminal!
,
only:
[
:terminal
,
:terminal_websocket_authorize
]
before_action
:authorize_use_build_terminal!
,
only:
[
:terminal
,
:terminal_websocket_authorize
]
before_action
:verify_api_request!
,
only: :terminal_websocket_authorize
before_action
:verify_api_request!
,
only: :terminal_websocket_authorize
...
@@ -93,22 +93,28 @@ class Projects::JobsController < Projects::ApplicationController
...
@@ -93,22 +93,28 @@ class Projects::JobsController < Projects::ApplicationController
end
end
def
cancel
def
cancel
return
respond_422
unless
@build
.
cancelable?
service_response
=
Ci
::
BuildCancelService
.
new
(
@build
,
current_user
).
execute
@build
.
cancel
if
service_response
.
success?
destination
=
continue_params
[
:to
].
presence
||
builds_project_pipeline_path
(
@project
,
@build
.
pipeline
.
id
)
if
continue_params
[
:to
]
redirect_to
destination
redirect_to
continue_params
[
:to
]
elsif
service_response
.
http_status
==
:forbidden
access_denied!
else
else
redirect_to
builds_project_pipeline_path
(
@project
,
@build
.
pipeline
.
id
)
head
service_response
.
http_status
end
end
end
end
def
unschedule
def
unschedule
return
respond_422
unless
@build
.
scheduled?
service_response
=
Ci
::
BuildUnscheduleService
.
new
(
@build
,
current_user
).
execute
@build
.
unschedule!
if
service_response
.
success?
redirect_to
build_path
(
@build
)
redirect_to
build_path
(
@build
)
elsif
service_response
.
http_status
==
:forbidden
access_denied!
else
head
service_response
.
http_status
end
end
end
def
status
def
status
...
...
app/services/ci/build_cancel_service.rb
0 → 100644
View file @
29fbf961
# frozen_string_literal: true
module
Ci
class
BuildCancelService
def
initialize
(
build
,
user
)
@build
=
build
@user
=
user
end
def
execute
return
forbidden
unless
allowed?
return
unprocessable_entity
unless
build
.
cancelable?
build
.
cancel
ServiceResponse
.
success
(
payload:
build
)
end
private
attr_reader
:build
,
:user
def
allowed?
user
.
can?
(
:update_build
,
build
)
end
def
forbidden
ServiceResponse
.
error
(
message:
'Forbidden'
,
http_status: :forbidden
)
end
def
unprocessable_entity
ServiceResponse
.
error
(
message:
'Unprocessable entity'
,
http_status: :unprocessable_entity
)
end
end
end
app/services/ci/build_unschedule_service.rb
0 → 100644
View file @
29fbf961
# frozen_string_literal: true
module
Ci
class
BuildUnscheduleService
def
initialize
(
build
,
user
)
@build
=
build
@user
=
user
end
def
execute
return
forbidden
unless
allowed?
return
unprocessable_entity
unless
build
.
scheduled?
build
.
unschedule!
ServiceResponse
.
success
(
payload:
build
)
end
private
attr_reader
:build
,
:user
def
allowed?
user
.
can?
(
:update_build
,
build
)
end
def
forbidden
ServiceResponse
.
error
(
message:
'Forbidden'
,
http_status: :forbidden
)
end
def
unprocessable_entity
ServiceResponse
.
error
(
message:
'Unprocessable entity'
,
http_status: :unprocessable_entity
)
end
end
end
spec/controllers/projects/jobs_controller_spec.rb
View file @
29fbf961
...
@@ -868,6 +868,7 @@ RSpec.describe Projects::JobsController, :clean_gitlab_redis_shared_state do
...
@@ -868,6 +868,7 @@ RSpec.describe Projects::JobsController, :clean_gitlab_redis_shared_state do
end
end
describe
'POST cancel'
do
describe
'POST cancel'
do
context
'when user is authorized to cancel the build'
do
before
do
before
do
project
.
add_developer
(
user
)
project
.
add_developer
(
user
)
sign_in
(
user
)
sign_in
(
user
)
...
@@ -928,6 +929,26 @@ RSpec.describe Projects::JobsController, :clean_gitlab_redis_shared_state do
...
@@ -928,6 +929,26 @@ RSpec.describe Projects::JobsController, :clean_gitlab_redis_shared_state do
end
end
end
end
end
end
end
context
'when user is not authorized to cancel the build'
do
let!
(
:job
)
{
create
(
:ci_build
,
:cancelable
,
pipeline:
pipeline
)
}
before
do
project
.
add_reporter
(
user
)
sign_in
(
user
)
post_cancel
end
it
'responds with not_found'
do
expect
(
response
).
to
have_gitlab_http_status
(
:not_found
)
end
it
'does not transit to canceled'
do
expect
(
job
.
reload
).
not_to
be_canceled
end
end
def
post_cancel
(
additional_params
=
{})
def
post_cancel
(
additional_params
=
{})
post
:cancel
,
params:
{
namespace_id:
project
.
namespace
,
post
:cancel
,
params:
{
namespace_id:
project
.
namespace
,
...
@@ -938,11 +959,12 @@ RSpec.describe Projects::JobsController, :clean_gitlab_redis_shared_state do
...
@@ -938,11 +959,12 @@ RSpec.describe Projects::JobsController, :clean_gitlab_redis_shared_state do
describe
'POST unschedule'
do
describe
'POST unschedule'
do
before
do
before
do
project
.
add_developer
(
user
)
create
(
:protected_branch
,
:developers_can_merge
,
name:
'master'
,
project:
project
)
end
create
(
:protected_branch
,
:developers_can_merge
,
name:
'master'
,
project:
project
)
context
'when user is authorized to unschedule the build'
do
before
do
project
.
add_developer
(
user
)
sign_in
(
user
)
sign_in
(
user
)
post_unschedule
post_unschedule
...
@@ -968,13 +990,29 @@ RSpec.describe Projects::JobsController, :clean_gitlab_redis_shared_state do
...
@@ -968,13 +990,29 @@ RSpec.describe Projects::JobsController, :clean_gitlab_redis_shared_state do
expect
(
response
).
to
have_gitlab_http_status
(
:unprocessable_entity
)
expect
(
response
).
to
have_gitlab_http_status
(
:unprocessable_entity
)
end
end
end
end
end
context
'when user is not authorized to unschedule the build'
do
let
(
:job
)
{
create
(
:ci_build
,
:scheduled
,
pipeline:
pipeline
)
}
before
do
project
.
add_reporter
(
user
)
sign_in
(
user
)
post_unschedule
end
it
'responds with not_found'
do
expect
(
response
).
to
have_gitlab_http_status
(
:not_found
)
end
it
'does not transit to scheduled'
do
expect
(
job
.
reload
).
not_to
be_manual
end
end
def
post_unschedule
def
post_unschedule
post
:unschedule
,
params:
{
post
:unschedule
,
params:
{
namespace_id:
project
.
namespace
,
project_id:
project
,
id:
job
.
id
}
namespace_id:
project
.
namespace
,
project_id:
project
,
id:
job
.
id
}
end
end
end
end
...
...
spec/services/ci/build_cancel_service_spec.rb
0 → 100644
View file @
29fbf961
# frozen_string_literal: true
require
'spec_helper'
RSpec
.
describe
Ci
::
BuildCancelService
do
let_it_be
(
:user
)
{
create
(
:user
)
}
let_it_be
(
:project
)
{
create
(
:project
)
}
let_it_be
(
:pipeline
)
{
create
(
:ci_pipeline
,
project:
project
)
}
describe
'#execute'
do
subject
(
:execute
)
{
described_class
.
new
(
build
,
user
).
execute
}
context
'when user is authorized to cancel the build'
do
before
do
project
.
add_maintainer
(
user
)
end
context
'when build is cancelable'
do
let!
(
:build
)
{
create
(
:ci_build
,
:cancelable
,
pipeline:
pipeline
)
}
it
'transits build to canceled'
,
:aggregate_failures
do
response
=
execute
expect
(
response
).
to
be_success
expect
(
response
.
payload
.
reload
).
to
be_canceled
end
end
context
'when build is not cancelable'
do
let!
(
:build
)
{
create
(
:ci_build
,
:canceled
,
pipeline:
pipeline
)
}
it
'responds with unprocessable entity'
,
:aggregate_failures
do
response
=
execute
expect
(
response
).
to
be_error
expect
(
response
.
http_status
).
to
eq
(
:unprocessable_entity
)
end
end
end
context
'when user is not authorized to cancel the build'
do
let!
(
:build
)
{
create
(
:ci_build
,
:cancelable
,
pipeline:
pipeline
)
}
it
'responds with forbidden'
,
:aggregate_failures
do
response
=
execute
expect
(
response
).
to
be_error
expect
(
response
.
http_status
).
to
eq
(
:forbidden
)
end
end
end
end
spec/services/ci/build_unschedule_service_spec.rb
0 → 100644
View file @
29fbf961
# frozen_string_literal: true
require
'spec_helper'
RSpec
.
describe
Ci
::
BuildUnscheduleService
do
let_it_be
(
:user
)
{
create
(
:user
)
}
let_it_be
(
:project
)
{
create
(
:project
)
}
let_it_be
(
:pipeline
)
{
create
(
:ci_pipeline
,
project:
project
)
}
describe
'#execute'
do
subject
(
:execute
)
{
described_class
.
new
(
build
,
user
).
execute
}
context
'when user is authorized to unschedule the build'
do
before
do
project
.
add_maintainer
(
user
)
end
context
'when build is scheduled'
do
let!
(
:build
)
{
create
(
:ci_build
,
:scheduled
,
pipeline:
pipeline
)
}
it
'transits build to manual'
do
response
=
execute
expect
(
response
).
to
be_success
expect
(
response
.
payload
.
reload
).
to
be_manual
end
end
context
'when build is not scheduled'
do
let!
(
:build
)
{
create
(
:ci_build
,
pipeline:
pipeline
)
}
it
'responds with unprocessable entity'
,
:aggregate_failures
do
response
=
execute
expect
(
response
).
to
be_error
expect
(
response
.
http_status
).
to
eq
(
:unprocessable_entity
)
end
end
end
context
'when user is not authorized to unschedule the build'
do
let!
(
:build
)
{
create
(
:ci_build
,
:scheduled
,
pipeline:
pipeline
)
}
it
'responds with forbidden'
,
:aggregate_failures
do
response
=
execute
expect
(
response
).
to
be_error
expect
(
response
.
http_status
).
to
eq
(
:forbidden
)
end
end
end
end
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