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
Boxiang Sun
gitlab-ce
Commits
a96507bf
Commit
a96507bf
authored
5 years ago
by
Lin Jen-Shin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Introduce ServiceResponse to wrap around response
See
https://gitlab.com/gitlab-org/gitlab-ce/issues/60730
parent
98f898d3
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
108 additions
and
22 deletions
+108
-22
app/controllers/projects/branches_controller.rb
app/controllers/projects/branches_controller.rb
+4
-4
app/services/delete_branch_service.rb
app/services/delete_branch_service.rb
+11
-13
app/services/service_response.rb
app/services/service_response.rb
+31
-0
lib/api/branches.rb
lib/api/branches.rb
+2
-2
spec/services/delete_branch_service_spec.rb
spec/services/delete_branch_service_spec.rb
+3
-3
spec/services/service_response_spec.rb
spec/services/service_response_spec.rb
+57
-0
No files found.
app/controllers/projects/branches_controller.rb
View file @
a96507bf
...
...
@@ -100,14 +100,14 @@ class Projects::BranchesController < Projects::ApplicationController
respond_to
do
|
format
|
format
.
html
do
flash_type
=
result
[
:status
]
==
:error
?
:alert
:
:notice
flash
[
flash_type
]
=
result
[
:message
]
flash_type
=
result
.
error?
?
:alert
:
:notice
flash
[
flash_type
]
=
result
.
message
redirect_to
project_branches_path
(
@project
),
status: :see_other
end
format
.
js
{
head
result
[
:return_code
]
}
format
.
json
{
render
json:
{
message:
result
[
:message
]
},
status:
result
[
:return_code
]
}
format
.
js
{
head
result
.
http_status
}
format
.
json
{
render
json:
{
message:
result
.
message
},
status:
result
.
http_status
}
end
end
...
...
This diff is collapsed.
Click to expand it.
app/services/delete_branch_service.rb
View file @
a96507bf
...
...
@@ -6,27 +6,25 @@ class DeleteBranchService < BaseService
branch
=
repository
.
find_branch
(
branch_name
)
unless
current_user
.
can?
(
:push_code
,
project
)
return
error
(
'You dont have push access to repo'
,
405
)
return
ServiceResponse
.
error
(
message:
'You dont have push access to repo'
,
http_status:
405
)
end
unless
branch
return
error
(
'No such branch'
,
404
)
return
ServiceResponse
.
error
(
message:
'No such branch'
,
http_status:
404
)
end
if
repository
.
rm_branch
(
current_user
,
branch_name
)
success
(
'Branch was deleted'
)
ServiceResponse
.
success
(
message:
'Branch was deleted'
)
else
error
(
'Failed to remove branch'
)
ServiceResponse
.
error
(
message:
'Failed to remove branch'
,
http_status:
400
)
end
rescue
Gitlab
::
Git
::
PreReceiveError
=>
ex
error
(
ex
.
message
)
end
def
error
(
message
,
return_code
=
400
)
super
(
message
).
merge
(
return_code:
return_code
)
end
def
success
(
message
)
super
().
merge
(
message:
message
)
ServiceResponse
.
error
(
message:
ex
.
message
,
http_status:
400
)
end
end
This diff is collapsed.
Click to expand it.
app/services/service_response.rb
0 → 100644
View file @
a96507bf
# frozen_string_literal: true
class
ServiceResponse
def
self
.
success
(
message:
nil
)
new
(
status: :success
,
message:
message
)
end
def
self
.
error
(
message
:,
http_status:
nil
)
new
(
status: :error
,
message:
message
,
http_status:
http_status
)
end
attr_reader
:status
,
:message
,
:http_status
def
initialize
(
status
:,
message:
nil
,
http_status:
nil
)
self
.
status
=
status
self
.
message
=
message
self
.
http_status
=
http_status
end
def
success?
status
==
:success
end
def
error?
status
==
:error
end
private
attr_writer
:status
,
:message
,
:http_status
end
This diff is collapsed.
Click to expand it.
lib/api/branches.rb
View file @
a96507bf
...
...
@@ -162,8 +162,8 @@ module API
result
=
DeleteBranchService
.
new
(
user_project
,
current_user
)
.
execute
(
params
[
:branch
])
if
result
[
:status
]
!=
:success
render_api_error!
(
result
[
:message
],
result
[
:return_code
]
)
if
result
.
error?
render_api_error!
(
result
.
message
,
result
.
http_status
)
end
end
end
...
...
This diff is collapsed.
Click to expand it.
spec/services/delete_branch_service_spec.rb
View file @
a96507bf
...
...
@@ -19,7 +19,7 @@ describe DeleteBranchService do
result
=
service
.
execute
(
'feature'
)
expect
(
result
[
:status
]
).
to
eq
:success
expect
(
result
.
status
).
to
eq
:success
expect
(
branch_exists?
(
'feature'
)).
to
be
false
end
end
...
...
@@ -30,8 +30,8 @@ describe DeleteBranchService do
result
=
service
.
execute
(
'feature'
)
expect
(
result
[
:status
]
).
to
eq
:error
expect
(
result
[
:message
]
).
to
eq
'You dont have push access to repo'
expect
(
result
.
status
).
to
eq
:error
expect
(
result
.
message
).
to
eq
'You dont have push access to repo'
expect
(
branch_exists?
(
'feature'
)).
to
be
true
end
end
...
...
This diff is collapsed.
Click to expand it.
spec/services/service_response_spec.rb
0 → 100644
View file @
a96507bf
# frozen_string_literal: true
require
'fast_spec_helper'
ActiveSupport
::
Dependencies
.
autoload_paths
<<
'app/services'
describe
ServiceResponse
do
describe
'.success'
do
it
'creates a successful response without a message'
do
expect
(
described_class
.
success
).
to
be_success
end
it
'creates a successful response with a message'
do
response
=
described_class
.
success
(
message:
'Good orange'
)
expect
(
response
).
to
be_success
expect
(
response
.
message
).
to
eq
(
'Good orange'
)
end
end
describe
'.error'
do
it
'creates a failed response without HTTP status'
do
response
=
described_class
.
error
(
message:
'Bad apple'
)
expect
(
response
).
to
be_error
expect
(
response
.
message
).
to
eq
(
'Bad apple'
)
end
it
'creates a failed response with HTTP status'
do
response
=
described_class
.
error
(
message:
'Bad apple'
,
http_status:
400
)
expect
(
response
).
to
be_error
expect
(
response
.
message
).
to
eq
(
'Bad apple'
)
expect
(
response
.
http_status
).
to
eq
(
400
)
end
end
describe
'#success?'
do
it
'returns true for a successful response'
do
expect
(
described_class
.
success
.
success?
).
to
eq
(
true
)
end
it
'returns false for a failed response'
do
expect
(
described_class
.
error
(
message:
'Bad apple'
).
success?
).
to
eq
(
false
)
end
end
describe
'#error?'
do
it
'returns false for a successful response'
do
expect
(
described_class
.
success
.
error?
).
to
eq
(
false
)
end
it
'returns true for a failed response'
do
expect
(
described_class
.
error
(
message:
'Bad apple'
).
error?
).
to
eq
(
true
)
end
end
end
This diff is collapsed.
Click to expand it.
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