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
536d56b0
Commit
536d56b0
authored
Jan 31, 2020
by
Felipe Artur
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Allow to change issues/epics health status
Allow IssuableBaseService to save issues/epics health_status_id value.
parent
be711a8d
Changes
18
Show whitespace changes
Inline
Side-by-side
Showing
18 changed files
with
137 additions
and
6 deletions
+137
-6
app/services/issuable_base_service.rb
app/services/issuable_base_service.rb
+6
-2
db/migrate/20200131181354_add_health_status_to_epics.rb
db/migrate/20200131181354_add_health_status_to_epics.rb
+9
-0
db/migrate/20200131191754_add_health_status_to_issues.rb
db/migrate/20200131191754_add_health_status_to_issues.rb
+9
-0
db/schema.rb
db/schema.rb
+2
-0
ee/app/models/concerns/ee/issuable.rb
ee/app/models/concerns/ee/issuable.rb
+4
-0
ee/app/models/concerns/health_status.rb
ee/app/models/concerns/health_status.rb
+20
-0
ee/app/models/ee/epic.rb
ee/app/models/ee/epic.rb
+1
-0
ee/app/models/ee/issue.rb
ee/app/models/ee/issue.rb
+1
-0
ee/app/models/license.rb
ee/app/models/license.rb
+1
-0
ee/app/services/ee/issuable_base_service.rb
ee/app/services/ee/issuable_base_service.rb
+6
-4
ee/changelogs/unreleased/issue_36427.yml
ee/changelogs/unreleased/issue_36427.yml
+5
-0
ee/spec/models/epic_spec.rb
ee/spec/models/epic_spec.rb
+2
-0
ee/spec/models/issue_spec.rb
ee/spec/models/issue_spec.rb
+2
-0
ee/spec/services/ee/issues/update_service_spec.rb
ee/spec/services/ee/issues/update_service_spec.rb
+5
-0
ee/spec/services/epics/update_service_spec.rb
ee/spec/services/epics/update_service_spec.rb
+5
-0
ee/spec/support/shared_examples/models/concerns/health_status_shared_examples.rb
...examples/models/concerns/health_status_shared_examples.rb
+12
-0
ee/spec/support/shared_examples/services/update_issuable_health_status_shared_examples.rb
...services/update_issuable_health_status_shared_examples.rb
+45
-0
spec/lib/gitlab/import_export/safe_model_attributes.yml
spec/lib/gitlab/import_export/safe_model_attributes.yml
+2
-0
No files found.
app/services/issuable_base_service.rb
View file @
536d56b0
...
@@ -11,10 +11,14 @@ class IssuableBaseService < BaseService
...
@@ -11,10 +11,14 @@ class IssuableBaseService < BaseService
@skip_milestone_email
=
@params
.
delete
(
:skip_milestone_email
)
@skip_milestone_email
=
@params
.
delete
(
:skip_milestone_email
)
end
end
def
filter_params
(
issuable
)
def
can_admin_issuable?
(
issuable
)
ability_name
=
:"admin_
#{
issuable
.
to_ability_name
}
"
ability_name
=
:"admin_
#{
issuable
.
to_ability_name
}
"
unless
can?
(
current_user
,
ability_name
,
issuable
)
can?
(
current_user
,
ability_name
,
issuable
)
end
def
filter_params
(
issuable
)
unless
can_admin_issuable?
(
issuable
)
params
.
delete
(
:milestone_id
)
params
.
delete
(
:milestone_id
)
params
.
delete
(
:labels
)
params
.
delete
(
:labels
)
params
.
delete
(
:add_label_ids
)
params
.
delete
(
:add_label_ids
)
...
...
db/migrate/20200131181354_add_health_status_to_epics.rb
0 → 100644
View file @
536d56b0
# frozen_string_literal: true
class
AddHealthStatusToEpics
<
ActiveRecord
::
Migration
[
6.0
]
DOWNTIME
=
false
def
change
add_column
:epics
,
:health_status
,
:integer
,
limit:
2
end
end
db/migrate/20200131191754_add_health_status_to_issues.rb
0 → 100644
View file @
536d56b0
# frozen_string_literal: true
class
AddHealthStatusToIssues
<
ActiveRecord
::
Migration
[
6.0
]
DOWNTIME
=
false
def
change
add_column
:issues
,
:health_status
,
:integer
,
limit:
2
end
end
db/schema.rb
View file @
536d56b0
...
@@ -1554,6 +1554,7 @@ ActiveRecord::Schema.define(version: 2020_02_07_151640) do
...
@@ -1554,6 +1554,7 @@ ActiveRecord::Schema.define(version: 2020_02_07_151640) do
t
.
integer
"state_id"
,
limit:
2
,
default:
1
,
null:
false
t
.
integer
"state_id"
,
limit:
2
,
default:
1
,
null:
false
t
.
integer
"start_date_sourcing_epic_id"
t
.
integer
"start_date_sourcing_epic_id"
t
.
integer
"due_date_sourcing_epic_id"
t
.
integer
"due_date_sourcing_epic_id"
t
.
integer
"health_status"
,
limit:
2
t
.
index
[
"assignee_id"
],
name:
"index_epics_on_assignee_id"
t
.
index
[
"assignee_id"
],
name:
"index_epics_on_assignee_id"
t
.
index
[
"author_id"
],
name:
"index_epics_on_author_id"
t
.
index
[
"author_id"
],
name:
"index_epics_on_author_id"
t
.
index
[
"closed_by_id"
],
name:
"index_epics_on_closed_by_id"
t
.
index
[
"closed_by_id"
],
name:
"index_epics_on_closed_by_id"
...
@@ -2181,6 +2182,7 @@ ActiveRecord::Schema.define(version: 2020_02_07_151640) do
...
@@ -2181,6 +2182,7 @@ ActiveRecord::Schema.define(version: 2020_02_07_151640) do
t
.
integer
"state_id"
,
limit:
2
,
default:
1
,
null:
false
t
.
integer
"state_id"
,
limit:
2
,
default:
1
,
null:
false
t
.
integer
"duplicated_to_id"
t
.
integer
"duplicated_to_id"
t
.
integer
"promoted_to_epic_id"
t
.
integer
"promoted_to_epic_id"
t
.
integer
"health_status"
,
limit:
2
t
.
index
[
"author_id"
],
name:
"index_issues_on_author_id"
t
.
index
[
"author_id"
],
name:
"index_issues_on_author_id"
t
.
index
[
"closed_by_id"
],
name:
"index_issues_on_closed_by_id"
t
.
index
[
"closed_by_id"
],
name:
"index_issues_on_closed_by_id"
t
.
index
[
"confidential"
],
name:
"index_issues_on_confidential"
t
.
index
[
"confidential"
],
name:
"index_issues_on_confidential"
...
...
ee/app/models/concerns/ee/issuable.rb
View file @
536d56b0
...
@@ -21,5 +21,9 @@ module EE
...
@@ -21,5 +21,9 @@ module EE
def
supports_epic?
def
supports_epic?
is_a?
(
Issue
)
&&
project
.
group
is_a?
(
Issue
)
&&
project
.
group
end
end
def
supports_health_status?
false
end
end
end
end
end
ee/app/models/concerns/health_status.rb
0 → 100644
View file @
536d56b0
# frozen_string_literal: true
module
HealthStatus
extend
ActiveSupport
::
Concern
extend
::
Gitlab
::
Utils
::
Override
included
do
enum
health_status:
{
on_track:
1
,
needs_attention:
2
,
at_risk:
3
}
end
override
:supports_health_status?
def
supports_health_status?
resource_parent
.
feature_available?
(
:issuable_health_status
)
&&
::
Feature
.
enabled?
(
:save_issuable_health_status
,
resource_parent
)
end
end
ee/app/models/ee/epic.rb
View file @
536d56b0
...
@@ -15,6 +15,7 @@ module EE
...
@@ -15,6 +15,7 @@ module EE
include
UsageStatistics
include
UsageStatistics
include
FromUnion
include
FromUnion
include
EpicTreeSorting
include
EpicTreeSorting
include
HealthStatus
enum
state_id:
{
enum
state_id:
{
opened:
::
Epic
.
available_states
[
:opened
],
opened:
::
Epic
.
available_states
[
:opened
],
...
...
ee/app/models/ee/issue.rb
View file @
536d56b0
...
@@ -14,6 +14,7 @@ module EE
...
@@ -14,6 +14,7 @@ module EE
include
Elastic
::
ApplicationVersionedSearch
include
Elastic
::
ApplicationVersionedSearch
include
UsageStatistics
include
UsageStatistics
include
WeightEventable
include
WeightEventable
include
HealthStatus
scope
:order_weight_desc
,
->
{
reorder
::
Gitlab
::
Database
.
nulls_last_order
(
'weight'
,
'DESC'
)
}
scope
:order_weight_desc
,
->
{
reorder
::
Gitlab
::
Database
.
nulls_last_order
(
'weight'
,
'DESC'
)
}
scope
:order_weight_asc
,
->
{
reorder
::
Gitlab
::
Database
.
nulls_last_order
(
'weight'
)
}
scope
:order_weight_asc
,
->
{
reorder
::
Gitlab
::
Database
.
nulls_last_order
(
'weight'
)
}
...
...
ee/app/models/license.rb
View file @
536d56b0
...
@@ -115,6 +115,7 @@ class License < ApplicationRecord
...
@@ -115,6 +115,7 @@ class License < ApplicationRecord
group_level_compliance_dashboard
group_level_compliance_dashboard
incident_management
incident_management
insights
insights
issuable_health_status
license_management
license_management
personal_access_token_expiration_policy
personal_access_token_expiration_policy
pod_logs
pod_logs
...
...
ee/app/services/ee/issuable_base_service.rb
View file @
536d56b0
...
@@ -11,14 +11,16 @@ module EE
...
@@ -11,14 +11,16 @@ module EE
override
:filter_params
override
:filter_params
def
filter_params
(
issuable
)
def
filter_params
(
issuable
)
# This security check is repeated here to avoid multiple backports,
can_admin_issuable
=
can_admin_issuable?
(
issuable
)
# this should be refactored to be reused from the base class.
ability_name
=
:"admin_
#{
issuable
.
to_ability_name
}
"
unless
issuable
.
supports_weight?
&&
can?
(
current_user
,
ability_name
,
issuable
)
unless
can_admin_issuable
&&
issuable
.
supports_weight?
params
.
delete
(
:weight
)
params
.
delete
(
:weight
)
end
end
unless
can_admin_issuable
&&
issuable
.
supports_health_status?
params
.
delete
(
:health_status
)
end
super
super
end
end
...
...
ee/changelogs/unreleased/issue_36427.yml
0 → 100644
View file @
536d56b0
---
title
:
Add health_status column to issues and epics tables
merge_request
:
24202
author
:
type
:
added
ee/spec/models/epic_spec.rb
View file @
536d56b0
...
@@ -565,4 +565,6 @@ describe Epic do
...
@@ -565,4 +565,6 @@ describe Epic do
end
end
it_behaves_like
'versioned description'
it_behaves_like
'versioned description'
it_behaves_like
'having health status'
end
end
ee/spec/models/issue_spec.rb
View file @
536d56b0
...
@@ -572,4 +572,6 @@ describe Issue do
...
@@ -572,4 +572,6 @@ describe Issue do
it
{
is_expected
.
to
eq
(
expected
)
}
it
{
is_expected
.
to
eq
(
expected
)
}
end
end
end
end
it_behaves_like
'having health status'
end
end
ee/spec/services/ee/issues/update_service_spec.rb
View file @
536d56b0
...
@@ -58,6 +58,11 @@ describe Issues::UpdateService do
...
@@ -58,6 +58,11 @@ describe Issues::UpdateService do
end
end
end
end
it_behaves_like
'updating issuable health status'
do
let
(
:issuable
)
{
issue
}
let
(
:parent
)
{
project
}
end
context
'updating other fields'
do
context
'updating other fields'
do
it
'does not call UpdateDatesService'
do
it
'does not call UpdateDatesService'
do
expect
(
Epics
::
UpdateDatesService
).
not_to
receive
(
:new
)
expect
(
Epics
::
UpdateDatesService
).
not_to
receive
(
:new
)
...
...
ee/spec/services/epics/update_service_spec.rb
View file @
536d56b0
...
@@ -254,5 +254,10 @@ describe Epics::UpdateService do
...
@@ -254,5 +254,10 @@ describe Epics::UpdateService do
let
(
:issuable
)
{
epic
}
let
(
:issuable
)
{
epic
}
let
(
:parent
)
{
group
}
let
(
:parent
)
{
group
}
end
end
it_behaves_like
'updating issuable health status'
do
let
(
:issuable
)
{
epic
}
let
(
:parent
)
{
group
}
end
end
end
end
end
ee/spec/support/shared_examples/models/concerns/health_status_shared_examples.rb
0 → 100644
View file @
536d56b0
# frozen_string_literal: true
RSpec
.
shared_examples
'having health status'
do
context
'validations'
do
it
do
is_expected
.
to
define_enum_for
(
:health_status
)
.
with_values
(
on_track:
1
,
needs_attention:
2
,
at_risk:
3
)
end
it
{
is_expected
.
to
allow_value
(
nil
).
for
(
:health_status
)
}
end
end
ee/spec/support/shared_examples/services/update_issuable_health_status_shared_examples.rb
0 → 100644
View file @
536d56b0
# frozen_string_literal: true
RSpec
.
shared_examples
'updating issuable health status'
do
context
'updating health_status'
do
let
(
:current_user
)
{
create
(
:user
)
}
let
(
:opts
)
{
{
health_status:
1
}
}
let
(
:service
)
{
described_class
.
new
(
parent
,
current_user
,
opts
)
}
context
'when feature is not available'
do
it
'does not update issue health status'
do
expect
{
service
.
execute
(
issuable
)
}.
not_to
change
{
issuable
.
health_status
}
end
end
context
'when feature is available'
do
before
do
stub_licensed_features
(
issuable_health_status:
true
,
epics:
true
)
end
context
'when feature flag is disabled'
do
it
'does not update issuable'
do
stub_feature_flags
(
save_issuable_health_status:
false
)
expect
{
service
.
execute
(
issuable
)
}.
not_to
change
{
issuable
.
health_status
}
end
end
context
'when user has reporter permissions'
do
before
do
issuable
.
resource_parent
.
add_reporter
(
current_user
)
end
it
'updates issuable with given health_status'
do
expect
{
service
.
execute
(
issuable
)
}.
to
change
{
issuable
.
health_status
}.
to
(
'on_track'
)
end
end
context
'when user does not have permissions'
do
it
'does not update issuable status'
do
expect
{
service
.
execute
(
issuable
)
}.
not_to
change
{
issuable
.
health_status
}
end
end
end
end
end
spec/lib/gitlab/import_export/safe_model_attributes.yml
View file @
536d56b0
...
@@ -30,6 +30,7 @@ Issue:
...
@@ -30,6 +30,7 @@ Issue:
-
last_edited_at
-
last_edited_at
-
last_edited_by_id
-
last_edited_by_id
-
discussion_locked
-
discussion_locked
-
health_status
Event
:
Event
:
-
id
-
id
-
target_type
-
target_type
...
@@ -824,3 +825,4 @@ Epic:
...
@@ -824,3 +825,4 @@ Epic:
-
state_id
-
state_id
-
start_date_sourcing_epic_id
-
start_date_sourcing_epic_id
-
due_date_sourcing_epic_id
-
due_date_sourcing_epic_id
-
health_status
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