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
983da2fb
Commit
983da2fb
authored
Mar 16, 2021
by
Marius Bobin
Committed by
Steve Abrams
Mar 16, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Disable pipeline schedules when a user is blocked
Disable pipeline schedules when a user is blocked
parent
76dc7136
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
82 additions
and
3 deletions
+82
-3
app/models/ci/pipeline_schedule.rb
app/models/ci/pipeline_schedule.rb
+2
-0
app/models/user.rb
app/models/user.rb
+1
-0
app/services/ci/disable_user_pipeline_schedules_service.rb
app/services/ci/disable_user_pipeline_schedules_service.rb
+11
-0
changelogs/unreleased/ci-disable-scheduled-pipelines-323341.yml
...logs/unreleased/ci-disable-scheduled-pipelines-323341.yml
+5
-0
db/migrate/20210312140029_add_owner_and_id_index_on_active_ci_pipeline_schedules.rb
...add_owner_and_id_index_on_active_ci_pipeline_schedules.rb
+18
-0
db/schema_migrations/20210312140029
db/schema_migrations/20210312140029
+1
-0
db/structure.sql
db/structure.sql
+2
-0
spec/features/projects/pipelines/pipeline_spec.rb
spec/features/projects/pipelines/pipeline_spec.rb
+2
-2
spec/models/ci/pipeline_schedule_spec.rb
spec/models/ci/pipeline_schedule_spec.rb
+12
-0
spec/models/user_spec.rb
spec/models/user_spec.rb
+9
-1
spec/services/ci/disable_user_pipeline_schedules_service_spec.rb
...rvices/ci/disable_user_pipeline_schedules_service_spec.rb
+19
-0
No files found.
app/models/ci/pipeline_schedule.rb
View file @
983da2fb
...
@@ -7,6 +7,7 @@ module Ci
...
@@ -7,6 +7,7 @@ module Ci
include
StripAttribute
include
StripAttribute
include
Schedulable
include
Schedulable
include
Limitable
include
Limitable
include
EachBatch
self
.
limit_name
=
'ci_pipeline_schedules'
self
.
limit_name
=
'ci_pipeline_schedules'
self
.
limit_scope
=
:project
self
.
limit_scope
=
:project
...
@@ -28,6 +29,7 @@ module Ci
...
@@ -28,6 +29,7 @@ module Ci
scope
:active
,
->
{
where
(
active:
true
)
}
scope
:active
,
->
{
where
(
active:
true
)
}
scope
:inactive
,
->
{
where
(
active:
false
)
}
scope
:inactive
,
->
{
where
(
active:
false
)
}
scope
:preloaded
,
->
{
preload
(
:owner
,
project:
[
:route
])
}
scope
:preloaded
,
->
{
preload
(
:owner
,
project:
[
:route
])
}
scope
:owned_by
,
->
(
user
)
{
where
(
owner:
user
)
}
accepts_nested_attributes_for
:variables
,
allow_destroy:
true
accepts_nested_attributes_for
:variables
,
allow_destroy:
true
...
...
app/models/user.rb
View file @
983da2fb
...
@@ -351,6 +351,7 @@ class User < ApplicationRecord
...
@@ -351,6 +351,7 @@ class User < ApplicationRecord
# For this reason the tradeoff is to disable this cop.
# For this reason the tradeoff is to disable this cop.
after_transition
any
=>
:blocked
do
|
user
|
after_transition
any
=>
:blocked
do
|
user
|
Ci
::
CancelUserPipelinesService
.
new
.
execute
(
user
)
Ci
::
CancelUserPipelinesService
.
new
.
execute
(
user
)
Ci
::
DisableUserPipelineSchedulesService
.
new
.
execute
(
user
)
end
end
# rubocop: enable CodeReuse/ServiceClass
# rubocop: enable CodeReuse/ServiceClass
end
end
...
...
app/services/ci/disable_user_pipeline_schedules_service.rb
0 → 100644
View file @
983da2fb
# frozen_string_literal: true
module
Ci
class
DisableUserPipelineSchedulesService
def
execute
(
user
)
Ci
::
PipelineSchedule
.
active
.
owned_by
(
user
).
each_batch
do
|
relation
|
relation
.
update_all
(
active:
false
)
end
end
end
end
changelogs/unreleased/ci-disable-scheduled-pipelines-323341.yml
0 → 100644
View file @
983da2fb
---
title
:
Disable pipeline schedules when a user is blocked
merge_request
:
56513
author
:
type
:
changed
db/migrate/20210312140029_add_owner_and_id_index_on_active_ci_pipeline_schedules.rb
0 → 100644
View file @
983da2fb
# frozen_string_literal: true
class
AddOwnerAndIdIndexOnActiveCiPipelineSchedules
<
ActiveRecord
::
Migration
[
6.0
]
include
Gitlab
::
Database
::
MigrationHelpers
DOWNTIME
=
false
INDEX_NAME
=
'index_ci_pipeline_schedules_on_owner_id_and_id_and_active'
disable_ddl_transaction!
def
up
add_concurrent_index
:ci_pipeline_schedules
,
[
:owner_id
,
:id
],
where:
"active = TRUE"
,
name:
INDEX_NAME
end
def
down
remove_concurrent_index_by_name
:ci_pipeline_schedules
,
INDEX_NAME
end
end
db/schema_migrations/20210312140029
0 → 100644
View file @
983da2fb
5d63a48f4a9327f683eff093d2862a0b88aa4249c94b2de9751ed6172c9b4799
\ No newline at end of file
db/structure.sql
View file @
983da2fb
...
@@ -22015,6 +22015,8 @@ CREATE INDEX index_ci_pipeline_schedules_on_next_run_at_and_active ON ci_pipelin
...
@@ -22015,6 +22015,8 @@ CREATE INDEX index_ci_pipeline_schedules_on_next_run_at_and_active ON ci_pipelin
CREATE INDEX index_ci_pipeline_schedules_on_owner_id ON ci_pipeline_schedules USING btree (owner_id);
CREATE INDEX index_ci_pipeline_schedules_on_owner_id ON ci_pipeline_schedules USING btree (owner_id);
CREATE INDEX index_ci_pipeline_schedules_on_owner_id_and_id_and_active ON ci_pipeline_schedules USING btree (owner_id, id) WHERE (active = true);
CREATE INDEX index_ci_pipeline_schedules_on_project_id ON ci_pipeline_schedules USING btree (project_id);
CREATE INDEX index_ci_pipeline_schedules_on_project_id ON ci_pipeline_schedules USING btree (project_id);
CREATE UNIQUE INDEX index_ci_pipeline_variables_on_pipeline_id_and_key ON ci_pipeline_variables USING btree (pipeline_id, key);
CREATE UNIQUE INDEX index_ci_pipeline_variables_on_pipeline_id_and_key ON ci_pipeline_variables USING btree (pipeline_id, key);
spec/features/projects/pipelines/pipeline_spec.rb
View file @
983da2fb
...
@@ -709,9 +709,9 @@ RSpec.describe 'Pipeline', :js do
...
@@ -709,9 +709,9 @@ RSpec.describe 'Pipeline', :js do
end
end
end
end
it
'displays the PipelineSchedule in an active state'
do
it
'displays the PipelineSchedule in an
in
active state'
do
visit
project_pipeline_schedules_path
(
project
)
visit
project_pipeline_schedules_path
(
project
)
page
.
click_link
(
'
A
ctive'
)
page
.
click_link
(
'
Ina
ctive'
)
expect
(
page
).
to
have_selector
(
'table.ci-table > tbody > tr > td'
,
text:
'blocked user schedule'
)
expect
(
page
).
to
have_selector
(
'table.ci-table > tbody > tr > td'
,
text:
'blocked user schedule'
)
end
end
...
...
spec/models/ci/pipeline_schedule_spec.rb
View file @
983da2fb
...
@@ -90,6 +90,18 @@ RSpec.describe Ci::PipelineSchedule do
...
@@ -90,6 +90,18 @@ RSpec.describe Ci::PipelineSchedule do
end
end
end
end
describe
'.owned_by'
do
let
(
:user
)
{
create
(
:user
)
}
let!
(
:owned_pipeline_schedule
)
{
create
(
:ci_pipeline_schedule
,
owner:
user
)
}
let!
(
:other_pipeline_schedule
)
{
create
(
:ci_pipeline_schedule
)
}
subject
{
described_class
.
owned_by
(
user
)
}
it
'returns owned pipeline schedules'
do
is_expected
.
to
eq
([
owned_pipeline_schedule
])
end
end
describe
'#set_next_run_at'
do
describe
'#set_next_run_at'
do
let
(
:pipeline_schedule
)
{
create
(
:ci_pipeline_schedule
,
:nightly
)
}
let
(
:pipeline_schedule
)
{
create
(
:ci_pipeline_schedule
,
:nightly
)
}
let
(
:ideal_next_run_at
)
{
pipeline_schedule
.
send
(
:ideal_next_run_from
,
Time
.
zone
.
now
)
}
let
(
:ideal_next_run_at
)
{
pipeline_schedule
.
send
(
:ideal_next_run_from
,
Time
.
zone
.
now
)
}
...
...
spec/models/user_spec.rb
View file @
983da2fb
...
@@ -1766,7 +1766,7 @@ RSpec.describe User do
...
@@ -1766,7 +1766,7 @@ RSpec.describe User do
end
end
describe
'blocking user'
do
describe
'blocking user'
do
let
(
:user
)
{
create
(
:user
,
name:
'John Smith'
)
}
let
_it_be_with_refind
(
:user
)
{
create
(
:user
,
name:
'John Smith'
)
}
it
'blocks user'
do
it
'blocks user'
do
user
.
block
user
.
block
...
@@ -1789,6 +1789,14 @@ RSpec.describe User do
...
@@ -1789,6 +1789,14 @@ RSpec.describe User do
user
.
block
user
.
block
end
end
end
end
context
'when user has active CI pipeline schedules'
do
let_it_be
(
:schedule
)
{
create
(
:ci_pipeline_schedule
,
active:
true
,
owner:
user
)
}
it
'disables any pipeline schedules'
do
expect
{
user
.
block
}.
to
change
{
schedule
.
reload
.
active?
}.
to
(
false
)
end
end
end
end
describe
'deactivating a user'
do
describe
'deactivating a user'
do
...
...
spec/services/ci/disable_user_pipeline_schedules_service_spec.rb
0 → 100644
View file @
983da2fb
# frozen_string_literal: true
require
'spec_helper'
RSpec
.
describe
Ci
::
DisableUserPipelineSchedulesService
do
describe
'#execute'
do
let
(
:user
)
{
create
(
:user
)
}
subject
(
:service
)
{
described_class
.
new
.
execute
(
user
)
}
context
'when user has active pipeline schedules'
do
let
(
:owned_pipeline_schedule
)
{
create
(
:ci_pipeline_schedule
,
active:
true
,
owner:
user
)
}
it
'disables all active pipeline schedules'
,
:aggregate_failures
do
expect
{
service
}.
to
change
{
owned_pipeline_schedule
.
reload
.
active?
}
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