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
5e7fce9a
Commit
5e7fce9a
authored
Apr 15, 2021
by
Markus Koller
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Reinstate "Optimize issuable updates"
This reverts commit
397835f2
.
parent
b645968b
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
62 additions
and
16 deletions
+62
-16
app/models/concerns/issuable.rb
app/models/concerns/issuable.rb
+8
-0
app/models/concerns/milestoneable.rb
app/models/concerns/milestoneable.rb
+3
-1
app/services/issuable/bulk_update_service.rb
app/services/issuable/bulk_update_service.rb
+10
-3
changelogs/unreleased/21068-optimize-issueable-updates.yml
changelogs/unreleased/21068-optimize-issueable-updates.yml
+5
-0
ee/app/services/ee/issuable/bulk_update_service.rb
ee/app/services/ee/issuable/bulk_update_service.rb
+5
-2
ee/spec/models/concerns/ee/milestoneable_spec.rb
ee/spec/models/concerns/ee/milestoneable_spec.rb
+5
-5
spec/models/concerns/issuable_spec.rb
spec/models/concerns/issuable_spec.rb
+17
-0
spec/models/concerns/milestoneable_spec.rb
spec/models/concerns/milestoneable_spec.rb
+9
-5
No files found.
app/models/concerns/issuable.rb
View file @
5e7fce9a
...
...
@@ -137,6 +137,14 @@ module Issuable
scope
:references_project
,
->
{
references
(
:project
)
}
scope
:non_archived
,
->
{
join_project
.
where
(
projects:
{
archived:
false
})
}
scope
:includes_for_bulk_update
,
->
do
associations
=
%i[author assignees epic group labels metrics project source_project target_project]
.
select
do
|
association
|
reflect_on_association
(
association
)
end
includes
(
*
associations
)
end
attr_mentionable
:title
,
pipeline: :single_line
attr_mentionable
:description
...
...
app/models/concerns/milestoneable.rb
View file @
5e7fce9a
...
...
@@ -39,11 +39,13 @@ module Milestoneable
private
def
milestone_is_valid
errors
.
add
(
:milestone_id
,
'is invalid'
)
if
respond_to?
(
:milestone_id
)
&&
milestone_id
.
present?
&&
!
milestone_available?
errors
.
add
(
:milestone_id
,
'is invalid'
)
if
respond_to?
(
:milestone_id
)
&&
!
milestone_available?
end
end
def
milestone_available?
return
true
if
milestone_id
.
blank?
project_id
==
milestone
&
.
project_id
||
project
.
ancestors_upto
.
compact
.
include?
(
milestone
&
.
group
)
end
...
...
app/services/issuable/bulk_update_service.rb
View file @
5e7fce9a
...
...
@@ -15,7 +15,7 @@ module Issuable
set_update_params
(
type
)
items
=
update_issuables
(
type
,
ids
)
response_success
(
payload:
{
count:
items
.
count
})
response_success
(
payload:
{
count:
items
.
size
})
rescue
ArgumentError
=>
e
response_error
(
e
.
message
,
422
)
end
...
...
@@ -59,10 +59,17 @@ module Issuable
def
find_issuables
(
parent
,
model_class
,
ids
)
if
parent
.
is_a?
(
Project
)
model_class
.
id_in
(
ids
).
of_projects
(
parent
)
projects
=
parent
elsif
parent
.
is_a?
(
Group
)
model_class
.
id_in
(
ids
).
of_projects
(
parent
.
all_projects
)
projects
=
parent
.
all_projects
else
return
end
model_class
.
id_in
(
ids
)
.
of_projects
(
projects
)
.
includes_for_bulk_update
end
def
response_success
(
message:
nil
,
payload:
nil
)
...
...
changelogs/unreleased/21068-optimize-issueable-updates.yml
0 → 100644
View file @
5e7fce9a
---
title
:
Optimize issuable updates
merge_request
:
59468
author
:
type
:
performance
ee/app/services/ee/issuable/bulk_update_service.rb
View file @
5e7fce9a
...
...
@@ -9,9 +9,12 @@ module EE
override
:find_issuables
def
find_issuables
(
parent
,
model_class
,
ids
)
return
model_class
.
id_in
(
ids
).
in_selected_groups
(
parent
.
self_and_descendants
)
if
model_class
==
::
Epic
return
super
unless
model_class
==
::
Epic
super
model_class
.
id_in
(
ids
)
.
in_selected_groups
(
parent
.
self_and_descendants
)
.
includes_for_bulk_update
end
override
:permitted_attrs
...
...
ee/spec/models/concerns/ee/milestoneable_spec.rb
View file @
5e7fce9a
...
...
@@ -4,11 +4,11 @@ require 'spec_helper'
RSpec
.
describe
EE
::
Milestoneable
do
describe
'#milestone_available?'
do
context
'
no Epic
'
do
let
(
:
issue
)
{
create
(
:issue
)
}
context
'
for epics
'
do
let
(
:
epic
)
{
build
(
:epic
)
}
it
'returns
fals
e'
do
expect
(
issue
.
milestone_available?
).
to
be_falsy
it
'returns
tru
e'
do
expect
(
epic
.
milestone_available?
).
to
be
(
true
)
end
end
end
...
...
@@ -21,7 +21,7 @@ RSpec.describe EE::Milestoneable do
let
(
:epic
)
{
build
(
:epic
)
}
it
'returns false'
do
expect
(
epic
.
supports_milestone?
).
to
be
_falsy
expect
(
epic
.
supports_milestone?
).
to
be
(
false
)
end
end
end
...
...
spec/models/concerns/issuable_spec.rb
View file @
5e7fce9a
...
...
@@ -65,6 +65,23 @@ RSpec.describe Issuable do
it
{
expect
(
issuable_class
).
to
respond_to
(
:opened
)
}
it
{
expect
(
issuable_class
).
to
respond_to
(
:closed
)
}
it
{
expect
(
issuable_class
).
to
respond_to
(
:assigned
)
}
describe
'.includes_for_bulk_update'
do
before
do
stub_const
(
'Example'
,
Class
.
new
(
ActiveRecord
::
Base
))
Example
.
class_eval
do
include
Issuable
# adds :labels and :metrics, among others
belongs_to
:author
has_many
:assignees
end
end
it
'includes available associations'
do
expect
(
Example
.
includes_for_bulk_update
.
includes_values
).
to
eq
([
:author
,
:assignees
,
:labels
,
:metrics
])
end
end
end
describe
'author_name'
do
...
...
spec/models/concerns/milestoneable_spec.rb
View file @
5e7fce9a
...
...
@@ -50,13 +50,13 @@ RSpec.describe Milestoneable do
it
'returns true with a milestone from the issue project'
do
milestone
=
create
(
:milestone
,
project:
project
)
expect
(
build_milestoneable
(
milestone
.
id
).
milestone_available?
).
to
be
_truthy
expect
(
build_milestoneable
(
milestone
.
id
).
milestone_available?
).
to
be
(
true
)
end
it
'returns true with a milestone from the issue project group'
do
milestone
=
create
(
:milestone
,
group:
group
)
expect
(
build_milestoneable
(
milestone
.
id
).
milestone_available?
).
to
be
_truthy
expect
(
build_milestoneable
(
milestone
.
id
).
milestone_available?
).
to
be
(
true
)
end
it
'returns true with a milestone from the the parent of the issue project group'
do
...
...
@@ -64,19 +64,23 @@ RSpec.describe Milestoneable do
group
.
update!
(
parent:
parent
)
milestone
=
create
(
:milestone
,
group:
parent
)
expect
(
build_milestoneable
(
milestone
.
id
).
milestone_available?
).
to
be_truthy
expect
(
build_milestoneable
(
milestone
.
id
).
milestone_available?
).
to
be
(
true
)
end
it
'returns true with a blank milestone'
do
expect
(
build_milestoneable
(
''
).
milestone_available?
).
to
be
(
true
)
end
it
'returns false with a milestone from another project'
do
milestone
=
create
(
:milestone
)
expect
(
build_milestoneable
(
milestone
.
id
).
milestone_available?
).
to
be
_falsey
expect
(
build_milestoneable
(
milestone
.
id
).
milestone_available?
).
to
be
(
false
)
end
it
'returns false with a milestone from another group'
do
milestone
=
create
(
:milestone
,
group:
create
(
:group
))
expect
(
build_milestoneable
(
milestone
.
id
).
milestone_available?
).
to
be
_falsey
expect
(
build_milestoneable
(
milestone
.
id
).
milestone_available?
).
to
be
(
false
)
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