2017-08-17 22:00:37 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe API::V3::Settings, 'Settings' do
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:admin) { create(:admin) }
|
|
|
|
|
|
|
|
describe "GET /application/settings" do
|
|
|
|
it "returns application settings" do
|
|
|
|
get v3_api("/application/settings", admin)
|
|
|
|
expect(response).to have_http_status(200)
|
|
|
|
expect(json_response).to be_an Hash
|
|
|
|
expect(json_response['default_projects_limit']).to eq(42)
|
2017-09-10 17:25:29 +05:30
|
|
|
expect(json_response['password_authentication_enabled']).to be_truthy
|
2017-08-17 22:00:37 +05:30
|
|
|
expect(json_response['repository_storage']).to eq('default')
|
|
|
|
expect(json_response['koding_enabled']).to be_falsey
|
|
|
|
expect(json_response['koding_url']).to be_nil
|
|
|
|
expect(json_response['plantuml_enabled']).to be_falsey
|
|
|
|
expect(json_response['plantuml_url']).to be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "PUT /application/settings" do
|
|
|
|
context "custom repository storage type set in the config" do
|
|
|
|
before do
|
|
|
|
storages = { 'custom' => 'tmp/tests/custom_repositories' }
|
|
|
|
allow(Gitlab.config.repositories).to receive(:storages).and_return(storages)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "updates application settings" do
|
|
|
|
put v3_api("/application/settings", admin),
|
2017-09-10 17:25:29 +05:30
|
|
|
default_projects_limit: 3, password_authentication_enabled: false, repository_storage: 'custom', koding_enabled: true, koding_url: 'http://koding.example.com',
|
2017-08-17 22:00:37 +05:30
|
|
|
plantuml_enabled: true, plantuml_url: 'http://plantuml.example.com'
|
|
|
|
expect(response).to have_http_status(200)
|
|
|
|
expect(json_response['default_projects_limit']).to eq(3)
|
2017-09-10 17:25:29 +05:30
|
|
|
expect(json_response['password_authentication_enabled']).to be_falsey
|
2017-08-17 22:00:37 +05:30
|
|
|
expect(json_response['repository_storage']).to eq('custom')
|
|
|
|
expect(json_response['repository_storages']).to eq(['custom'])
|
|
|
|
expect(json_response['koding_enabled']).to be_truthy
|
|
|
|
expect(json_response['koding_url']).to eq('http://koding.example.com')
|
|
|
|
expect(json_response['plantuml_enabled']).to be_truthy
|
|
|
|
expect(json_response['plantuml_url']).to eq('http://plantuml.example.com')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "missing koding_url value when koding_enabled is true" do
|
|
|
|
it "returns a blank parameter error message" do
|
|
|
|
put v3_api("/application/settings", admin), koding_enabled: true
|
|
|
|
|
|
|
|
expect(response).to have_http_status(400)
|
|
|
|
expect(json_response['error']).to eq('koding_url is missing')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "missing plantuml_url value when plantuml_enabled is true" do
|
|
|
|
it "returns a blank parameter error message" do
|
|
|
|
put v3_api("/application/settings", admin), plantuml_enabled: true
|
|
|
|
|
|
|
|
expect(response).to have_http_status(400)
|
|
|
|
expect(json_response['error']).to eq('plantuml_url is missing')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|