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
769b20fa
Commit
769b20fa
authored
Feb 02, 2020
by
Rajendra Kadam
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add partial update method to update service and refactor specs
parent
988e0b53
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
130 additions
and
36 deletions
+130
-36
app/services/projects/operations/update_service.rb
app/services/projects/operations/update_service.rb
+21
-0
lib/api/error_tracking.rb
lib/api/error_tracking.rb
+11
-12
spec/factories/project_error_tracking_settings.rb
spec/factories/project_error_tracking_settings.rb
+4
-0
spec/requests/api/error_tracking_spec.rb
spec/requests/api/error_tracking_spec.rb
+59
-24
spec/services/projects/operations/update_service_spec.rb
spec/services/projects/operations/update_service_spec.rb
+35
-0
No files found.
app/services/projects/operations/update_service.rb
View file @
769b20fa
...
@@ -30,6 +30,27 @@ module Projects
...
@@ -30,6 +30,27 @@ module Projects
settings
=
params
[
:error_tracking_setting_attributes
]
settings
=
params
[
:error_tracking_setting_attributes
]
return
{}
if
settings
.
blank?
return
{}
if
settings
.
blank?
if
error_tracking_params_partial_updates?
(
settings
)
error_tracking_params_for_partial_update
(
settings
)
else
error_tracking_params_for_update
(
settings
)
end
end
def
error_tracking_params_partial_updates?
(
settings
)
# Help from @splattael :bow:
# Make sure we're converting to symbols because
# * ActionController::Parameters#keys returns a list of strings
# * in specs we're using hashes with symbols as keys
settings
.
keys
.
map
(
&
:to_sym
)
==
%i[enabled]
end
def
error_tracking_params_for_partial_update
(
settings
)
{
error_tracking_setting_attributes:
settings
}
end
def
error_tracking_params_for_update
(
settings
)
api_url
=
::
ErrorTracking
::
ProjectErrorTrackingSetting
.
build_api_url_from
(
api_url
=
::
ErrorTracking
::
ProjectErrorTrackingSetting
.
build_api_url_from
(
api_host:
settings
[
:api_host
],
api_host:
settings
[
:api_host
],
project_slug:
settings
.
dig
(
:project
,
:slug
),
project_slug:
settings
.
dig
(
:project
,
:slug
),
...
...
lib/api/error_tracking.rb
View file @
769b20fa
...
@@ -39,18 +39,17 @@ module API
...
@@ -39,18 +39,17 @@ module API
not_found!
(
'Error Tracking Setting'
)
unless
setting
not_found!
(
'Error Tracking Setting'
)
unless
setting
# update_params = {
update_params
=
{
# error_tracking_setting_attributes: { enabled: params[:active] }
error_tracking_setting_attributes:
{
enabled:
params
[
:active
]
}
# }
}
# result = ::Projects::Operations::UpdateService.new(user_project, current_user, update_params).execute
result
=
::
Projects
::
Operations
::
UpdateService
.
new
(
user_project
,
current_user
,
update_params
).
execute
setting
.
enabled
=
params
[
:active
]
setting
.
save!
if
result
[
:status
]
==
:success
# if result[:status] == :success
present
setting
,
with:
Entities
::
ErrorTracking
::
ProjectSetting
present
setting
,
with:
Entities
::
ErrorTracking
::
ProjectSetting
else
# else
result
# result
end
# end
end
end
end
end
end
end
...
...
spec/factories/project_error_tracking_settings.rb
View file @
769b20fa
...
@@ -8,5 +8,9 @@ FactoryBot.define do
...
@@ -8,5 +8,9 @@ FactoryBot.define do
token
{
'access_token_123'
}
token
{
'access_token_123'
}
project_name
{
'Sentry Project'
}
project_name
{
'Sentry Project'
}
organization_name
{
'Sentry Org'
}
organization_name
{
'Sentry Org'
}
trait
:disabled
do
enabled
{
false
}
end
end
end
end
end
spec/requests/api/error_tracking_spec.rb
View file @
769b20fa
...
@@ -17,52 +17,87 @@ describe API::ErrorTracking do
...
@@ -17,52 +17,87 @@ describe API::ErrorTracking do
end
end
context
'when authenticated as maintainer'
do
context
'when authenticated as maintainer'
do
shared_examples
'returns project settings'
do
it
'returns correct project settings'
do
subject
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
json_response
).
to
eq
(
'active'
=>
setting
.
reload
.
enabled
,
'project_name'
=>
setting
.
project_name
,
'sentry_external_url'
=>
setting
.
sentry_external_url
,
'api_url'
=>
setting
.
api_url
)
end
end
before
do
before
do
project
.
add_maintainer
(
user
)
project
.
add_maintainer
(
user
)
end
end
it
'returns project settings'
do
context
'get settings'
do
make_request
subject
do
make_request
end
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
it_behaves_like
'returns project settings'
expect
(
json_response
).
to
eq
(
'active'
=>
setting
.
enabled
,
'project_name'
=>
setting
.
project_name
,
'sentry_external_url'
=>
setting
.
sentry_external_url
,
'api_url'
=>
setting
.
api_url
)
end
end
it
'returns active is invalid if non boolean'
do
context
'patch settings'
do
make_patch_request
(
"randomstring"
)
subject
do
make_patch_request
(
true
)
end
it_behaves_like
'returns project settings'
expect
(
response
).
to
have_gitlab_http_status
(
:bad_request
)
subject
do
expect
(
json_response
[
'error'
])
make_patch_request
(
false
)
.
to
eq
(
'active is invalid'
)
end
it_behaves_like
'returns project settings'
it
'returns active is invalid if non boolean'
do
make_patch_request
(
"randomstring"
)
expect
(
response
).
to
have_gitlab_http_status
(
:bad_request
)
expect
(
json_response
[
'error'
])
.
to
eq
(
'active is invalid'
)
end
end
end
end
end
context
'without a project setting'
do
context
'without a project setting'
do
let
(
:project
)
{
create
(
:project
)
}
let
(
:project
)
{
create
(
:project
)
}
shared_examples
'returns 404'
do
it
'returns correct project settings'
do
subject
expect
(
response
).
to
have_gitlab_http_status
(
:not_found
)
expect
(
json_response
[
'message'
])
.
to
eq
(
'404 Error Tracking Setting Not Found'
)
end
end
before
do
before
do
project
.
add_maintainer
(
user
)
project
.
add_maintainer
(
user
)
end
end
it
'returns 404'
do
context
'get settings'
do
make_request
subject
do
make_request
end
expect
(
response
).
to
have_gitlab_http_status
(
:not_found
)
it_behaves_like
'returns 404'
expect
(
json_response
[
'message'
])
.
to
eq
(
'404 Error Tracking Setting Not Found'
)
end
end
it
'returns 404 for update request'
do
context
'patch settings'
do
make_patch_request
(
true
)
subject
do
make_patch_request
(
true
)
end
expect
(
response
).
to
have_gitlab_http_status
(
:not_found
)
it_behaves_like
'returns 404'
expect
(
json_response
[
'message'
])
.
to
eq
(
'404 Error Tracking Setting Not Found'
)
end
end
end
end
...
...
spec/services/projects/operations/update_service_spec.rb
View file @
769b20fa
...
@@ -145,6 +145,41 @@ describe Projects::Operations::UpdateService do
...
@@ -145,6 +145,41 @@ describe Projects::Operations::UpdateService do
end
end
end
end
context
'partial_update'
do
let
(
:params
)
{
{
error_tracking_setting_attributes:
{
enabled:
true
}
}
}
context
'with setting'
do
before
do
create
(
:project_error_tracking_setting
,
:disabled
,
project:
project
)
end
it
'service succeeds'
do
expect
(
result
[
:status
]).
to
eq
(
:success
)
end
it
'updates attributes'
do
expect
{
result
}
.
to
change
{
project
.
reload
.
error_tracking_setting
.
enabled
}
.
from
(
false
)
.
to
(
true
)
end
end
context
'without setting'
do
it
'does not create a setting'
do
expect
(
result
[
:status
]).
to
eq
(
:error
)
expect
(
project
.
reload
.
error_tracking_setting
).
to
be_nil
end
end
end
context
'with masked param token'
do
context
'with masked param token'
do
let
(
:params
)
do
let
(
:params
)
do
{
{
...
...
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