161 lines
6.9 KiB
Ruby
161 lines
6.9 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe Users::BuildService do
|
|
describe '#execute' do
|
|
let(:params) do
|
|
{ name: 'John Doe', username: 'jduser', email: 'jd@example.com', password: 'mydummypass' }
|
|
end
|
|
|
|
context 'with an admin user' do
|
|
let(:admin_user) { create(:admin) }
|
|
let(:service) { described_class.new(admin_user, params) }
|
|
|
|
it 'returns a valid user' do
|
|
expect(service.execute).to be_valid
|
|
end
|
|
|
|
context 'with "user_default_external" application setting' do
|
|
using RSpec::Parameterized::TableSyntax
|
|
|
|
where(:user_default_external, :external, :email, :user_default_internal_regex, :result) do
|
|
true | nil | 'fl@example.com' | nil | true
|
|
true | true | 'fl@example.com' | nil | true
|
|
true | false | 'fl@example.com' | nil | false
|
|
|
|
true | nil | 'fl@example.com' | '' | true
|
|
true | true | 'fl@example.com' | '' | true
|
|
true | false | 'fl@example.com' | '' | false
|
|
|
|
true | nil | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
true | true | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | true
|
|
true | false | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
|
|
true | nil | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true
|
|
true | true | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true
|
|
true | false | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
|
|
false | nil | 'fl@example.com' | nil | false
|
|
false | true | 'fl@example.com' | nil | true
|
|
false | false | 'fl@example.com' | nil | false
|
|
|
|
false | nil | 'fl@example.com' | '' | false
|
|
false | true | 'fl@example.com' | '' | true
|
|
false | false | 'fl@example.com' | '' | false
|
|
|
|
false | nil | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
false | true | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | true
|
|
false | false | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
|
|
false | nil | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
false | true | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true
|
|
false | false | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
end
|
|
|
|
with_them do
|
|
before do
|
|
stub_application_setting(user_default_external: user_default_external)
|
|
stub_application_setting(user_default_internal_regex: user_default_internal_regex)
|
|
|
|
params.merge!({ external: external, email: email }.compact)
|
|
end
|
|
|
|
subject(:user) { service.execute }
|
|
|
|
it 'correctly sets user.external' do
|
|
expect(user.external).to eq(result)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with non admin user' do
|
|
let(:user) { create(:user) }
|
|
let(:service) { described_class.new(user, params) }
|
|
|
|
it 'raises AccessDeniedError exception' do
|
|
expect { service.execute }.to raise_error Gitlab::Access::AccessDeniedError
|
|
end
|
|
end
|
|
|
|
context 'with nil user' do
|
|
let(:service) { described_class.new(nil, params) }
|
|
|
|
it 'returns a valid user' do
|
|
expect(service.execute).to be_valid
|
|
end
|
|
|
|
context 'when "send_user_confirmation_email" application setting is true' do
|
|
before do
|
|
stub_application_setting(send_user_confirmation_email: true, signup_enabled?: true)
|
|
end
|
|
|
|
it 'does not confirm the user' do
|
|
expect(service.execute).not_to be_confirmed
|
|
end
|
|
end
|
|
|
|
context 'when "send_user_confirmation_email" application setting is false' do
|
|
before do
|
|
stub_application_setting(send_user_confirmation_email: false, signup_enabled?: true)
|
|
end
|
|
|
|
it 'confirms the user' do
|
|
expect(service.execute).to be_confirmed
|
|
end
|
|
end
|
|
|
|
context 'with "user_default_external" application setting' do
|
|
using RSpec::Parameterized::TableSyntax
|
|
|
|
where(:user_default_external, :external, :email, :user_default_internal_regex, :result) do
|
|
true | nil | 'fl@example.com' | nil | true
|
|
true | true | 'fl@example.com' | nil | true
|
|
true | false | 'fl@example.com' | nil | true
|
|
|
|
true | nil | 'fl@example.com' | '' | true
|
|
true | true | 'fl@example.com' | '' | true
|
|
true | false | 'fl@example.com' | '' | true
|
|
|
|
true | nil | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | true
|
|
true | true | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | true
|
|
true | false | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | true
|
|
|
|
true | nil | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true
|
|
true | true | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true
|
|
true | false | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true
|
|
|
|
false | nil | 'fl@example.com' | nil | false
|
|
false | true | 'fl@example.com' | nil | false
|
|
false | false | 'fl@example.com' | nil | false
|
|
|
|
false | nil | 'fl@example.com' | '' | false
|
|
false | true | 'fl@example.com' | '' | false
|
|
false | false | 'fl@example.com' | '' | false
|
|
|
|
false | nil | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
false | true | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
false | false | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
|
|
false | nil | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
false | true | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
false | false | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false
|
|
end
|
|
|
|
with_them do
|
|
before do
|
|
stub_application_setting(user_default_external: user_default_external)
|
|
stub_application_setting(user_default_internal_regex: user_default_internal_regex)
|
|
|
|
params.merge!({ external: external, email: email }.compact)
|
|
end
|
|
|
|
subject(:user) { service.execute }
|
|
|
|
it 'sets the value of Gitlab::CurrentSettings.user_default_external' do
|
|
expect(user.external).to eq(result)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|