Commit d1234bb2 authored by Kamil Trzciński's avatar Kamil Trzciński

Merge branch 'mc/cleanup-metrics-ff' into 'master'

Remove Metrics feature flag gate

Closes #9788

See merge request gitlab-org/gitlab-ee!11131
parents d6d93fe2 6635c5f0
...@@ -43,10 +43,6 @@ module EE ...@@ -43,10 +43,6 @@ module EE
end end
def metrics_reports def metrics_reports
unless ::Feature.enabled?(:metrics_reports, project)
return render json: '', status: :bad_request
end
reports_response(merge_request.compare_metrics_reports) reports_response(merge_request.compare_metrics_reports)
end end
......
...@@ -403,6 +403,8 @@ describe Projects::MergeRequestsController do ...@@ -403,6 +403,8 @@ describe Projects::MergeRequestsController do
end end
describe 'GET #metrics_reports' do describe 'GET #metrics_reports' do
let(:merge_request) { create(:ee_merge_request, :with_metrics_reports, source_project: project, author: create(:user)) }
let(:params) do let(:params) do
{ {
namespace_id: project.namespace.to_param, namespace_id: project.namespace.to_param,
...@@ -413,91 +415,75 @@ describe Projects::MergeRequestsController do ...@@ -413,91 +415,75 @@ describe Projects::MergeRequestsController do
subject { get :metrics_reports, params: params, format: :json } subject { get :metrics_reports, params: params, format: :json }
context 'when feature is enabled' do before do
let(:merge_request) { create(:ee_merge_request, :with_metrics_reports, source_project: project, author: create(:user)) } allow_any_instance_of(::MergeRequest).to receive(:compare_reports)
.with(::Ci::CompareMetricsReportsService).and_return(comparison_status)
before do end
allow_any_instance_of(::MergeRequest).to receive(:compare_reports)
.with(::Ci::CompareMetricsReportsService).and_return(comparison_status)
end
context 'when comparison is being processed' do
let(:comparison_status) { { status: :parsing } }
it 'sends polling interval' do
expect(::Gitlab::PollingInterval).to receive(:set_header)
subject context 'when comparison is being processed' do
end let(:comparison_status) { { status: :parsing } }
it 'returns 204 HTTP status' do it 'sends polling interval' do
subject expect(::Gitlab::PollingInterval).to receive(:set_header)
expect(response).to have_gitlab_http_status(:no_content) subject
end
end end
context 'when comparison is done' do it 'returns 204 HTTP status' do
let(:comparison_status) { { status: :parsed, data: { summary: 1 } } } subject
it 'does not send polling interval' do
expect(::Gitlab::PollingInterval).not_to receive(:set_header)
subject
end
it 'returns 200 HTTP status' do
subject
expect(response).to have_gitlab_http_status(:ok) expect(response).to have_gitlab_http_status(:no_content)
expect(json_response).to eq({ 'summary' => 1 })
end
end end
end
context 'when user created corrupted test reports' do context 'when comparison is done' do
let(:comparison_status) { { status: :error, status_reason: 'Failed to parse test reports' } } let(:comparison_status) { { status: :parsed, data: { summary: 1 } } }
it 'does not send polling interval' do it 'does not send polling interval' do
expect(::Gitlab::PollingInterval).not_to receive(:set_header) expect(::Gitlab::PollingInterval).not_to receive(:set_header)
subject subject
end end
it 'returns 400 HTTP status' do it 'returns 200 HTTP status' do
subject subject
expect(response).to have_gitlab_http_status(:bad_request) expect(response).to have_gitlab_http_status(:ok)
expect(json_response).to eq({ 'status_reason' => 'Failed to parse test reports' }) expect(json_response).to eq({ 'summary' => 1 })
end
end end
end
context 'when something went wrong on our system' do context 'when user created corrupted test reports' do
let(:comparison_status) { {} } let(:comparison_status) { { status: :error, status_reason: 'Failed to parse test reports' } }
it 'does not send polling interval' do it 'does not send polling interval' do
expect(::Gitlab::PollingInterval).not_to receive(:set_header) expect(::Gitlab::PollingInterval).not_to receive(:set_header)
subject subject
end end
it 'returns 500 HTTP status' do it 'returns 400 HTTP status' do
subject subject
expect(response).to have_gitlab_http_status(:internal_server_error) expect(response).to have_gitlab_http_status(:bad_request)
expect(json_response).to eq({ 'status_reason' => 'Unknown error' }) expect(json_response).to eq({ 'status_reason' => 'Failed to parse test reports' })
end
end end
end end
context 'when feature is not enabled' do context 'when something went wrong on our system' do
before do let(:comparison_status) { {} }
stub_feature_flags(metrics_reports: false)
it 'does not send polling interval' do
expect(::Gitlab::PollingInterval).not_to receive(:set_header)
subject
end end
it 'returns no content' do it 'returns 500 HTTP status' do
subject subject
expect(response).to have_gitlab_http_status(:bad_request) expect(response).to have_gitlab_http_status(:internal_server_error)
expect(json_response).to eq({ 'status_reason' => 'Unknown error' })
end end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment