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
0
Merge Requests
0
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
Léo-Paul Géneau
gitlab-ce
Commits
8c126525
Commit
8c126525
authored
Nov 01, 2018
by
Brett Walker
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Extract code into IssueBoardEntity
parent
c6d4449f
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
155 additions
and
34 deletions
+155
-34
app/controllers/boards/issues_controller.rb
app/controllers/boards/issues_controller.rb
+5
-11
app/models/issue.rb
app/models/issue.rb
+0
-14
app/serializers/README.md
app/serializers/README.md
+2
-2
app/serializers/issue_board_entity.rb
app/serializers/issue_board_entity.rb
+51
-0
app/serializers/issue_serializer.rb
app/serializers/issue_serializer.rb
+4
-2
app/serializers/label_entity.rb
app/serializers/label_entity.rb
+4
-0
spec/controllers/boards/issues_controller_spec.rb
spec/controllers/boards/issues_controller_spec.rb
+3
-3
spec/fixtures/api/schemas/entities/issue_board.json
spec/fixtures/api/schemas/entities/issue_board.json
+38
-0
spec/fixtures/api/schemas/entities/issue_boards.json
spec/fixtures/api/schemas/entities/issue_boards.json
+15
-0
spec/models/concerns/awardable_spec.rb
spec/models/concerns/awardable_spec.rb
+2
-2
spec/serializers/issue_board_entity_spec.rb
spec/serializers/issue_board_entity_spec.rb
+23
-0
spec/serializers/issue_serializer_spec.rb
spec/serializers/issue_serializer_spec.rb
+8
-0
No files found.
app/controllers/boards/issues_controller.rb
View file @
8c126525
...
@@ -100,18 +100,12 @@ module Boards
...
@@ -100,18 +100,12 @@ module Boards
.
merge
(
board_id:
params
[
:board_id
],
list_id:
params
[
:list_id
],
request:
request
)
.
merge
(
board_id:
params
[
:board_id
],
list_id:
params
[
:list_id
],
request:
request
)
end
end
def
serializer
IssueSerializer
.
new
(
current_user:
current_user
)
end
def
serialize_as_json
(
resource
)
def
serialize_as_json
(
resource
)
resource
.
as_json
(
serializer
.
represent
(
resource
,
serializer:
'board'
,
include_full_project_path:
board
.
group_board?
)
only:
[
:id
,
:iid
,
:project_id
,
:title
,
:confidential
,
:due_date
,
:relative_position
,
:weight
],
labels:
true
,
issue_endpoints:
true
,
include_full_project_path:
board
.
group_board?
,
include:
{
project:
{
only:
[
:id
,
:path
]
},
assignees:
{
only:
[
:id
,
:name
,
:username
],
methods:
[
:avatar_url
]
},
milestone:
{
only:
[
:id
,
:title
]
}
}
)
end
end
def
whitelist_query_limiting
def
whitelist_query_limiting
...
...
app/models/issue.rb
View file @
8c126525
...
@@ -231,20 +231,6 @@ class Issue < ActiveRecord::Base
...
@@ -231,20 +231,6 @@ class Issue < ActiveRecord::Base
def
as_json
(
options
=
{})
def
as_json
(
options
=
{})
super
(
options
).
tap
do
|
json
|
super
(
options
).
tap
do
|
json
|
if
options
.
key?
(
:issue_endpoints
)
&&
project
url_helper
=
Gitlab
::
Routing
.
url_helpers
issue_reference
=
options
[
:include_full_project_path
]
?
to_reference
(
full:
true
)
:
to_reference
json
.
merge!
(
reference_path:
issue_reference
,
real_path:
url_helper
.
project_issue_path
(
project
,
self
),
issue_sidebar_endpoint:
url_helper
.
project_issue_path
(
project
,
self
,
format: :json
,
serializer:
'sidebar'
),
toggle_subscription_endpoint:
url_helper
.
toggle_subscription_project_issue_path
(
project
,
self
),
assignable_labels_endpoint:
url_helper
.
project_labels_path
(
project
,
format: :json
,
include_ancestor_groups:
true
)
)
end
if
options
.
key?
(
:labels
)
if
options
.
key?
(
:labels
)
json
[
:labels
]
=
labels
.
as_json
(
json
[
:labels
]
=
labels
.
as_json
(
project:
project
,
project:
project
,
...
...
app/serializers/README.md
View file @
8c126525
...
@@ -180,7 +180,7 @@ def index
...
@@ -180,7 +180,7 @@ def index
render
json:
MyResourceSerializer
render
json:
MyResourceSerializer
.
new
(
current_user:
@current_user
)
.
new
(
current_user:
@current_user
)
.
represent_details
(
@project
.
resources
)
.
represent_details
(
@project
.
resources
)
nd
e
nd
end
end
```
```
...
@@ -196,7 +196,7 @@ def index
...
@@ -196,7 +196,7 @@ def index
.
represent_details
(
@project
.
resources
),
.
represent_details
(
@project
.
resources
),
count:
@project
.
resources
.
count
count:
@project
.
resources
.
count
}
}
nd
e
nd
end
end
```
```
...
...
app/serializers/issue_board_entity.rb
0 → 100644
View file @
8c126525
# frozen_string_literal: true
class
IssueBoardEntity
<
Grape
::
Entity
include
RequestAwareEntity
expose
:id
expose
:iid
expose
:title
expose
:confidential
expose
:due_date
expose
:project_id
expose
:relative_position
expose
:weight
,
if:
->
(
*
)
{
respond_to?
(
:weight
)
}
expose
:project
do
|
issue
|
API
::
Entities
::
Project
.
represent
issue
.
project
,
only:
[
:id
,
:path
]
end
expose
:milestone
,
expose_nil:
false
do
|
issue
|
API
::
Entities
::
Project
.
represent
issue
.
milestone
,
only:
[
:id
,
:title
]
end
expose
:assignees
do
|
issue
|
API
::
Entities
::
UserBasic
.
represent
issue
.
assignees
,
only:
[
:id
,
:name
,
:username
,
:avatar_url
]
end
expose
:labels
do
|
issue
|
LabelEntity
.
represent
issue
.
labels
,
project:
issue
.
project
,
only:
[
:id
,
:title
,
:description
,
:color
,
:priority
,
:text_color
]
end
expose
:reference_path
,
if:
->
(
issue
)
{
issue
.
project
}
do
|
issue
,
options
|
options
[
:include_full_project_path
]
?
issue
.
to_reference
(
full:
true
)
:
issue
.
to_reference
end
expose
:real_path
,
if:
->
(
issue
)
{
issue
.
project
}
do
|
issue
|
project_issue_path
(
issue
.
project
,
issue
)
end
expose
:issue_sidebar_endpoint
,
if:
->
(
issue
)
{
issue
.
project
}
do
|
issue
|
project_issue_path
(
issue
.
project
,
issue
,
format: :json
,
serializer:
'sidebar'
)
end
expose
:toggle_subscription_endpoint
,
if:
->
(
issue
)
{
issue
.
project
}
do
|
issue
|
toggle_subscription_project_issue_path
(
issue
.
project
,
issue
)
end
expose
:assignable_labels_endpoint
,
if:
->
(
issue
)
{
issue
.
project
}
do
|
issue
|
project_labels_path
(
issue
.
project
,
format: :json
,
include_ancestor_groups:
true
)
end
end
app/serializers/issue_serializer.rb
View file @
8c126525
...
@@ -4,15 +4,17 @@ class IssueSerializer < BaseSerializer
...
@@ -4,15 +4,17 @@ class IssueSerializer < BaseSerializer
# This overrided method takes care of which entity should be used
# This overrided method takes care of which entity should be used
# to serialize the `issue` based on `basic` key in `opts` param.
# to serialize the `issue` based on `basic` key in `opts` param.
# Hence, `entity` doesn't need to be declared on the class scope.
# Hence, `entity` doesn't need to be declared on the class scope.
def
represent
(
merge_request
,
opts
=
{})
def
represent
(
issue
,
opts
=
{})
entity
=
entity
=
case
opts
[
:serializer
]
case
opts
[
:serializer
]
when
'sidebar'
when
'sidebar'
IssueSidebarEntity
IssueSidebarEntity
when
'board'
IssueBoardEntity
else
else
IssueEntity
IssueEntity
end
end
super
(
merge_request
,
opts
,
entity
)
super
(
issue
,
opts
,
entity
)
end
end
end
end
app/serializers/label_entity.rb
View file @
8c126525
...
@@ -12,4 +12,8 @@ class LabelEntity < Grape::Entity
...
@@ -12,4 +12,8 @@ class LabelEntity < Grape::Entity
expose
:text_color
expose
:text_color
expose
:created_at
expose
:created_at
expose
:updated_at
expose
:updated_at
expose
:priority
,
if:
->
(
*
)
{
options
.
key?
(
:project
)
}
do
|
label
|
label
.
priority
(
options
[
:project
])
end
end
end
spec/controllers/boards/issues_controller_spec.rb
View file @
8c126525
...
@@ -50,7 +50,7 @@ describe Boards::IssuesController do
...
@@ -50,7 +50,7 @@ describe Boards::IssuesController do
parsed_response
=
JSON
.
parse
(
response
.
body
)
parsed_response
=
JSON
.
parse
(
response
.
body
)
expect
(
response
).
to
match_response_schema
(
'
issue
s'
)
expect
(
response
).
to
match_response_schema
(
'
entities/issue_board
s'
)
expect
(
parsed_response
[
'issues'
].
length
).
to
eq
2
expect
(
parsed_response
[
'issues'
].
length
).
to
eq
2
expect
(
development
.
issues
.
map
(
&
:relative_position
)).
not_to
include
(
nil
)
expect
(
development
.
issues
.
map
(
&
:relative_position
)).
not_to
include
(
nil
)
end
end
...
@@ -121,7 +121,7 @@ describe Boards::IssuesController do
...
@@ -121,7 +121,7 @@ describe Boards::IssuesController do
parsed_response
=
JSON
.
parse
(
response
.
body
)
parsed_response
=
JSON
.
parse
(
response
.
body
)
expect
(
response
).
to
match_response_schema
(
'
issue
s'
)
expect
(
response
).
to
match_response_schema
(
'
entities/issue_board
s'
)
expect
(
parsed_response
[
'issues'
].
length
).
to
eq
2
expect
(
parsed_response
[
'issues'
].
length
).
to
eq
2
end
end
end
end
...
@@ -168,7 +168,7 @@ describe Boards::IssuesController do
...
@@ -168,7 +168,7 @@ describe Boards::IssuesController do
it
'returns the created issue'
do
it
'returns the created issue'
do
create_issue
user:
user
,
board:
board
,
list:
list1
,
title:
'New issue'
create_issue
user:
user
,
board:
board
,
list:
list1
,
title:
'New issue'
expect
(
response
).
to
match_response_schema
(
'
issue
'
)
expect
(
response
).
to
match_response_schema
(
'
entities/issue_board
'
)
end
end
end
end
...
...
spec/fixtures/api/schemas/entities/issue_board.json
0 → 100644
View file @
8c126525
{
"type"
:
"object"
,
"properties"
:
{
"id"
:
{
"type"
:
"integer"
},
"iid"
:
{
"type"
:
"integer"
},
"title"
:
{
"type"
:
"string"
},
"confidential"
:
{
"type"
:
"boolean"
},
"due_date"
:
{
"type"
:
"date"
},
"project_id"
:
{
"type"
:
"integer"
},
"relative_position"
:
{
"type"
:
[
"integer"
,
"null"
]
},
"weight"
:
{
"type"
:
"integer"
},
"project"
:
{
"type"
:
"object"
,
"properties"
:
{
"id"
:
{
"type"
:
"integer"
},
"path"
:
{
"type"
:
"string"
}
}
},
"milestone"
:
{
"type"
:
"object"
,
"properties"
:
{
"id"
:
{
"type"
:
"integer"
},
"title"
:
{
"type"
:
"string"
}
}
},
"assignees"
:
{
"type"
:
[
"array"
,
"null"
]
},
"labels"
:
{
"type"
:
"array"
,
"items"
:
{
"$ref"
:
"label.json"
}
},
"reference_path"
:
{
"type"
:
"string"
},
"real_path"
:
{
"type"
:
"string"
},
"issue_sidebar_endpoint"
:
{
"type"
:
"string"
},
"toggle_subscription_endpoint"
:
{
"type"
:
"string"
},
"assignable_labels_endpoint"
:
{
"type"
:
"string"
}
},
"additionalProperties"
:
false
}
spec/fixtures/api/schemas/entities/issue_boards.json
0 → 100644
View file @
8c126525
{
"type"
:
"object"
,
"required"
:
[
"issues"
,
"size"
],
"properties"
:
{
"issues"
:
{
"type"
:
"array"
,
"items"
:
{
"$ref"
:
"issue_board.json"
}
},
"size"
:
{
"type"
:
"integer"
}
},
"additionalProperties"
:
false
}
spec/models/concerns/awardable_spec.rb
View file @
8c126525
...
@@ -37,8 +37,8 @@ describe Awardable do
...
@@ -37,8 +37,8 @@ describe Awardable do
create
(
:award_emoji
,
awardable:
issue3
,
name:
"star"
,
user:
award_emoji
.
user
)
create
(
:award_emoji
,
awardable:
issue3
,
name:
"star"
,
user:
award_emoji
.
user
)
create
(
:award_emoji
,
awardable:
issue3
,
name:
"star"
,
user:
award_emoji2
.
user
)
create
(
:award_emoji
,
awardable:
issue3
,
name:
"star"
,
user:
award_emoji2
.
user
)
expect
(
Issue
.
awarded
(
award_emoji
.
user
)).
to
eq
[
issue
,
issue3
]
expect
(
Issue
.
awarded
(
award_emoji
.
user
)).
to
contain_exactly
(
issue
,
issue3
)
expect
(
Issue
.
awarded
(
award_emoji2
.
user
)).
to
eq
[
issue2
,
issue3
]
expect
(
Issue
.
awarded
(
award_emoji2
.
user
)).
to
contain_exactly
(
issue2
,
issue3
)
end
end
end
end
...
...
spec/serializers/issue_board_entity_spec.rb
0 → 100644
View file @
8c126525
# frozen_string_literal: true
require
'spec_helper'
describe
IssueBoardEntity
do
let
(
:project
)
{
create
(
:project
)
}
let
(
:resource
)
{
create
(
:issue
,
project:
project
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:request
)
{
double
(
'request'
,
current_user:
user
)
}
subject
{
described_class
.
new
(
resource
,
request:
request
).
as_json
}
it
'has basic attributes'
do
expect
(
subject
).
to
include
(
:id
,
:iid
,
:title
,
:confidential
,
:due_date
,
:project_id
,
:relative_position
,
:project
,
:labels
)
end
it
'has path and endpoints'
do
expect
(
subject
).
to
include
(
:reference_path
,
:real_path
,
:issue_sidebar_endpoint
,
:toggle_subscription_endpoint
,
:assignable_labels_endpoint
)
end
end
spec/serializers/issue_serializer_spec.rb
View file @
8c126525
...
@@ -24,4 +24,12 @@ describe IssueSerializer do
...
@@ -24,4 +24,12 @@ describe IssueSerializer do
expect
(
json_entity
).
to
match_schema
(
'entities/issue_sidebar'
)
expect
(
json_entity
).
to
match_schema
(
'entities/issue_sidebar'
)
end
end
end
end
context
'board issue serialization'
do
let
(
:serializer
)
{
'board'
}
it
'matches board issue json schema'
do
expect
(
json_entity
).
to
match_schema
(
'entities/issue_board'
)
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