Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-02-05 21:09:06 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2020-02-05 21:09:06 +0300
commitb042382bbf5a4977c5b5c6b0a9a33f4e8ca8d16d (patch)
treede31671ab7c6ca8c2a3721cbabd1f2a42b3d0194 /spec/requests/api/error_tracking_spec.rb
parenteabf8fd774fef6a54903e5141138f47bdafeb331 (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/requests/api/error_tracking_spec.rb')
-rw-r--r--spec/requests/api/error_tracking_spec.rb162
1 files changed, 144 insertions, 18 deletions
diff --git a/spec/requests/api/error_tracking_spec.rb b/spec/requests/api/error_tracking_spec.rb
index 48ddc7f5a75..059744898b8 100644
--- a/spec/requests/api/error_tracking_spec.rb
+++ b/spec/requests/api/error_tracking_spec.rb
@@ -3,11 +3,129 @@
require 'spec_helper'
describe API::ErrorTracking do
- describe "GET /projects/:id/error_tracking/settings" do
- let(:user) { create(:user) }
- let(:setting) { create(:project_error_tracking_setting) }
- let(:project) { setting.project }
+ let(: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
+ 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
+
+ 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
+
+ describe "PATCH /projects/:id/error_tracking/settings" do
+ def make_patch_request(**params)
+ patch api("/projects/#{project.id}/error_tracking/settings", user), params: params
+ end
+
+ context 'when authenticated as maintainer' do
+ before do
+ project.add_maintainer(user)
+ end
+
+ context 'patch settings' do
+ subject do
+ make_patch_request(active: false)
+ end
+
+ it_behaves_like 'returns project settings'
+
+ it 'returns active is invalid if non boolean' do
+ make_patch_request(active: "randomstring")
+
+ expect(response).to have_gitlab_http_status(:bad_request)
+ expect(json_response['error'])
+ .to eq('active is invalid')
+ end
+
+ it 'returns 400 if active is empty' do
+ make_patch_request(active: '')
+ expect(response).to have_gitlab_http_status(:bad_request)
+ expect(json_response['error'])
+ .to eq('active is empty')
+ end
+ end
+
+ context 'without a project setting' do
+ let(:project) { create(:project) }
+
+ before do
+ project.add_maintainer(user)
+ end
+
+ context 'patch settings' do
+ subject do
+ make_patch_request(active: true)
+ end
+
+ it_behaves_like 'returns 404'
+ end
+ end
+ end
+
+ context 'when authenticated as reporter' do
+ before do
+ project.add_reporter(user)
+ end
+
+ it 'returns 403 for update request' do
+ make_patch_request(active: true)
+
+ expect(response).to have_gitlab_http_status(:forbidden)
+ 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)
+
+ expect(response).to have_gitlab_http_status(:forbidden)
+ end
+ end
+
+ context 'when authenticated as non-member' do
+ it 'returns 404 for update request' do
+ make_patch_request(active: false)
+
+ expect(response).to have_gitlab_http_status(:not_found)
+ end
+ end
+
+ context 'when unauthenticated' do
+ let(:user) { nil }
+
+ it 'returns 401 for update request' do
+ make_patch_request(active: true)
+
+ expect(response).to have_gitlab_http_status(:unauthorized)
+ end
+ end
+ end
+
+ describe "GET /projects/:id/error_tracking/settings" do
def make_request
get api("/projects/#{project.id}/error_tracking/settings", user)
end
@@ -17,16 +135,12 @@ describe API::ErrorTracking do
project.add_maintainer(user)
end
- it 'returns project settings' do
- make_request
+ context 'get settings' do
+ subject do
+ make_request
+ end
- expect(response).to have_gitlab_http_status(:ok)
- 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
- )
+ it_behaves_like 'returns project settings'
end
end
@@ -37,12 +151,12 @@ describe API::ErrorTracking do
project.add_maintainer(user)
end
- it 'returns 404' do
- make_request
+ context 'get settings' do
+ subject do
+ make_request
+ end
- expect(response).to have_gitlab_http_status(:not_found)
- expect(json_response['message'])
- .to eq('404 Error Tracking Setting Not Found')
+ it_behaves_like 'returns 404'
end
end
@@ -58,6 +172,18 @@ describe API::ErrorTracking do
end
end
+ context 'when authenticated as developer' do
+ before do
+ project.add_developer(user)
+ end
+
+ it 'returns 403' do
+ make_request
+
+ expect(response).to have_gitlab_http_status(:forbidden)
+ end
+ end
+
context 'when authenticated as non-member' do
it 'returns 404' do
make_request