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
c2463711
Commit
c2463711
authored
Oct 31, 2019
by
Brett Walker
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add GraphQL support for sorting issues by priority
leveraging the new OffsetActiveRecordRelationConnection
parent
4949b735
Changes
9
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
189 additions
and
42 deletions
+189
-42
app/graphql/resolvers/issues_resolver.rb
app/graphql/resolvers/issues_resolver.rb
+15
-1
app/graphql/types/issuable_sort_enum.rb
app/graphql/types/issuable_sort_enum.rb
+3
-0
changelogs/unreleased/29713-graphql-add-issue-priority-sort.yml
...logs/unreleased/29713-graphql-add-issue-priority-sort.yml
+5
-0
doc/api/graphql/reference/gitlab_schema.graphql
doc/api/graphql/reference/gitlab_schema.graphql
+10
-0
doc/api/graphql/reference/gitlab_schema.json
doc/api/graphql/reference/gitlab_schema.json
+12
-0
ee/spec/graphql/ee/resolvers/issues_resolver_spec.rb
ee/spec/graphql/ee/resolvers/issues_resolver_spec.rb
+5
-5
spec/graphql/resolvers/issues_resolver_spec.rb
spec/graphql/resolvers/issues_resolver_spec.rb
+31
-10
spec/graphql/types/issuable_sort_enum_spec.rb
spec/graphql/types/issuable_sort_enum_spec.rb
+11
-0
spec/requests/api/graphql/project/issues_spec.rb
spec/requests/api/graphql/project/issues_spec.rb
+97
-26
No files found.
app/graphql/resolvers/issues_resolver.rb
View file @
c2463711
...
...
@@ -52,6 +52,8 @@ module Resolvers
type
Types
::
IssueType
,
null:
true
NON_STABLE_CURSOR_SORTS
=
%i[priority_asc priority_desc]
.
freeze
def
resolve
(
**
args
)
# The project could have been loaded in batch by `BatchLoader`.
# At this point we need the `id` of the project to query for issues, so
...
...
@@ -70,7 +72,15 @@ module Resolvers
args
[
:iids
]
||=
[
args
[
:iid
]].
compact
args
[
:attempt_project_search_optimizations
]
=
args
[
:search
].
present?
IssuesFinder
.
new
(
context
[
:current_user
],
args
).
execute
issues
=
IssuesFinder
.
new
(
context
[
:current_user
],
args
).
execute
if
non_stable_cursor_sort?
(
args
[
:sort
])
# Certain complex sorts are not supported by the stable cursor pagination yet.
# In these cases, we use offset pagination, so we return the correct connection.
Gitlab
::
Graphql
::
Pagination
::
OffsetActiveRecordRelationConnection
.
new
(
issues
)
else
issues
end
end
def
self
.
resolver_complexity
(
args
,
child_complexity
:)
...
...
@@ -79,5 +89,9 @@ module Resolvers
complexity
end
def
non_stable_cursor_sort?
(
sort
)
NON_STABLE_CURSOR_SORTS
.
include?
(
sort
)
end
end
end
app/graphql/types/issuable_sort_enum.rb
View file @
c2463711
...
...
@@ -4,5 +4,8 @@ module Types
class
IssuableSortEnum
<
SortEnum
graphql_name
'IssuableSort'
description
'Values for sorting issuables'
value
'PRIORITY_ASC'
,
'Priority by ascending order'
,
value: :priority_asc
value
'PRIORITY_DESC'
,
'Priority by descending order'
,
value: :priority_desc
end
end
changelogs/unreleased/29713-graphql-add-issue-priority-sort.yml
0 → 100644
View file @
c2463711
---
title
:
Graphql query for issues can now be sorted by priority
merge_request
:
18901
author
:
type
:
added
doc/api/graphql/reference/gitlab_schema.graphql
View file @
c2463711
...
...
@@ -4398,6 +4398,16 @@ enum IssueSort {
"""
DUE_DATE_DESC
"""
Priority
by
ascending
order
"""
PRIORITY_ASC
"""
Priority
by
descending
order
"""
PRIORITY_DESC
"""
Relative
position
by
ascending
order
"""
...
...
doc/api/graphql/reference/gitlab_schema.json
View file @
c2463711
...
...
@@ -12546,6 +12546,18 @@
"isDeprecated"
:
false
,
"deprecationReason"
:
null
},
{
"name"
:
"PRIORITY_ASC"
,
"description"
:
"Priority by ascending order"
,
"isDeprecated"
:
false
,
"deprecationReason"
:
null
},
{
"name"
:
"PRIORITY_DESC"
,
"description"
:
"Priority by descending order"
,
"isDeprecated"
:
false
,
"deprecationReason"
:
null
},
{
"name"
:
"DUE_DATE_ASC"
,
"description"
:
"Due date by ascending order"
,
...
...
ee/spec/graphql/ee/resolvers/issues_resolver_spec.rb
View file @
c2463711
...
...
@@ -6,16 +6,16 @@ describe Resolvers::IssuesResolver do
include
GraphqlHelpers
let_it_be
(
:current_user
)
{
create
(
:user
)
}
let
(
:project
)
{
create
(
:project
)
}
let
_it_be
(
:project
)
{
create
(
:project
)
}
context
"with a project"
do
describe
'#resolve'
do
describe
'sorting'
do
context
'when sorting by weight'
do
let
!
(
:weight_issue1
)
{
create
(
:issue
,
project:
project
,
weight:
5
)
}
let
!
(
:weight_issue2
)
{
create
(
:issue
,
project:
project
,
weight:
nil
)
}
let
!
(
:weight_issue3
)
{
create
(
:issue
,
project:
project
,
weight:
1
)
}
let
!
(
:weight_issue4
)
{
create
(
:issue
,
project:
project
,
weight:
nil
)
}
let
_it_be
(
:weight_issue1
)
{
create
(
:issue
,
project:
project
,
weight:
5
)
}
let
_it_be
(
:weight_issue2
)
{
create
(
:issue
,
project:
project
,
weight:
nil
)
}
let
_it_be
(
:weight_issue3
)
{
create
(
:issue
,
project:
project
,
weight:
1
)
}
let
_it_be
(
:weight_issue4
)
{
create
(
:issue
,
project:
project
,
weight:
nil
)
}
before
do
project
.
add_developer
(
current_user
)
...
...
spec/graphql/resolvers/issues_resolver_spec.rb
View file @
c2463711
...
...
@@ -125,12 +125,12 @@ describe Resolvers::IssuesResolver do
end
context
'when sorting by due date'
do
let
(
:project
)
{
create
(
:project
)
}
let
_it_be
(
:project
)
{
create
(
:project
)
}
let
!
(
:due_issue1
)
{
create
(
:issue
,
project:
project
,
due_date:
3
.
days
.
from_now
)
}
let
!
(
:due_issue2
)
{
create
(
:issue
,
project:
project
,
due_date:
nil
)
}
let
!
(
:due_issue3
)
{
create
(
:issue
,
project:
project
,
due_date:
2
.
days
.
ago
)
}
let
!
(
:due_issue4
)
{
create
(
:issue
,
project:
project
,
due_date:
nil
)
}
let
_it_be
(
:due_issue1
)
{
create
(
:issue
,
project:
project
,
due_date:
3
.
days
.
from_now
)
}
let
_it_be
(
:due_issue2
)
{
create
(
:issue
,
project:
project
,
due_date:
nil
)
}
let
_it_be
(
:due_issue3
)
{
create
(
:issue
,
project:
project
,
due_date:
2
.
days
.
ago
)
}
let
_it_be
(
:due_issue4
)
{
create
(
:issue
,
project:
project
,
due_date:
nil
)
}
it
'sorts issues ascending'
do
expect
(
resolve_issues
(
sort: :due_date_asc
)).
to
eq
[
due_issue3
,
due_issue1
,
due_issue4
,
due_issue2
]
...
...
@@ -142,17 +142,38 @@ describe Resolvers::IssuesResolver do
end
context
'when sorting by relative position'
do
let
(
:project
)
{
create
(
:project
)
}
let
_it_be
(
:project
)
{
create
(
:project
)
}
let
!
(
:relative_issue1
)
{
create
(
:issue
,
project:
project
,
relative_position:
2000
)
}
let
!
(
:relative_issue2
)
{
create
(
:issue
,
project:
project
,
relative_position:
nil
)
}
let
!
(
:relative_issue3
)
{
create
(
:issue
,
project:
project
,
relative_position:
1000
)
}
let
!
(
:relative_issue4
)
{
create
(
:issue
,
project:
project
,
relative_position:
nil
)
}
let
_it_be
(
:relative_issue1
)
{
create
(
:issue
,
project:
project
,
relative_position:
2000
)
}
let
_it_be
(
:relative_issue2
)
{
create
(
:issue
,
project:
project
,
relative_position:
nil
)
}
let
_it_be
(
:relative_issue3
)
{
create
(
:issue
,
project:
project
,
relative_position:
1000
)
}
let
_it_be
(
:relative_issue4
)
{
create
(
:issue
,
project:
project
,
relative_position:
nil
)
}
it
'sorts issues ascending'
do
expect
(
resolve_issues
(
sort: :relative_position_asc
)).
to
eq
[
relative_issue3
,
relative_issue1
,
relative_issue4
,
relative_issue2
]
end
end
context
'when sorting by priority'
do
let_it_be
(
:project
)
{
create
(
:project
)
}
let_it_be
(
:early_milestone
)
{
create
(
:milestone
,
project:
project
,
due_date:
10
.
days
.
from_now
)
}
let_it_be
(
:late_milestone
)
{
create
(
:milestone
,
project:
project
,
due_date:
30
.
days
.
from_now
)
}
let_it_be
(
:label_1
)
{
create
(
:label
,
project:
project
,
priority:
1
)
}
let_it_be
(
:label_2
)
{
create
(
:label
,
project:
project
,
priority:
5
)
}
let_it_be
(
:issue1
)
{
create
(
:issue
,
project:
project
,
labels:
[
label_1
],
milestone:
late_milestone
)
}
let_it_be
(
:issue2
)
{
create
(
:issue
,
project:
project
,
labels:
[
label_2
])
}
let_it_be
(
:issue3
)
{
create
(
:issue
,
project:
project
,
milestone:
early_milestone
)
}
let_it_be
(
:issue4
)
{
create
(
:issue
,
project:
project
)
}
it
'sorts issues ascending'
do
expect
(
resolve_issues
(
sort: :priority_asc
).
items
).
to
eq
([
issue3
,
issue1
,
issue2
,
issue4
])
end
it
'sorts issues descending'
do
expect
(
resolve_issues
(
sort: :priority_desc
).
items
).
to
eq
([
issue1
,
issue3
,
issue2
,
issue4
])
end
end
end
it
'returns issues user can see'
do
...
...
spec/graphql/types/issuable_sort_enum_spec.rb
0 → 100644
View file @
c2463711
# frozen_string_literal: true
require
'spec_helper'
describe
Types
::
IssuableSortEnum
do
it
{
expect
(
described_class
.
graphql_name
).
to
eq
(
'IssuableSort'
)
}
it
'exposes all the existing issuable sort values'
do
expect
(
described_class
.
values
.
keys
).
to
include
(
*
%w[PRIORITY_ASC PRIORITY_DESC]
)
end
end
spec/requests/api/graphql/project/issues_spec.rb
View file @
c2463711
...
...
@@ -45,8 +45,8 @@ describe 'getting an issue list for a project' do
it
'includes discussion locked'
do
post_graphql
(
query
,
current_user:
current_user
)
expect
(
issues_data
[
0
][
'node'
][
'discussionLocked'
]).
to
eq
false
expect
(
issues_data
[
1
][
'node'
][
'discussionLocked'
]).
to
eq
true
expect
(
issues_data
[
0
][
'node'
][
'discussionLocked'
]).
to
eq
(
false
)
expect
(
issues_data
[
1
][
'node'
][
'discussionLocked'
]).
to
eq
(
true
)
end
context
'when limiting the number of results'
do
...
...
@@ -79,7 +79,7 @@ describe 'getting an issue list for a project' do
post_graphql
(
query
)
expect
(
issues_data
).
to
eq
[]
expect
(
issues_data
).
to
eq
([])
end
end
...
...
@@ -122,15 +122,15 @@ describe 'getting an issue list for a project' do
let
(
:end_cursor
)
{
graphql_data
[
'project'
][
'issues'
][
'pageInfo'
][
'endCursor'
]
}
context
'when sorting by due date'
do
let
(
:sort_project
)
{
create
(
:project
,
:public
)
}
let
_it_be
(
:sort_project
)
{
create
(
:project
,
:public
)
}
let
!
(
:due_issue1
)
{
create
(
:issue
,
project:
sort_project
,
due_date:
3
.
days
.
from_now
)
}
let
!
(
:due_issue2
)
{
create
(
:issue
,
project:
sort_project
,
due_date:
nil
)
}
let
!
(
:due_issue3
)
{
create
(
:issue
,
project:
sort_project
,
due_date:
2
.
days
.
ago
)
}
let
!
(
:due_issue4
)
{
create
(
:issue
,
project:
sort_project
,
due_date:
nil
)
}
let
!
(
:due_issue5
)
{
create
(
:issue
,
project:
sort_project
,
due_date:
1
.
day
.
ago
)
}
let
_it_be
(
:due_issue1
)
{
create
(
:issue
,
project:
sort_project
,
due_date:
3
.
days
.
from_now
)
}
let
_it_be
(
:due_issue2
)
{
create
(
:issue
,
project:
sort_project
,
due_date:
nil
)
}
let
_it_be
(
:due_issue3
)
{
create
(
:issue
,
project:
sort_project
,
due_date:
2
.
days
.
ago
)
}
let
_it_be
(
:due_issue4
)
{
create
(
:issue
,
project:
sort_project
,
due_date:
nil
)
}
let
_it_be
(
:due_issue5
)
{
create
(
:issue
,
project:
sort_project
,
due_date:
1
.
day
.
ago
)
}
let
(
:params
)
{
'sort: DUE_DATE_ASC'
}
let
_it_be
(
:params
)
{
'sort: DUE_DATE_ASC'
}
def
query
(
issue_params
=
params
)
graphql_query_for
(
...
...
@@ -160,20 +160,20 @@ describe 'getting an issue list for a project' do
context
'when ascending'
do
it
'sorts issues'
do
expect
(
grab_iids
).
to
eq
[
due_issue3
.
iid
,
due_issue5
.
iid
,
due_issue1
.
iid
,
due_issue4
.
iid
,
due_issue2
.
iid
]
expect
(
grab_iids
).
to
eq
([
due_issue3
.
iid
,
due_issue5
.
iid
,
due_issue1
.
iid
,
due_issue4
.
iid
,
due_issue2
.
iid
])
end
context
'when paginating'
do
let
(
:params
)
{
'sort: DUE_DATE_ASC, first: 2'
}
it
'sorts issues'
do
expect
(
grab_iids
).
to
eq
[
due_issue3
.
iid
,
due_issue5
.
iid
]
expect
(
grab_iids
).
to
eq
([
due_issue3
.
iid
,
due_issue5
.
iid
])
cursored_query
=
query
(
"sort: DUE_DATE_ASC, after:
\"
#{
end_cursor
}
\"
"
)
post_graphql
(
cursored_query
,
current_user:
current_user
)
response_data
=
JSON
.
parse
(
response
.
body
)[
'data'
][
'project'
][
'issues'
][
'edges'
]
expect
(
grab_iids
(
response_data
)).
to
eq
[
due_issue1
.
iid
,
due_issue4
.
iid
,
due_issue2
.
iid
]
expect
(
grab_iids
(
response_data
)).
to
eq
([
due_issue1
.
iid
,
due_issue4
.
iid
,
due_issue2
.
iid
])
end
end
end
...
...
@@ -182,35 +182,35 @@ describe 'getting an issue list for a project' do
let
(
:params
)
{
'sort: DUE_DATE_DESC'
}
it
'sorts issues'
do
expect
(
grab_iids
).
to
eq
[
due_issue1
.
iid
,
due_issue5
.
iid
,
due_issue3
.
iid
,
due_issue4
.
iid
,
due_issue2
.
iid
]
expect
(
grab_iids
).
to
eq
([
due_issue1
.
iid
,
due_issue5
.
iid
,
due_issue3
.
iid
,
due_issue4
.
iid
,
due_issue2
.
iid
])
end
context
'when paginating'
do
let
(
:params
)
{
'sort: DUE_DATE_DESC, first: 2'
}
it
'sorts issues'
do
expect
(
grab_iids
).
to
eq
[
due_issue1
.
iid
,
due_issue5
.
iid
]
expect
(
grab_iids
).
to
eq
([
due_issue1
.
iid
,
due_issue5
.
iid
])
cursored_query
=
query
(
"sort: DUE_DATE_DESC, after:
\"
#{
end_cursor
}
\"
"
)
post_graphql
(
cursored_query
,
current_user:
current_user
)
response_data
=
JSON
.
parse
(
response
.
body
)[
'data'
][
'project'
][
'issues'
][
'edges'
]
expect
(
grab_iids
(
response_data
)).
to
eq
[
due_issue3
.
iid
,
due_issue4
.
iid
,
due_issue2
.
iid
]
expect
(
grab_iids
(
response_data
)).
to
eq
([
due_issue3
.
iid
,
due_issue4
.
iid
,
due_issue2
.
iid
])
end
end
end
end
context
'when sorting by relative position'
do
let
(
:sort_project
)
{
create
(
:project
,
:public
)
}
let
_it_be
(
:sort_project
)
{
create
(
:project
,
:public
)
}
let
!
(
:relative_issue1
)
{
create
(
:issue
,
project:
sort_project
,
relative_position:
2000
)
}
let
!
(
:relative_issue2
)
{
create
(
:issue
,
project:
sort_project
,
relative_position:
nil
)
}
let
!
(
:relative_issue3
)
{
create
(
:issue
,
project:
sort_project
,
relative_position:
1000
)
}
let
!
(
:relative_issue4
)
{
create
(
:issue
,
project:
sort_project
,
relative_position:
nil
)
}
let
!
(
:relative_issue5
)
{
create
(
:issue
,
project:
sort_project
,
relative_position:
500
)
}
let
_it_be
(
:relative_issue1
)
{
create
(
:issue
,
project:
sort_project
,
relative_position:
2000
)
}
let
_it_be
(
:relative_issue2
)
{
create
(
:issue
,
project:
sort_project
,
relative_position:
nil
)
}
let
_it_be
(
:relative_issue3
)
{
create
(
:issue
,
project:
sort_project
,
relative_position:
1000
)
}
let
_it_be
(
:relative_issue4
)
{
create
(
:issue
,
project:
sort_project
,
relative_position:
nil
)
}
let
_it_be
(
:relative_issue5
)
{
create
(
:issue
,
project:
sort_project
,
relative_position:
500
)
}
let
(
:params
)
{
'sort: RELATIVE_POSITION_ASC'
}
let
_it_be
(
:params
)
{
'sort: RELATIVE_POSITION_ASC'
}
def
query
(
issue_params
=
params
)
graphql_query_for
(
...
...
@@ -228,20 +228,91 @@ describe 'getting an issue list for a project' do
context
'when ascending'
do
it
'sorts issues'
do
expect
(
grab_iids
).
to
eq
[
relative_issue5
.
iid
,
relative_issue3
.
iid
,
relative_issue1
.
iid
,
relative_issue4
.
iid
,
relative_issue2
.
iid
]
expect
(
grab_iids
).
to
eq
([
relative_issue5
.
iid
,
relative_issue3
.
iid
,
relative_issue1
.
iid
,
relative_issue4
.
iid
,
relative_issue2
.
iid
])
end
context
'when paginating'
do
let
(
:params
)
{
'sort: RELATIVE_POSITION_ASC, first: 2'
}
it
'sorts issues'
do
expect
(
grab_iids
).
to
eq
[
relative_issue5
.
iid
,
relative_issue3
.
iid
]
expect
(
grab_iids
).
to
eq
([
relative_issue5
.
iid
,
relative_issue3
.
iid
])
cursored_query
=
query
(
"sort: RELATIVE_POSITION_ASC, after:
\"
#{
end_cursor
}
\"
"
)
post_graphql
(
cursored_query
,
current_user:
current_user
)
response_data
=
JSON
.
parse
(
response
.
body
)[
'data'
][
'project'
][
'issues'
][
'edges'
]
expect
(
grab_iids
(
response_data
)).
to
eq
[
relative_issue1
.
iid
,
relative_issue4
.
iid
,
relative_issue2
.
iid
]
expect
(
grab_iids
(
response_data
)).
to
eq
([
relative_issue1
.
iid
,
relative_issue4
.
iid
,
relative_issue2
.
iid
])
end
end
end
end
context
'when sorting by priority'
do
let_it_be
(
:sort_project
)
{
create
(
:project
,
:public
)
}
let_it_be
(
:early_milestone
)
{
create
(
:milestone
,
project:
sort_project
,
due_date:
10
.
days
.
from_now
)
}
let_it_be
(
:late_milestone
)
{
create
(
:milestone
,
project:
sort_project
,
due_date:
30
.
days
.
from_now
)
}
let_it_be
(
:label_1
)
{
create
(
:label
,
project:
sort_project
,
priority:
1
)
}
let_it_be
(
:label_2
)
{
create
(
:label
,
project:
sort_project
,
priority:
5
)
}
let_it_be
(
:issue1
)
{
create
(
:issue
,
project:
sort_project
,
labels:
[
label_1
],
milestone:
late_milestone
)
}
let_it_be
(
:issue2
)
{
create
(
:issue
,
project:
sort_project
,
labels:
[
label_2
])
}
let_it_be
(
:issue3
)
{
create
(
:issue
,
project:
sort_project
,
milestone:
early_milestone
)
}
let_it_be
(
:issue4
)
{
create
(
:issue
,
project:
sort_project
)
}
let_it_be
(
:params
)
{
'sort: PRIORITY_ASC'
}
def
query
(
issue_params
=
params
)
graphql_query_for
(
'project'
,
{
'fullPath'
=>
sort_project
.
full_path
},
"issues(
#{
issue_params
}
) { pageInfo { endCursor} edges { node { iid dueDate } } }"
)
end
before
do
post_graphql
(
query
,
current_user:
current_user
)
end
it_behaves_like
'a working graphql query'
context
'when ascending'
do
it
'sorts issues'
do
expect
(
grab_iids
).
to
eq
([
issue3
.
iid
,
issue1
.
iid
,
issue2
.
iid
,
issue4
.
iid
])
end
context
'when paginating'
do
let
(
:params
)
{
'sort: PRIORITY_ASC, first: 2'
}
it
'sorts issues'
do
expect
(
grab_iids
).
to
eq
([
issue3
.
iid
,
issue1
.
iid
])
cursored_query
=
query
(
"sort: PRIORITY_ASC, after:
\"
#{
end_cursor
}
\"
"
)
post_graphql
(
cursored_query
,
current_user:
current_user
)
response_data
=
JSON
.
parse
(
response
.
body
)[
'data'
][
'project'
][
'issues'
][
'edges'
]
expect
(
grab_iids
(
response_data
)).
to
eq
([
issue2
.
iid
,
issue4
.
iid
])
end
end
end
context
'when descending'
do
let
(
:params
)
{
'sort: PRIORITY_DESC'
}
it
'sorts issues'
do
expect
(
grab_iids
).
to
eq
([
issue1
.
iid
,
issue3
.
iid
,
issue2
.
iid
,
issue4
.
iid
])
end
context
'when paginating'
do
let
(
:params
)
{
'sort: PRIORITY_DESC, first: 2'
}
it
'sorts issues'
do
expect
(
grab_iids
).
to
eq
([
issue1
.
iid
,
issue3
.
iid
])
cursored_query
=
query
(
"sort: PRIORITY_DESC, after:
\"
#{
end_cursor
}
\"
"
)
post_graphql
(
cursored_query
,
current_user:
current_user
)
response_data
=
JSON
.
parse
(
response
.
body
)[
'data'
][
'project'
][
'issues'
][
'edges'
]
expect
(
grab_iids
(
response_data
)).
to
eq
([
issue2
.
iid
,
issue4
.
iid
])
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