4376167a04
This new table will be used to store the external_dashboard_url which allows users to add a link to their external dashboards (ex Grafana) to the Metrics dashboard.
174 lines
5.1 KiB
Ruby
174 lines
5.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
describe Projects::Operations::UpdateService do
|
|
set(:user) { create(:user) }
|
|
set(:project) { create(:project) }
|
|
|
|
let(:result) { subject.execute }
|
|
|
|
subject { described_class.new(project, user, params) }
|
|
|
|
describe '#execute' do
|
|
context 'metrics dashboard setting' do
|
|
let(:params) do
|
|
{
|
|
metrics_setting_attributes: {
|
|
external_dashboard_url: 'http://gitlab.com'
|
|
}
|
|
}
|
|
end
|
|
|
|
context 'without existing metrics dashboard setting' do
|
|
it 'creates a setting' do
|
|
expect(result[:status]).to eq(:success)
|
|
|
|
expect(project.reload.metrics_setting.external_dashboard_url).to eq(
|
|
'http://gitlab.com'
|
|
)
|
|
end
|
|
end
|
|
|
|
context 'with existing metrics dashboard setting' do
|
|
before do
|
|
create(:project_metrics_setting, project: project)
|
|
end
|
|
|
|
it 'updates the settings' do
|
|
expect(result[:status]).to eq(:success)
|
|
|
|
expect(project.reload.metrics_setting.external_dashboard_url).to eq(
|
|
'http://gitlab.com'
|
|
)
|
|
end
|
|
|
|
context 'with blank external_dashboard_url in params' do
|
|
let(:params) do
|
|
{
|
|
metrics_setting_attributes: {
|
|
external_dashboard_url: ''
|
|
}
|
|
}
|
|
end
|
|
|
|
it 'destroys the metrics_setting entry in DB' do
|
|
expect(result[:status]).to eq(:success)
|
|
|
|
expect(project.reload.metrics_setting).to be_nil
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'error tracking' do
|
|
context 'with existing error tracking setting' do
|
|
let(:params) do
|
|
{
|
|
error_tracking_setting_attributes: {
|
|
enabled: false,
|
|
api_host: 'http://gitlab.com/',
|
|
token: 'token',
|
|
project: {
|
|
slug: 'project',
|
|
name: 'Project',
|
|
organization_slug: 'org',
|
|
organization_name: 'Org'
|
|
}
|
|
}
|
|
}
|
|
end
|
|
|
|
before do
|
|
create(:project_error_tracking_setting, project: project)
|
|
end
|
|
|
|
it 'updates the settings' do
|
|
expect(result[:status]).to eq(:success)
|
|
|
|
project.reload
|
|
expect(project.error_tracking_setting).not_to be_enabled
|
|
expect(project.error_tracking_setting.api_url).to eq(
|
|
'http://gitlab.com/api/0/projects/org/project/'
|
|
)
|
|
expect(project.error_tracking_setting.token).to eq('token')
|
|
expect(project.error_tracking_setting[:project_name]).to eq('Project')
|
|
expect(project.error_tracking_setting[:organization_name]).to eq('Org')
|
|
end
|
|
|
|
context 'disable error tracking' do
|
|
before do
|
|
params[:error_tracking_setting_attributes][:api_host] = ''
|
|
params[:error_tracking_setting_attributes][:enabled] = false
|
|
end
|
|
|
|
it 'can set api_url to nil' do
|
|
expect(result[:status]).to eq(:success)
|
|
|
|
project.reload
|
|
expect(project.error_tracking_setting).not_to be_enabled
|
|
expect(project.error_tracking_setting.api_url).to be_nil
|
|
expect(project.error_tracking_setting.token).to eq('token')
|
|
expect(project.error_tracking_setting[:project_name]).to eq('Project')
|
|
expect(project.error_tracking_setting[:organization_name]).to eq('Org')
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'without an existing error tracking setting' do
|
|
let(:params) do
|
|
{
|
|
error_tracking_setting_attributes: {
|
|
enabled: true,
|
|
api_host: 'http://gitlab.com/',
|
|
token: 'token',
|
|
project: {
|
|
slug: 'project',
|
|
name: 'Project',
|
|
organization_slug: 'org',
|
|
organization_name: 'Org'
|
|
}
|
|
}
|
|
}
|
|
end
|
|
|
|
it 'creates a setting' do
|
|
expect(result[:status]).to eq(:success)
|
|
|
|
expect(project.error_tracking_setting).to be_enabled
|
|
expect(project.error_tracking_setting.api_url).to eq(
|
|
'http://gitlab.com/api/0/projects/org/project/'
|
|
)
|
|
expect(project.error_tracking_setting.token).to eq('token')
|
|
expect(project.error_tracking_setting[:project_name]).to eq('Project')
|
|
expect(project.error_tracking_setting[:organization_name]).to eq('Org')
|
|
end
|
|
end
|
|
|
|
context 'with invalid parameters' do
|
|
let(:params) { {} }
|
|
|
|
let!(:error_tracking_setting) do
|
|
create(:project_error_tracking_setting, project: project)
|
|
end
|
|
|
|
it 'does nothing' do
|
|
expect(result[:status]).to eq(:success)
|
|
expect(project.reload.error_tracking_setting)
|
|
.to eq(error_tracking_setting)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with inappropriate params' do
|
|
let(:params) { { name: '' } }
|
|
|
|
let!(:original_name) { project.name }
|
|
|
|
it 'ignores params' do
|
|
expect(result[:status]).to eq(:success)
|
|
expect(project.reload.name).to eq(original_name)
|
|
end
|
|
end
|
|
end
|
|
end
|