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
1cd7e801
Commit
1cd7e801
authored
Feb 15, 2020
by
Rajendra Kadam
Committed by
Peter Leitzen
Feb 15, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make follow up fixes for enable error tracking api
parent
90fd52b0
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
72 additions
and
41 deletions
+72
-41
app/models/error_tracking/project_error_tracking_setting.rb
app/models/error_tracking/project_error_tracking_setting.rb
+2
-0
changelogs/unreleased/error-tracking-api-followup.yml
changelogs/unreleased/error-tracking-api-followup.yml
+5
-0
spec/models/error_tracking/project_error_tracking_setting_spec.rb
...els/error_tracking/project_error_tracking_setting_spec.rb
+13
-0
spec/requests/api/error_tracking_spec.rb
spec/requests/api/error_tracking_spec.rb
+52
-41
No files found.
app/models/error_tracking/project_error_tracking_setting.rb
View file @
1cd7e801
...
...
@@ -27,6 +27,8 @@ module ErrorTracking
validates
:api_url
,
length:
{
maximum:
255
},
public_url:
{
enforce_sanitization:
true
,
ascii_only:
true
},
allow_nil:
true
validates
:enabled
,
inclusion:
{
in:
[
true
,
false
]
}
validates
:api_url
,
presence:
{
message:
'is a required field'
},
if: :enabled
validate
:validate_api_url_path
,
if: :enabled
...
...
changelogs/unreleased/error-tracking-api-followup.yml
0 → 100644
View file @
1cd7e801
---
title
:
Refactor error tracking specs and add validation to enabled field in error tracking model
merge_request
:
24892
author
:
Rajendra Kadam
type
:
added
spec/models/error_tracking/project_error_tracking_setting_spec.rb
View file @
1cd7e801
...
...
@@ -19,6 +19,19 @@ describe ErrorTracking::ProjectErrorTrackingSetting do
it
{
is_expected
.
to
allow_value
(
"http://gitlab.com/api/0/projects/project1/something"
).
for
(
:api_url
)
}
it
{
is_expected
.
not_to
allow_values
(
"http://gitlab.com/api/0/projects/project1/something€"
).
for
(
:api_url
)
}
it
'disallows non-booleans in enabled column'
do
is_expected
.
not_to
allow_value
(
nil
).
for
(
:enabled
)
end
it
'allows booleans in enabled column'
do
is_expected
.
to
allow_value
(
true
,
false
).
for
(
:enabled
)
end
it
'rejects invalid api_urls'
do
is_expected
.
not_to
allow_values
(
"https://replaceme.com/'><script>alert(document.cookie)</script>"
,
# unsafe
...
...
spec/requests/api/error_tracking_spec.rb
View file @
1cd7e801
...
...
@@ -3,13 +3,13 @@
require
'spec_helper'
describe
API
::
ErrorTracking
do
let
(
:user
)
{
create
(
:user
)
}
let
_it_be
(
:user
)
{
create
(
:user
)
}
let
(
:setting
)
{
create
(
:project_error_tracking_setting
)
}
let
(
:project
)
{
setting
.
project
}
shared_examples
'returns project settings'
do
it
'returns correct project settings'
do
subjec
t
make_reques
t
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
json_response
).
to
eq
(
...
...
@@ -23,7 +23,7 @@ describe API::ErrorTracking do
shared_examples
'returns 404'
do
it
'returns correct project settings'
do
subjec
t
make_reques
t
expect
(
response
).
to
have_gitlab_http_status
(
:not_found
)
expect
(
json_response
[
'message'
])
...
...
@@ -32,7 +32,9 @@ describe API::ErrorTracking do
end
describe
"PATCH /projects/:id/error_tracking/settings"
do
def
make_patch_request
(
**
params
)
let
(
:params
)
{
{
active:
false
}
}
def
make_request
patch
api
(
"/projects/
#{
project
.
id
}
/error_tracking/settings"
,
user
),
params:
params
end
...
...
@@ -42,28 +44,41 @@ describe API::ErrorTracking do
end
context
'patch settings'
do
subject
do
make_patch_request
(
active:
false
)
it_behaves_like
'returns project settings'
it
'updates enabled flag'
do
expect
(
setting
).
to
be_enabled
make_request
expect
(
json_response
).
to
include
(
'active'
=>
false
)
expect
(
setting
.
reload
).
not_to
be_enabled
end
it_behaves_like
'returns project settings'
context
'active is invalid'
do
let
(
:params
)
{
{
active:
"randomstring"
}
}
it
'returns active is invalid if non boolean'
do
make_patch_request
(
active:
"randomstring"
)
make_request
expect
(
response
).
to
have_gitlab_http_status
(
:bad_request
)
expect
(
json_response
[
'error'
])
.
to
eq
(
'active is invalid'
)
end
end
context
'active is empty'
do
let
(
:params
)
{
{
active:
''
}
}
it
'returns 400 if active is empty
'
do
make_patch_request
(
active:
''
)
it
'returns 400
'
do
make_request
expect
(
response
).
to
have_gitlab_http_status
(
:bad_request
)
expect
(
json_response
[
'error'
])
.
to
eq
(
'active is empty'
)
end
end
end
context
'without a project setting'
do
let
(
:project
)
{
create
(
:project
)
}
...
...
@@ -73,10 +88,6 @@ describe API::ErrorTracking do
end
context
'patch settings'
do
subject
do
make_patch_request
(
active:
true
)
end
it_behaves_like
'returns 404'
end
end
...
...
@@ -87,43 +98,51 @@ describe API::ErrorTracking do
project
.
add_reporter
(
user
)
end
it
'returns 403 for update request'
do
make_patch_request
(
active:
true
)
context
'patch request'
do
it
'returns 403'
do
make_request
expect
(
response
).
to
have_gitlab_http_status
(
:forbidden
)
end
end
end
context
'when authenticated as developer'
do
before
do
project
.
add_developer
(
user
)
end
it
'returns 403 for update request'
do
make_patch_request
(
active:
true
)
context
'patch request'
do
it
'returns 403'
do
make_request
expect
(
response
).
to
have_gitlab_http_status
(
:forbidden
)
end
end
end
context
'when authenticated as non-member'
do
it
'returns 404 for update request'
do
make_patch_request
(
active:
false
)
context
'patch request'
do
it
'returns 404'
do
make_request
expect
(
response
).
to
have_gitlab_http_status
(
:not_found
)
end
end
end
context
'when unauthenticated'
do
let
(
:user
)
{
nil
}
context
'patch request'
do
it
'returns 401 for update request'
do
make_patch_request
(
active:
true
)
make_request
expect
(
response
).
to
have_gitlab_http_status
(
:unauthorized
)
end
end
end
end
describe
"GET /projects/:id/error_tracking/settings"
do
def
make_request
...
...
@@ -136,10 +155,6 @@ describe API::ErrorTracking do
end
context
'get settings'
do
subject
do
make_request
end
it_behaves_like
'returns project settings'
end
end
...
...
@@ -152,10 +167,6 @@ describe API::ErrorTracking do
end
context
'get settings'
do
subject
do
make_request
end
it_behaves_like
'returns 404'
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